OLD | NEW |
---|---|
(Empty) | |
1 # Copyright 2014 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 # Defines a static library corresponding to the output of schema compiler tools | |
6 # over a set of extensions API schemas (IDL or JSON format.) The library target | |
7 # has implicit hard dependencies on all schema files listed by the invoker and | |
8 # is itself a hard dependency. | |
9 # | |
10 # Invocations of this template may use the following variables: | |
11 # | |
12 # schemas [required] A list of schema files to be compiled. | |
brettw
2014/04/24 18:29:44
I'm thinking we should generally name this kind of
Ken Rockot(use gerrit already)
2014/04/24 19:39:54
Debated this for a while myself. I agree with your
| |
13 # | |
14 # root_namespace [required] The namespace in which generated API code is to be | |
15 # wrapped. C++ namespace syntax is accepted for nested namespace | |
16 # (e.g. "foo::bar::api"). | |
17 # | |
18 # impl_dir [required] The path containing C++ implementations of API functions. | |
19 # This path is used as the root path when looking for | |
20 # {schema}/{schema}_api.h headers during the API bundle generation phase. | |
21 # Such headers, if found, are automatically included by the generated code. | |
22 # | |
23 # uncompiled_schemas [optional] A list of schema files which should not be | |
24 # compiled, but which should still be processed for API bundle generation. | |
25 # | |
26 # deps [optional] If any deps are specified they will be inherited by the | |
27 # static library target. | |
28 # | |
29 # The static libarary target also inherits the visibility and output_name | |
30 # of its invoker. | |
31 | |
32 template("generated_extensions_api") { | |
33 assert(defined(invoker.schemas), | |
34 "\"schemas\" must be defined for the $target_name template.") | |
35 assert(defined(invoker.root_namespace), | |
36 "\"root_namespace\" must be defined for the $target_name template.") | |
37 assert(defined(invoker.impl_dir), | |
38 "\"impl_dir\" must be defined for the $target_name template.") | |
39 | |
40 # Keep a copy of the target_name here since it will be trampled | |
41 # in nested targets. | |
42 target_visibility = ":$target_name" | |
43 | |
44 generated_config_name = target_name + "_generated_config" | |
45 config(generated_config_name) { | |
46 include_dirs = [ target_gen_dir ] | |
47 visibility = target_visibility | |
48 } | |
49 | |
50 schemas = invoker.schemas | |
51 root_namespace = invoker.root_namespace | |
52 impl_dir = invoker.impl_dir | |
53 uncompiled_schemas = [] | |
54 if (defined(invoker.uncompiled_schemas)) { | |
55 uncompiled_schemas = invoker.uncompiled_schemas | |
56 } | |
57 | |
58 compiler_root = "//tools/json_schema_compiler" | |
59 compiler_script = "$compiler_root/compiler.py" | |
60 compiler_sources = [ | |
61 "$compiler_root/cc_generator.py", | |
brettw
2014/04/24 18:29:44
Be consistent with the indenting. I would use 2 sp
Ken Rockot(use gerrit already)
2014/04/24 19:39:54
Done. Force of habit from C++ style...
| |
62 "$compiler_root/code.py", | |
63 "$compiler_root/compiler.py", | |
64 "$compiler_root/cpp_generator.py", | |
65 "$compiler_root/cpp_type_generator.py", | |
66 "$compiler_root/cpp_util.py", | |
67 "$compiler_root/h_generator.py", | |
68 "$compiler_root/idl_schema.py", | |
69 "$compiler_root/model.py", | |
70 "$compiler_root/util_cc_helper.py" ] | |
brettw
2014/04/24 18:29:44
For these multiline lists, I put the ] on the next
Ken Rockot(use gerrit already)
2014/04/24 19:39:54
Done.
| |
71 | |
72 # This list mirrors the outputs that will be generated by the following | |
73 # action_foreach. It's used by the static_library target. | |
74 compiled_schema_outputs = process_file_template( | |
75 schemas, | |
76 [ "$target_gen_dir/{{source_name_part}}.cc", | |
77 "$target_gen_dir/{{source_name_part}}.h" ]) | |
78 | |
79 schema_generator_name = target_name + "_schema_generator" | |
80 action_foreach(schema_generator_name) { | |
81 script = compiler_script | |
82 hard_dep = true | |
83 source_prereqs = compiler_sources | |
84 sources = schemas | |
85 outputs = [ | |
86 "$target_gen_dir/{{source_name_part}}.cc", | |
87 "$target_gen_dir/{{source_name_part}}.h" ] | |
88 args = [ | |
89 "{{source}}", | |
90 "--root=" + rebase_path("//", root_build_dir), | |
brettw
2014/04/24 18:29:44
FWIW I have no way to tell if this is correct othe
Ken Rockot(use gerrit already)
2014/04/24 19:39:54
Yep. I' pretty confident the arguments are concept
| |
91 "--destdir=" + rebase_path(root_gen_dir, root_build_dir), | |
92 "--namespace=$root_namespace", | |
93 "--generator=cpp" ] | |
94 visibility = target_visibility | |
95 } | |
96 | |
97 bundle_generator_name = target_name + "_bundle_generator" | |
98 bundle_outputs = [ | |
99 "$target_gen_dir/generated_api.cc", | |
brettw
2014/04/24 18:29:44
Ditto previous comments.
| |
100 "$target_gen_dir/generated_api.h", | |
101 "$target_gen_dir/generated_schemas.cc", | |
102 "$target_gen_dir/generated_schemas.h" ] | |
103 action(bundle_generator_name) { | |
104 script = compiler_script | |
105 hard_dep = true | |
106 source_prereqs = compiler_sources + schemas + uncompiled_schemas | |
107 outputs = bundle_outputs | |
108 args = [ | |
109 "--root=" + rebase_path("//", root_build_dir), | |
110 "--destdir=" + rebase_path(root_gen_dir, root_build_dir), | |
111 "--namespace=$root_namespace", | |
112 "--generator=cpp-bundle", | |
113 "--impl-dir=" + rebase_path(impl_dir, "//")] + | |
114 rebase_path(schemas, root_build_dir) + | |
115 rebase_path(uncompiled_schemas, root_build_dir) | |
116 } | |
117 | |
118 static_library(target_name) { | |
brettw
2014/04/24 18:29:44
CAn this be a source_set instead of a static_libra
Ken Rockot(use gerrit already)
2014/04/24 19:39:54
I guess I don't see why it couldn't. Done.
Some d
| |
119 hard_dep = true | |
120 sources = compiled_schema_outputs + bundle_outputs | |
121 deps = [ | |
122 ":$schema_generator_name", | |
123 ":$bundle_generator_name", | |
124 "//tools/json_schema_compiler:generated_api_util" ] | |
125 | |
126 if (defined(invoker.deps)) { | |
127 deps += invoker.deps | |
128 } | |
129 direct_dependent_configs = [ ":$generated_config_name" ] | |
130 | |
131 if (defined(invoker.visibility)) { | |
132 visibility = invoker.visibility | |
133 } | |
134 if (defined(invoker.output_name)) { | |
135 output_name = invoker.output_name | |
136 } | |
137 } | |
138 } | |
OLD | NEW |