Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(56)

Unified Diff: tools/json_schema_compiler/cpp_util.py

Issue 10825029: Added JSON schema compiler support for serialized types (Closed) Base URL: http://git.chromium.org/chromium/src.git@master
Patch Set: More changes Created 8 years, 5 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « tools/json_schema_compiler/cpp_type_generator_test.py ('k') | tools/json_schema_compiler/h_generator.py » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: tools/json_schema_compiler/cpp_util.py
diff --git a/tools/json_schema_compiler/cpp_util.py b/tools/json_schema_compiler/cpp_util.py
index 1229fb8597654e10b785f2b9836a00ccc15fbd32..96a5cd36144a3beb2521e7dbbfd6497843a65a08 100644
--- a/tools/json_schema_compiler/cpp_util.py
+++ b/tools/json_schema_compiler/cpp_util.py
@@ -75,9 +75,47 @@ def GetParameterDeclaration(param, type_):
}
def GenerateIfndefName(path, filename):
- """Formats a path and filename as a #define name.
+ """Formats a path and filename as a #define name.
- e.g chrome/extensions/gen, file.h becomes CHROME_EXTENSIONS_GEN_FILE_H__.
- """
- return (('%s_%s_H__' % (path, filename))
- .upper().replace(os.sep, '_').replace('/', '_'))
+ e.g chrome/extensions/gen, file.h becomes CHROME_EXTENSIONS_GEN_FILE_H__.
+ """
+ return (('%s_%s_H__' % (path, filename))
+ .upper().replace(os.sep, '_').replace('/', '_'))
+
+def GenerateTypeToCompiledTypeConversion(prop, from_, to):
+ try:
+ return _GenerateTypeConversionHelper(prop.type_, prop.compiled_type, from_,
+ to)
+ except KeyError:
+ raise NotImplementedError('Conversion from %s to %s in %s not supported' %
+ (prop.type_, prop.compiled_type, prop.name))
+
+def GenerateCompiledTypeToTypeConversion(prop, from_, to):
+ try:
+ return _GenerateTypeConversionHelper(prop.compiled_type, prop.type_, from_,
+ to)
+ except KeyError:
+ raise NotImplementedError('Conversion from %s to %s in %s not supported' %
+ (prop.compiled_type, prop.type_, prop.name))
+
+def _GenerateTypeConversionHelper(from_type, to_type, from_, to):
+ """Converts from PropertyType from_type to PropertyType to_type.
+
+ from_type: The PropertyType to be converted from.
+ to_type: The PropertyType to be converted to.
+ from_: The variable name of the type to be converted from.
+ to: The variable name of the type to be converted to.
+ """
+ # TODO(mwrosen): Add support for more from/to combinations as necessary.
+ return {
+ PropertyType.STRING: {
+ PropertyType.INTEGER: 'base::StringToInt(%(from)s, &%(to)s)',
+ PropertyType.INT64: 'base::StringToInt64(%(from)s, &%(to)s)',
+ },
+ PropertyType.INTEGER: {
+ PropertyType.STRING: '%(to)s = base::IntToString(%(from)s)',
+ },
+ PropertyType.INT64: {
+ PropertyType.STRING: '%(to)s = base::Int64ToString(%(from)s)',
+ }
+ }[from_type][to_type] % {'from': from_, 'to': to}
« no previous file with comments | « tools/json_schema_compiler/cpp_type_generator_test.py ('k') | tools/json_schema_compiler/h_generator.py » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698