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

Side by Side Diff: mojo/public/bindings/generators/mojom_cpp_generator.py

Issue 138143003: Support default values for POD struct fields in mojom IDL. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: . Created 6 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 unified diff | Download patch | Annotate | Revision Log
OLDNEW
1 # Copyright 2013 The Chromium Authors. All rights reserved. 1 # Copyright 2013 The Chromium Authors. All rights reserved.
2 # Use of this source code is governed by a BSD-style license that can be 2 # Use of this source code is governed by a BSD-style license that can be
3 # found in the LICENSE file. 3 # found in the LICENSE file.
4 4
5 """Generates C++ source files from a mojom.Module.""" 5 """Generates C++ source files from a mojom.Module."""
6 6
7 import mojom 7 import mojom
8 import mojom_pack 8 import mojom_pack
9 import mojom_generator 9 import mojom_generator
10 10
(...skipping 88 matching lines...) Expand 10 before | Expand all | Expand 10 after
99 99
100 cpp_filters = { 100 cpp_filters = {
101 "camel_to_underscores": mojom_generator.CamelToUnderscores, 101 "camel_to_underscores": mojom_generator.CamelToUnderscores,
102 "cpp_const_wrapper_type": GetCppConstWrapperType, 102 "cpp_const_wrapper_type": GetCppConstWrapperType,
103 "cpp_field_type": GetCppFieldType, 103 "cpp_field_type": GetCppFieldType,
104 "cpp_type": GetCppType, 104 "cpp_type": GetCppType,
105 "cpp_wrapper_type": GetCppWrapperType, 105 "cpp_wrapper_type": GetCppWrapperType,
106 "get_pad": mojom_pack.GetPad, 106 "get_pad": mojom_pack.GetPad,
107 "is_handle_kind": mojom_generator.IsHandleKind, 107 "is_handle_kind": mojom_generator.IsHandleKind,
108 "is_object_kind": mojom_generator.IsObjectKind, 108 "is_object_kind": mojom_generator.IsObjectKind,
109 "is_string_kind": mojom_generator.IsStringKind,
109 "is_struct_with_handles": IsStructWithHandles, 110 "is_struct_with_handles": IsStructWithHandles,
110 "struct_size": lambda ps: ps.GetTotalSize() + _HEADER_SIZE, 111 "struct_size": lambda ps: ps.GetTotalSize() + _HEADER_SIZE,
111 "struct_from_method": mojom_generator.GetStructFromMethod, 112 "struct_from_method": mojom_generator.GetStructFromMethod,
112 "stylize_method": mojom_generator.StudlyCapsToCamel, 113 "stylize_method": mojom_generator.StudlyCapsToCamel,
113 } 114 }
114 115
115 @UseJinja("cpp_templates/module.h.tmpl", filters=cpp_filters) 116 @UseJinja("cpp_templates/module.h.tmpl", filters=cpp_filters)
116 def GenerateModuleHeader(self): 117 def GenerateModuleHeader(self):
117 return { 118 return {
118 "module_name": self.module.name, 119 "module_name": self.module.name,
(...skipping 31 matching lines...) Expand 10 before | Expand all | Expand 10 after
150 self.Write(self.GenerateModuleInternalHeader(), 151 self.Write(self.GenerateModuleInternalHeader(),
151 "%s_internal.h" % self.module.name) 152 "%s_internal.h" % self.module.name)
152 self.Write(self.GenerateModuleSource(), "%s.cc" % self.module.name) 153 self.Write(self.GenerateModuleSource(), "%s.cc" % self.module.name)
153 154
154 def GetIncludePrefix(self): 155 def GetIncludePrefix(self):
155 if not self.header_dir: 156 if not self.header_dir:
156 return "" 157 return ""
157 if self.header_dir[-1] == "/": 158 if self.header_dir[-1] == "/":
158 return self.header_dir 159 return self.header_dir
159 return self.header_dir + "/" 160 return self.header_dir + "/"
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698