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

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

Issue 53173008: Add mojom_bindings_generator.gypi (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: One more rename Created 7 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 | Annotate | Revision Log
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 os 9 import os
10 import sys 10 import sys
11 from optparse import OptionParser 11 from optparse import OptionParser
12 from parser import mojo_parser 12 from parse import mojo_parser
13 from parser import mojo_translate 13 from parse import mojo_translate
14 from generators import mojom_data 14 from generators import mojom_data
15 from generators import mojom_cpp_generator 15 from generators import mojom_cpp_generator
16 16
17 17
18 def Main(): 18 def Main():
19 parser = OptionParser(usage="usage: %prog [options] filename1 [filename2...]") 19 parser = OptionParser(usage="usage: %prog [options] filename1 [filename2...]")
20 parser.add_option("-i", "--include_dir", dest="include_dir", default=".", 20 parser.add_option("-i", "--include_dir", dest="include_dir", default=".",
21 help="specify directory for #includes") 21 help="specify directory for #includes")
22 parser.add_option("-o", "--output_dir", dest="output_dir", default=".", 22 parser.add_option("-o", "--output_dir", dest="output_dir", default=".",
23 help="specify output directory") 23 help="specify output directory")
24 (options, args) = parser.parse_args() 24 (options, args) = parser.parse_args()
25 25
26 if len(args) < 1: 26 if len(args) < 1:
27 parser.print_help() 27 parser.print_help()
28 sys.exit(1) 28 sys.exit(1)
29 29
30 if not os.path.exists(options.output_dir):
31 os.makedirs(options.output_dir)
32
30 for filename in args: 33 for filename in args:
31 name = os.path.splitext(os.path.basename(filename))[0] 34 name = os.path.splitext(os.path.basename(filename))[0]
32 # TODO(darin): There's clearly too many layers of translation here! We can 35 # TODO(darin): There's clearly too many layers of translation here! We can
33 # at least avoid generating the serialized Mojom IR. 36 # at least avoid generating the serialized Mojom IR.
34 tree = mojo_parser.Parse(filename) 37 tree = mojo_parser.Parse(filename)
35 mojom = mojo_translate.Translate(tree, name) 38 mojom = mojo_translate.Translate(tree, name)
36 module = mojom_data.ModuleFromData(mojom) 39 module = mojom_data.ModuleFromData(mojom)
37 cpp = mojom_cpp_generator.CPPGenerator( 40 cpp = mojom_cpp_generator.CPPGenerator(
38 module, options.include_dir, options.output_dir) 41 module, options.include_dir, options.output_dir)
39 cpp.GenerateFiles() 42 cpp.GenerateFiles()
40 43
41 44
42 if __name__ == '__main__': 45 if __name__ == '__main__':
43 Main() 46 Main()
OLDNEW
« no previous file with comments | « mojo/public/bindings/mojom_bindings_generator.gypi ('k') | mojo/public/bindings/parse/__init__.py » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698