Index: chrome/tools/profile_reset/jtl_compiler.h |
diff --git a/chrome/tools/profile_reset/jtl_compiler.h b/chrome/tools/profile_reset/jtl_compiler.h |
new file mode 100644 |
index 0000000000000000000000000000000000000000..fe3a68de1fa4ef35dd5b42085ae1789ae4641dc2 |
--- /dev/null |
+++ b/chrome/tools/profile_reset/jtl_compiler.h |
@@ -0,0 +1,73 @@ |
+// 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. |
+ |
+#ifndef CHROME_TOOLS_PROFILE_RESET_JTL_COMPILER_H_ |
+#define CHROME_TOOLS_PROFILE_RESET_JTL_COMPILER_H_ |
+ |
+#include <string> |
+ |
+#include "base/basictypes.h" |
+ |
+// Compiles text-based JTL source code into JTL byte-code. |
+// |
+// For an overview of JTL (JSON Traversal Language), and the exhaustive list of |
+// instructions, please see "chrome/browser/profile_resetter/jtl_foundation.h". |
+// |
+// The text-based JTL syntax itself much resembles C/C++. A program consists of |
+// zero or more sentences. Each sentence is terminated by a semi-colon (;), and |
+// is composed of *one* or more operations, separated by forward slashes (/). |
+// |
+// Each operation resembles a C/C++ function call and consists of an instruction |
+// name, and an optional argument list, which takes Boolean values and/or string |
+// literals. The text-based instruction names are defined in "jtl_compiler.cc". |
+// |
+// Whitespace does not matter, except for inside string literals. C++-style, |
+// double-slash-introduced comments are also supported. |
+// |
+// Example source code: |
+// |
+// // Store "x"=true if path "foo.bar" is found. |
+// node("foo")/node("bar")/store_bool("x", true); |
+// |
+// // Store "y"="1" if the above value is set. |
+// compare_stored_bool("x", true, false)/store_hash("y", "1"); |
+// |
+class JtlCompiler { |
+ public: |
+ struct CompileError { |
+ enum ErrorCode { |
+ ERROR_NONE, |
+ MISMATCHED_DOUBLE_QUOTES, |
+ PARSING_ERROR, |
+ INVALID_OPERATION_NAME, |
+ INVALID_ARGUMENT_COUNT, |
+ INVALID_ARGUMENT_TYPE |
+ }; |
+ |
+ CompileError() : line_number(0), error_code(ERROR_NONE) {} |
+ CompileError(size_t line_number, |
+ const std::string& context, |
+ ErrorCode error_code) |
+ : line_number(line_number), context(context), error_code(error_code) {} |
+ |
+ size_t line_number; // 0-based. |
+ std::string context; |
+ ErrorCode error_code; |
+ }; |
+ |
+ // Compiles text-based JTL source code contained in |source_code| into JTL |
+ // byte-code to |output_bytecode|. Variable, node names, and string literals |
+ // will be hashed using the seed in |hash_seed|. |
+ // On success, returns true. Otherwise, returns false and fills |error| with |
+ // more information (if it is non-NULL). |
+ static bool Compile(const std::string& source_code, |
+ const std::string& hash_seed, |
+ std::string* output_bytecode, |
+ CompileError* error); |
+ |
+ private: |
+ DISALLOW_IMPLICIT_CONSTRUCTORS(JtlCompiler); |
+}; |
+ |
+#endif // CHROME_TOOLS_PROFILE_RESET_JTL_COMPILER_H_ |