Chromium Code Reviews| Index: tools/json_schema_compiler/h_generator.py |
| diff --git a/tools/json_schema_compiler/h_generator.py b/tools/json_schema_compiler/h_generator.py |
| index 7cf6836fbf00ae8d92d79d166c46c056ea7c0665..a0a79f6d5ff1bed606c20f64e976aa8043c1f9c5 100644 |
| --- a/tools/json_schema_compiler/h_generator.py |
| +++ b/tools/json_schema_compiler/h_generator.py |
| @@ -26,6 +26,8 @@ class _Generator(object): |
| self._cpp_namespace = cpp_namespace |
| self._target_namespace = ( |
| self._type_helper.GetCppNamespaceName(self._namespace)) |
| + self._generate_error_messages = namespace.compiler_options.get( |
| + 'generate_error_messages', False) |
| def Generate(self): |
| """Generates a Code object with the .h for a single namespace. |
| @@ -227,15 +229,15 @@ class _Generator(object): |
| (c.Append() |
| .Comment('Populates a %s object from a base::Value. Returns' |
| ' whether |out| was successfully populated.' % classname) |
| - .Append('static bool Populate(const base::Value& value, ' |
| - '%(classname)s* out);') |
| + .Append('static bool Populate(%s);' % self._GenerateParams( |
| + ['const base::Value& value', '%s* out' % classname])) |
|
not at google - send to devlin
2013/06/14 21:48:39
for all of these, pass in a tuple not a list, cc_g
Aaron Jacobs
2013/06/15 00:47:18
Done.
|
| ) |
| if is_toplevel: |
| (c.Append() |
| .Comment('Creates a %s object from a base::Value, or NULL on ' |
| 'failure.' % classname) |
| - .Append('static scoped_ptr<%(classname)s> ' |
| - 'FromValue(const base::Value& value);') |
| + .Append('static scoped_ptr<%s> FromValue(%s);' % ( |
| + classname, self._GenerateParams(['const base::Value& value']))) |
| ) |
| if type_.origin.from_client: |
| (c.Append() |
| @@ -278,8 +280,8 @@ class _Generator(object): |
| if type_.origin.from_json: |
| (c.Comment('Populates a %s object from a base::Value. Returns' |
| ' whether |out| was successfully populated.' % classname) |
| - .Append('static bool Populate(const base::Value& value, ' |
| - '%(classname)s* out);') |
| + .Append('static bool Populate(%s);' % self._GenerateParams( |
| + ['const base::Value& value', '%s* out' % classname])) |
| .Append() |
| ) |
| if type_.origin.from_client: |
| @@ -338,7 +340,8 @@ class _Generator(object): |
| c = Code() |
| (c.Sblock('struct Params {') |
| - .Append('static scoped_ptr<Params> Create(const base::ListValue& args);') |
| + .Append('static scoped_ptr<Params> Create(%s);' % self._GenerateParams( |
| + ['const base::ListValue& args'])) |
| .Append('~Params();') |
| .Append() |
| .Cblock(self._GenerateTypes(p.type_ for p in function.params)) |
| @@ -391,3 +394,10 @@ class _Generator(object): |
| .Append('} // namespace Results') |
| ) |
| return c |
| + |
| + def _GenerateParams(self, params): |
| + """Builds the parameter list for a function, given an array of parameters. |
| + """ |
| + if self._generate_error_messages: |
| + params.append('std::string* error = NULL') |
| + return ', '.join(params) |