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

Side by Side Diff: mojo/public/tools/bindings/mojom_bindings_generator.py

Issue 1751563002: Mojo C++ bindings: support mapping mojo string to WTF::String. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: sync & rebase Created 4 years, 9 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
OLDNEW
1 #!/usr/bin/env python 1 #!/usr/bin/env python
2 # Copyright 2013 The Chromium Authors. All rights reserved. 2 # Copyright 2013 The Chromium Authors. All rights reserved.
3 # Use of this source code is governed by a BSD-style license that can be 3 # Use of this source code is governed by a BSD-style license that can be
4 # found in the LICENSE file. 4 # found in the LICENSE file.
5 5
6 """The frontend for the Mojo bindings system.""" 6 """The frontend for the Mojo bindings system."""
7 7
8 8
9 import argparse 9 import argparse
10 import imp 10 import imp
(...skipping 125 matching lines...) Expand 10 before | Expand all | Expand 10 after
136 module.path = os.path.relpath(os.path.abspath(filename), 136 module.path = os.path.relpath(os.path.abspath(filename),
137 os.path.abspath(args.depth)) 137 os.path.abspath(args.depth))
138 138
139 # Normalize to unix-style path here to keep the generators simpler. 139 # Normalize to unix-style path here to keep the generators simpler.
140 module.path = module.path.replace('\\', '/') 140 module.path = module.path.replace('\\', '/')
141 141
142 if self._should_generate(filename): 142 if self._should_generate(filename):
143 for language, generator_module in generator_modules.iteritems(): 143 for language, generator_module in generator_modules.iteritems():
144 generator = generator_module.Generator( 144 generator = generator_module.Generator(
145 module, args.output_dir, typemap=self._typemap.get(language, {}), 145 module, args.output_dir, typemap=self._typemap.get(language, {}),
146 variant=args.variant, bytecode_path=args.bytecode_path) 146 variant=args.variant, bytecode_path=args.bytecode_path,
147 for_blink=args.for_blink)
147 filtered_args = [] 148 filtered_args = []
148 if hasattr(generator_module, 'GENERATOR_PREFIX'): 149 if hasattr(generator_module, 'GENERATOR_PREFIX'):
149 prefix = '--' + generator_module.GENERATOR_PREFIX + '_' 150 prefix = '--' + generator_module.GENERATOR_PREFIX + '_'
150 filtered_args = [arg for arg in remaining_args 151 filtered_args = [arg for arg in remaining_args
151 if arg.startswith(prefix)] 152 if arg.startswith(prefix)]
152 generator.GenerateFiles(filtered_args) 153 generator.GenerateFiles(filtered_args)
153 154
154 # Save result. 155 # Save result.
155 self._processed_files[filename] = module 156 self._processed_files[filename] = module
156 return module 157 return module
(...skipping 88 matching lines...) Expand 10 before | Expand all | Expand 10 after
245 generate_parser.add_argument("--typemap", action="append", metavar="TYPEMAP", 246 generate_parser.add_argument("--typemap", action="append", metavar="TYPEMAP",
246 default=[], dest="typemaps", 247 default=[], dest="typemaps",
247 help="apply TYPEMAP to generated output") 248 help="apply TYPEMAP to generated output")
248 generate_parser.add_argument("--variant", dest="variant", default=None, 249 generate_parser.add_argument("--variant", dest="variant", default=None,
249 help="output a named variant of the bindings") 250 help="output a named variant of the bindings")
250 generate_parser.add_argument( 251 generate_parser.add_argument(
251 "--bytecode_path", type=str, required=True, help=( 252 "--bytecode_path", type=str, required=True, help=(
252 "the path from which to load template bytecode; to generate template " 253 "the path from which to load template bytecode; to generate template "
253 "bytecode, run %s precompile BYTECODE_PATH" % os.path.basename( 254 "bytecode, run %s precompile BYTECODE_PATH" % os.path.basename(
254 sys.argv[0]))) 255 sys.argv[0])))
256 generate_parser.add_argument("--for_blink", action="store_true",
257 help="Use WTF types as generated types for mojo "
258 "string/array/map.")
255 generate_parser.set_defaults(func=_Generate) 259 generate_parser.set_defaults(func=_Generate)
256 260
257 precompile_parser = subparsers.add_parser("precompile", 261 precompile_parser = subparsers.add_parser("precompile",
258 description="Precompile templates for the mojom bindings generator.") 262 description="Precompile templates for the mojom bindings generator.")
259 precompile_parser.add_argument( 263 precompile_parser.add_argument(
260 "-o", "--output_dir", dest="output_dir", default=".", 264 "-o", "--output_dir", dest="output_dir", default=".",
261 help="output directory for precompiled templates") 265 help="output directory for precompiled templates")
262 precompile_parser.set_defaults(func=_Precompile) 266 precompile_parser.set_defaults(func=_Precompile)
263 267
264 args, remaining_args = parser.parse_known_args() 268 args, remaining_args = parser.parse_known_args()
265 return args.func(args, remaining_args) 269 return args.func(args, remaining_args)
266 270
267 271
268 if __name__ == "__main__": 272 if __name__ == "__main__":
269 sys.exit(main()) 273 sys.exit(main())
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698