Index: chrome/tools/profile_reset/jtl_compiler_frontend.cc |
diff --git a/chrome/tools/profile_reset/jtl_compiler_frontend.cc b/chrome/tools/profile_reset/jtl_compiler_frontend.cc |
deleted file mode 100644 |
index b17220547ec4c8d7f6ed9426e368a727e4a9f36c..0000000000000000000000000000000000000000 |
--- a/chrome/tools/profile_reset/jtl_compiler_frontend.cc |
+++ /dev/null |
@@ -1,112 +0,0 @@ |
-// Copyright 2013 The Chromium Authors. All rights reserved. |
-// Use of this source code is governed by a BSD-style license that can be |
-// found in the LICENSE file. |
-// |
-// A simple command-line compiler for JTL (JSON Traversal Language). |
-// |
-// Translates rules from a text-based, human-readable format to an easy-to-parse |
-// byte-code format, which then can be interpreted by JtlInterpreter. |
-// |
-// Example usage: |
-// jtl_compiler --input=blah.txt --hash-seed="foobar" --output=blah.dat |
- |
-#include <iostream> |
-#include <string> |
- |
-#include "base/command_line.h" |
-#include "base/file_util.h" |
-#include "base/files/file_path.h" |
-#include "chrome/tools/profile_reset/jtl_compiler.h" |
- |
-namespace { |
- |
-// Command-line argument name: path to the input text-based JTL source code. |
-const char kInputPath[] = "input"; |
- |
-// Command-line argument name: path to the output byte-code. |
-const char kOutputPath[] = "output"; |
- |
-// Command-line argument name: the hash seed to use. |
-const char kHashSeed[] = "hash-seed"; |
- |
-// Error codes. |
-const char kMismatchedDoubleQuotes[] = "Mismatched double-quotes before EOL."; |
-const char kParsingError[] = "Parsing error. Input is ill-formed."; |
-const char kArgumentCountError[] = "Wrong number of arguments for operation."; |
-const char kArgumentTypeError[] = "Wrong argument type(s) for operation."; |
-const char kArgumentValueError[] = "Wrong argument value(s) for operation."; |
-const char kUnknownOperationError[] = "No operation by this name."; |
-const char kUnknownError[] = "Unknown error."; |
- |
-const char* ResolveErrorCode(JtlCompiler::CompileError::ErrorCode code) { |
- switch (code) { |
- case JtlCompiler::CompileError::MISMATCHED_DOUBLE_QUOTES: |
- return kMismatchedDoubleQuotes; |
- case JtlCompiler::CompileError::PARSING_ERROR: |
- return kParsingError; |
- case JtlCompiler::CompileError::INVALID_ARGUMENT_COUNT: |
- return kArgumentCountError; |
- case JtlCompiler::CompileError::INVALID_ARGUMENT_TYPE: |
- return kArgumentTypeError; |
- case JtlCompiler::CompileError::INVALID_ARGUMENT_VALUE: |
- return kArgumentValueError; |
- case JtlCompiler::CompileError::INVALID_OPERATION_NAME: |
- return kUnknownOperationError; |
- default: |
- return kUnknownError; |
- } |
-} |
- |
-} // namespace |
- |
-int main(int argc, char* argv[]) { |
- CommandLine::Init(argc, argv); |
- CommandLine* cmd_line = CommandLine::ForCurrentProcess(); |
- if (!cmd_line->HasSwitch(kInputPath) || !cmd_line->HasSwitch(kHashSeed) || |
- !cmd_line->HasSwitch(kOutputPath)) { |
- std::cerr << "Usage: " << argv[0] << " <required switches>" << std::endl; |
- std::cerr << "\nRequired switches are:" << std::endl; |
- std::cerr << " --" << kInputPath << "=<file>" |
- << "\t\tPath to the input text-based JTL source code." |
- << std::endl; |
- std::cerr << " --" << kOutputPath << "=<file>" |
- << "\t\tPath to the output byte-code." << std::endl; |
- std::cerr << " --" << kHashSeed << "=<value>" |
- << "\t\tThe hash seed to use." << std::endl; |
- return -1; |
- } |
- |
- base::FilePath source_code_path = |
- MakeAbsoluteFilePath(cmd_line->GetSwitchValuePath(kInputPath)); |
- std::string source_code; |
- if (!base::ReadFileToString(source_code_path, &source_code)) { |
- std::cerr << "ERROR: Cannot read input file." << std::endl; |
- return -3; |
- } |
- |
- std::string bytecode; |
- JtlCompiler::CompileError error; |
- std::string hash_seed = cmd_line->GetSwitchValueASCII(kHashSeed); |
- if (!JtlCompiler::Compile(source_code, hash_seed, &bytecode, &error)) { |
- std::cerr << "COMPILE ERROR: " << ResolveErrorCode(error.error_code) |
- << std::endl; |
- std::cerr << " Line number: " << (error.line_number + 1) << std::endl; |
- std::cerr << " Context: " << (error.context.size() > 63 |
- ? error.context.substr(0, 60) + "..." |
- : error.context) << std::endl; |
- return -2; |
- } |
- |
- base::FilePath bytecode_path = |
- MakeAbsoluteFilePath(cmd_line->GetSwitchValuePath(kOutputPath)); |
- int bytes_written = |
- base::WriteFile(cmd_line->GetSwitchValuePath(kOutputPath), |
- bytecode.data(), |
- static_cast<int>(bytecode.size())); |
- if (bytes_written != static_cast<int>(bytecode.size())) { |
- std::cerr << "ERROR: Cannot write output file." << std::endl; |
- return -3; |
- } |
- |
- return 0; |
-} |