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

Unified Diff: tools/json_schema_compiler/util_cc_helper.py

Issue 9309044: Supporting more APIs with json_schema_compiler (Closed) Base URL: http://git.chromium.org/chromium/src.git@master
Patch Set: fixed optional properties Created 8 years, 11 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
« tools/json_schema_compiler/util.cc ('K') | « tools/json_schema_compiler/util.cc ('k') | no next file » | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: tools/json_schema_compiler/util_cc_helper.py
diff --git a/tools/json_schema_compiler/util_cc_helper.py b/tools/json_schema_compiler/util_cc_helper.py
new file mode 100644
index 0000000000000000000000000000000000000000..a079ccc434f5b99f7b8705c48e9351260ddd864b
--- /dev/null
+++ b/tools/json_schema_compiler/util_cc_helper.py
@@ -0,0 +1,99 @@
+from model import PropertyType
+import code
+
+API_UTIL_NAMESPACE = 'json_schema_compiler::util'
+
+class UtilCCHelper(object):
+ """A util class that generates code that uses tools/json_schema_compiler/util.cc.
+ """
not at google - send to devlin 2012/02/05 23:42:12 line length
calamity 2012/02/06 11:51:18 Done.
+ def __init__(self, type_manager):
+ self.type_manager = type_manager
not at google - send to devlin 2012/02/05 23:42:12 type_manager should be private
calamity 2012/02/06 11:51:18 Done.
+
+ def GetArray(self, array_prop, src, name, dst):
+ """Generates code to get an array from a src.name into dst.
+
+ src: DictionaryValue*
+ dst: std::vector or scoped_ptr<std::vector>
+ """
+ prop = array_prop.item_type
+ sub = {
+ 'namespace': API_UTIL_NAMESPACE,
+ 'name': name,
+ 'src': src,
+ 'dst': dst,
+ }
+
+ sub['type'] = self.type_manager.GetType(prop)
+ if array_prop.optional:
+ val = '%(namespace)s::GetOptionalArrayFromDictionary(*%(src)s, "%(name)s", &%(dst)s)'
+ else:
+ val = '%(namespace)s::GetArrayFromDictionary(*%(src)s, "%(name)s", &%(dst)s)'
+
+ return val % sub
+
+ def GetArrayFromList(self, array_prop, src, dst):
+ """Generates code to get an array from src into dst.
+
+ src: ListValue*
+ dst: std::vector or scoped_ptr<std::vector>
+ """
+ prop = array_prop.item_type
+ sub = {
+ 'namespace': API_UTIL_NAMESPACE,
+ 'src': src,
+ 'dst': dst,
+ 'type': self.type_manager.GetType(prop),
+ }
+
+ if array_prop.optional:
+ val = '%(namespace)s::GetOptionalArrayFromList(*%(src)s, &%(dst)s)'
+ else:
+ val = '%(namespace)s::GetArrayFromList(*%(src)s, &%(dst)s)'
+
+ return val % sub
+
+ def SetArray(self, array_prop, src, name, dst):
+ """Sets dst.name to the array at src
+
+ src: std::vector or scoped_ptr<std::vector>
+ dst: DictionaryValue*
+ """
+ prop = array_prop.item_type
+ sub = {
+ 'namespace': API_UTIL_NAMESPACE,
+ 'src': src,
+ 'name': name,
+ 'dst': dst,
+ 'type': self.type_manager.GetType(prop),
+ }
+
+ if array_prop.optional:
+ val = '%(namespace)s::SetOptionalArrayToDictionary(%(src)s, "%(name)s", %(dst)s)'
not at google - send to devlin 2012/02/05 23:42:12 line wrap
calamity 2012/02/06 11:51:18 Done.
+ else:
+ val = '%(namespace)s::SetArrayToDictionary(%(src)s, "%(name)s", %(dst)s)'
+
+ return val % sub
+
+ def SetArrayToList(self, array_prop, src, dst):
+ """Sets dst to the array at src
+
+ src: std::vector or scoped_ptr<std::vector>
+ dst: ListValue*
+ """
+ prop = array_prop.item_type
+ sub = {
+ 'namespace': API_UTIL_NAMESPACE,
+ 'src': src,
+ 'dst': dst,
+ 'type': self.type_manager.GetType(prop),
+ }
+
+ if array_prop.optional:
+ val = '%(namespace)s::SetOptionalArrayToList(%(src)s, %(dst)s)'
+ else:
+ val = '%(namespace)s::SetArrayToList(%(src)s, %(dst)s)'
+
+ return val % sub
+
+ def GetIncludePath(self):
+ return '#include "tools/json_schema_compiler/util.h"'
« tools/json_schema_compiler/util.cc ('K') | « tools/json_schema_compiler/util.cc ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698