blob: 2101a89655522e8892eca448a4bb73fc738d1b41 [file] [log] [blame]
[email protected]ae33d322012-03-19 22:24:351# Copyright (c) 2012 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{
6 'variables': {
7 # When including this gypi, the following variables must be set:
[email protected]8d368d62014-08-05 08:02:068 # schema_files:
9 # An array of json or idl files that comprise the api model.
lfg8a1bee32014-08-29 03:56:2810 # schema_include_rules (optional):
11 # An array of paths to include when searching for referenced objects,
12 # with the namespace separated by a :.
13 # Example:
14 # [ '/foo/bar:Foo::Bar::%(namespace)s' ]
[email protected]8d368d62014-08-05 08:02:0615 # cc_dir:
16 # The directory to put the generated code in.
17 # root_namespace:
18 # A Python string substituion pattern used to generate the C++
19 # namespace for each API. Use %(namespace)s to replace with the API
20 # namespace, like "toplevel::%(namespace)s_api".
kalmane58e62232015-07-23 18:27:2221 # bundle_name:
22 # A string to prepend to generated bundle class names, so that multiple
23 # bundle rules can be used without conflicting. Only used with one of
24 # the cpp-bundle generators.
[email protected]8d368d62014-08-05 08:02:0625 #
[email protected]ae33d322012-03-19 22:24:3526 # Functions and namespaces can be excluded by setting "nocompile" to true.
[email protected]704a9002014-03-05 10:11:1927 # The default root path of API implementation sources is
28 # chrome/browser/extensions/api and can be overridden by setting "impl_dir".
[email protected]ae33d322012-03-19 22:24:3529 'api_gen_dir': '<(DEPTH)/tools/json_schema_compiler',
30 'api_gen': '<(api_gen_dir)/compiler.py',
yoz774dcda2d2014-08-27 03:32:5831 'generator_files': [
32 '<(api_gen_dir)/cc_generator.py',
33 '<(api_gen_dir)/code.py',
34 '<(api_gen_dir)/compiler.py',
35 '<(api_gen_dir)/cpp_bundle_generator.py',
36 '<(api_gen_dir)/cpp_type_generator.py',
37 '<(api_gen_dir)/cpp_util.py',
38 '<(api_gen_dir)/h_generator.py',
39 '<(api_gen_dir)/idl_schema.py',
40 '<(api_gen_dir)/json_schema.py',
41 '<(api_gen_dir)/model.py',
42 '<(api_gen_dir)/util_cc_helper.py',
43 ],
lfg8a1bee32014-08-29 03:56:2844 'schema_include_rules': [],
[email protected]ae33d322012-03-19 22:24:3545 },
46 'actions': [
47 {
yoz774dcda2d2014-08-27 03:32:5848 'action_name': 'genapi_bundle_schema',
[email protected]ae33d322012-03-19 22:24:3549 'inputs': [
yoz774dcda2d2014-08-27 03:32:5850 '<@(generator_files)',
[email protected]4636c832013-01-11 02:10:1151 '<@(schema_files)',
[email protected]4ac46352013-11-04 20:31:2952 '<@(non_compiled_schema_files)',
[email protected]ae33d322012-03-19 22:24:3553 ],
54 'outputs': [
[email protected]2fe86eec2012-03-21 05:40:1455 '<(SHARED_INTERMEDIATE_DIR)/<(cc_dir)/generated_schemas.h',
56 '<(SHARED_INTERMEDIATE_DIR)/<(cc_dir)/generated_schemas.cc',
[email protected]ae33d322012-03-19 22:24:3557 ],
58 'action': [
59 'python',
60 '<(api_gen)',
61 '--root=<(DEPTH)',
62 '--destdir=<(SHARED_INTERMEDIATE_DIR)',
63 '--namespace=<(root_namespace)',
kalmane58e62232015-07-23 18:27:2264 '--bundle-name=<(bundle_name)',
yoz774dcda2d2014-08-27 03:32:5865 '--generator=cpp-bundle-schema',
lfg8a1bee32014-08-29 03:56:2866 '--include-rules=<(schema_include_rules)',
[email protected]4636c832013-01-11 02:10:1167 '<@(schema_files)',
[email protected]ad0e98df2013-10-23 18:40:1268 '<@(non_compiled_schema_files)',
[email protected]ae33d322012-03-19 22:24:3569 ],
yoz774dcda2d2014-08-27 03:32:5870 'message': 'Generating C++ API bundle code for schemas',
[email protected]ae33d322012-03-19 22:24:3571 'process_outputs_as_sources': 1,
yoz774dcda2d2014-08-27 03:32:5872 # Avoid running MIDL compiler on IDL input files.
73 'explicit_idl_action': 1,
74 },
[email protected]ae33d322012-03-19 22:24:3575 ],
76 'include_dirs': [
77 '<(SHARED_INTERMEDIATE_DIR)',
78 '<(DEPTH)',
79 ],
[email protected]ae33d322012-03-19 22:24:3580 'direct_dependent_settings': {
81 'include_dirs': [
82 '<(SHARED_INTERMEDIATE_DIR)',
83 ]
84 },
85 # This target exports a hard dependency because it generates header
86 # files.
87 'hard_dependency': 1,
88}