Instrumenting internals of AccountIdFetcher::Start to locate the source of jankiness.
[chromium-blink-merge.git] / build / json_schema_api.gni
blob58577396de28a900151cf2265c9375e18ba809da
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.
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.
10 # Invocations of this template may use the following variables:
12 # sources [required] A list of schema files to be compiled.
14 # root_namespace [required]
15 #     A Python string substituion pattern used to generate the C++
16 #     namespace for each API. Use %(namespace)s to replace with the API
17 #     namespace, like "toplevel::%(namespace)s_api".
19 # schema_include_rules [optional]
20 #     A list of paths to include when searching for referenced objects,
21 #     with the namespace separated by a :.
22 #     Example:
23 #       [ '/foo/bar:Foo::Bar::%(namespace)s' ]
25 # schemas [optional, default = false]
26 #   Boolean indicating if the schema files should be generated.
28 # bundle [optional, default = false]
29 #   Boolean indicating if the schema bundle files should be generated.
31 # bundle_registration [optional, default = false]
32 #   Boolean indicating if the API registration bundle files should be generated.
34 # impl_dir [required if bundle_registration = true, otherwise unused]
35 #   The path containing C++ implementations of API functions. This path is
36 #   used as the root path when looking for {schema}/{schema}_api.h headers
37 #   when generating API registration bundles. Such headers, if found, are
38 #   automatically included by the generated code.
40 # uncompiled_sources [optional, only used when bundle = true or
41 #     bundle_registration = true]
42 #   A list of schema files which should not be compiled, but which should still
43 #   be processed for API bundle generation.
45 # deps [optional]
46 #   If any deps are specified they will be inherited by the static library
47 #   target.
49 # The static library target also inherits the visibility and output_name
50 # of its invoker.
52 template("json_schema_api") {
53   assert(defined(invoker.sources),
54          "\"sources\" must be defined for the $target_name template.")
55   assert(defined(invoker.root_namespace),
56          "\"root_namespace\" must be defined for the $target_name template.")
58   schemas = defined(invoker.schemas) && invoker.schemas
59   bundle = defined(invoker.bundle) && invoker.bundle
60   bundle_registration = defined(invoker.bundle_registration) &&
61       invoker.bundle_registration
63   schema_include_rules = ""
64   if (defined(invoker.schema_include_rules)) {
65     schema_include_rules = invoker.schema_include_rules
66   }
68   # Keep a copy of the target_name here since it will be trampled
69   # in nested targets.
70   target_visibility = [ ":$target_name" ]
72   generated_config_name = target_name + "_generated_config"
73   config(generated_config_name) {
74     include_dirs = [ target_gen_dir ]
75     visibility = target_visibility
76   }
78   sources = invoker.sources
79   root_namespace = invoker.root_namespace
81   compiler_root = "//tools/json_schema_compiler"
82   compiler_script = "$compiler_root/compiler.py"
83   compiler_sources = [
84     "$compiler_root/cc_generator.py",
85     "$compiler_root/code.py",
86     "$compiler_root/compiler.py",
87     "$compiler_root/cpp_generator.py",
88     "$compiler_root/cpp_type_generator.py",
89     "$compiler_root/cpp_util.py",
90     "$compiler_root/h_generator.py",
91     "$compiler_root/idl_schema.py",
92     "$compiler_root/model.py",
93     "$compiler_root/util_cc_helper.py",
94   ]
96   if (schemas) {
97     schema_generator_name = target_name + "_schema_generator"
98     action_foreach(schema_generator_name) {
99       script = compiler_script
100       inputs = compiler_sources
101       outputs = [
102         "$target_gen_dir/{{source_name_part}}.cc",
103         "$target_gen_dir/{{source_name_part}}.h",
104       ]
105       args = [
106         "{{source}}",
107         "--root=" + rebase_path("//", root_build_dir),
108         "--destdir=" + rebase_path(root_gen_dir, root_build_dir),
109         "--namespace=$root_namespace",
110         "--generator=cpp",
111         "--include-rules=$schema_include_rules" ]
113       if (defined(invoker.visibility)) {
114         # If visibility is restricted, add our own target to it.
115         visibility = [ invoker.visibility, target_visibility ]
116       }
117     }
118   }
120   if (bundle) {
121     uncompiled_sources = []
122     if (defined(invoker.uncompiled_sources)) {
123      uncompiled_sources = invoker.uncompiled_sources
124     }
126     bundle_generator_schema_name = target_name + "_bundle_generator_schema"
127     action(bundle_generator_schema_name) {
128       script = compiler_script
129       inputs = compiler_sources + sources + uncompiled_sources
130       outputs = [
131         "$target_gen_dir/generated_schemas.cc",
132         "$target_gen_dir/generated_schemas.h",
133       ]
134       args = [
135         "--root=" + rebase_path("//", root_build_dir),
136         "--destdir=" + rebase_path(root_gen_dir, root_build_dir),
137         "--namespace=$root_namespace",
138         "--generator=cpp-bundle-schema",
139         "--include-rules=$schema_include_rules" ]
140         + rebase_path(sources, root_build_dir)
141         + rebase_path(uncompiled_sources, root_build_dir)
142     }
143   }
145   if (bundle_registration) {
146     uncompiled_sources = []
147     if (defined(invoker.uncompiled_sources)) {
148      uncompiled_sources = invoker.uncompiled_sources
149     }
151     assert(defined(invoker.impl_dir),
152            "\"impl_dir\" must be defined for the $target_name template.")
153     impl_dir = invoker.impl_dir
155     bundle_generator_registration_name = target_name +
156         "_bundle_generator_registration"
157     action(bundle_generator_registration_name) {
158       script = compiler_script
159       inputs = compiler_sources + sources + uncompiled_sources
160       outputs = [
161         "$root_gen_dir/$impl_dir/generated_api_registration.cc",
162         "$root_gen_dir/$impl_dir/generated_api_registration.h",
163       ]
164       args = [
165         "--root=" + rebase_path("//", root_build_dir),
166         "--destdir=" + rebase_path(root_gen_dir, root_build_dir),
167         "--namespace=$root_namespace",
168         "--generator=cpp-bundle-registration",
169         "--impl-dir=" + rebase_path(impl_dir, "//"),
170         "--include-rules=$schema_include_rules" ]
171         + rebase_path(sources, root_build_dir)
172         + rebase_path(uncompiled_sources, root_build_dir)
173     }
174   }
176   source_set(target_name) {
177     sources = []
178     deps = []
179     public_deps = []
181     if (schemas) {
182       sources += get_target_outputs(":$schema_generator_name")
183       public_deps += [ ":$schema_generator_name" ]
184       deps += [ "//tools/json_schema_compiler:generated_api_util" ]
185     }
187     if (bundle) {
188       sources += get_target_outputs(":$bundle_generator_schema_name")
189       deps += [ ":$bundle_generator_schema_name" ]
190     }
192     if (bundle_registration) {
193       sources += get_target_outputs(":$bundle_generator_registration_name")
194       deps += [ ":$bundle_generator_registration_name" ]
195     }
197     if (defined(invoker.deps)) {
198       deps += invoker.deps
199     }
200     public_configs = [ ":$generated_config_name" ]
202     if (defined(invoker.visibility)) {
203       visibility = invoker.visibility
204     }
205     if (defined(invoker.output_name)) {
206       output_name = invoker.output_name
207     }
208   }