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

Side by Side Diff: tools/json_to_struct/element_generator.py

Issue 11377049: Moving prepopulated search engines to a JSON file. (Closed) Base URL: http://git.chromium.org/chromium/src.git@master
Patch Set: Rebased to fix conflict. Created 8 years, 1 month 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 unified diff | Download patch
« no previous file with comments | « tools/json_to_struct/PRESUBMIT.py ('k') | tools/json_to_struct/element_generator_test.py » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
(Empty)
1 # Copyright (c) 2012 The Chromium Authors. All rights reserved.
2 # Use of this source code is governed by a BSD-style license that can be
3 # found in the LICENSE file.
4
5 import json
6 import struct_generator
7
8 def _JSONToCString16(json_string_literal):
9 """Converts a JSON string literal to a C++ UTF-16 string literal. This is
10 done by converting \\u#### to \\x####.
11 """
12 c_string_literal = json_string_literal
13 escape_index = c_string_literal.find('\\')
14 while escape_index > 0:
15 if c_string_literal[escape_index + 1] == 'u':
16 # We close the C string literal after the 4 hex digits and reopen it right
17 # after, otherwise the Windows compiler will sometimes try to get more
18 # than 4 characters in the hex string.
19 c_string_literal = (c_string_literal[0:escape_index + 1] + 'x' +
20 c_string_literal[escape_index + 2:escape_index + 6] + '" L"' +
21 c_string_literal[escape_index + 6:])
22 escape_index = c_string_literal.find('\\', escape_index + 6)
23 return c_string_literal
24
25 def _GenerateString(content, lines):
26 """Generates an UTF-8 string to be included in a static structure initializer.
27 If content is not specified, uses NULL.
28 """
29 if content is None:
30 lines.append(' NULL,')
31 else:
32 # json.dumps quotes the string and escape characters as required.
33 lines.append(' %s,' % json.dumps(content))
34
35 def _GenerateString16(content, lines):
36 """Generates an UTF-16 string to be included in a static structure
37 initializer. If content is not specified, uses NULL.
38 """
39 if content is None:
40 lines.append(' NULL,')
41 else:
42 # json.dumps quotes the string and escape characters as required.
43 lines.append(' L%s,' % _JSONToCString16(json.dumps(content)))
44
45 def _GenerateArray(field_info, content, lines):
46 """Generates an array to be included in a static structure initializer. If
47 content is not specified, uses NULL. The array is assigned to a temporary
48 variable which is initialized before the structure.
49 """
50 if content is None:
51 lines.append(' NULL,')
52 lines.append(' 0,') # Size of the array.
53 return
54
55 # Create a new array variable and use it in the structure initializer.
56 # This prohibits nested arrays. Add a clash detection and renaming mechanism
57 # to solve the problem.
58 var = 'array_%s' % field_info['field'];
59 lines.append(' %s,' % var)
60 lines.append(' %s,' % len(content)) # Size of the array.
61 # Generate the array content.
62 array_lines = []
63 field_info['contents']['field'] = var;
64 array_lines.append(struct_generator.GenerateField(
65 field_info['contents']) + '[] = {')
66 for subcontent in content:
67 GenerateFieldContent(field_info['contents'], subcontent, array_lines)
68 array_lines.append('};')
69 # Prepend the generated array so it is initialized before the structure.
70 lines.reverse()
71 array_lines.reverse()
72 lines.extend(array_lines)
73 lines.reverse()
74
75 def GenerateFieldContent(field_info, content, lines):
76 """Generate the content of a field to be included in the static structure
77 initializer. If the field's content is not specified, uses the default value
78 if one exists.
79 """
80 if content is None:
81 content = field_info.get('default', None)
82 type = field_info['type']
83 if type == 'int' or type == 'enum':
84 lines.append(' %s,' % content)
85 elif type == 'string':
86 _GenerateString(content, lines)
87 elif type == 'string16':
88 _GenerateString16(content, lines)
89 elif type == 'array':
90 _GenerateArray(field_info, content, lines)
91 else:
92 raise RuntimeError('Unknown field type "%s"' % type)
93
94 def GenerateElement(type_name, schema, element_name, element):
95 """Generate the static structure initializer for one element.
96 """
97 lines = [];
98 lines.append('const %s %s = {' % (type_name, element_name));
99 for field_info in schema:
100 content = element.get(field_info['field'], None)
101 if (content == None and not field_info.get('optional', False)):
102 raise RuntimeError('Mandatory field "%s" omitted in element "%s".' %
103 (field_info['field'], element_name))
104 GenerateFieldContent(field_info, content, lines)
105 lines.append('};')
106 return '\n'.join(lines)
107
108 def GenerateElements(type_name, schema, description):
109 """Generate the static structure initializer for all the elements in the
110 description['elements'] dictionary, as well as for any variables in
111 description['int_variables'].
112 """
113 result = [];
114 for var_name, value in description.get('int_variables', {}).items():
115 result.append('const int %s = %s;' % (var_name, value))
116 result.append('')
117
118 for element_name, element in description.get('elements', {}).items():
119 result.append(GenerateElement(type_name, schema, element_name, element))
120 result.append('')
121 return '\n'.join(result)
OLDNEW
« no previous file with comments | « tools/json_to_struct/PRESUBMIT.py ('k') | tools/json_to_struct/element_generator_test.py » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698