OLD | NEW |
---|---|
(Empty) | |
1 # 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 # This file is meant to be included into a target to provide a rule | |
6 # to generate Java source files from templates that are processed | |
7 # through the host C pre-processor. | |
8 # | |
9 # This assumes a GNU-compatible pre-processor installed as 'cpp'. | |
10 # Only tested on Linux. | |
11 # | |
12 # To use this, create a gyp target with the following form: | |
13 # { | |
14 # 'target_name': 'android_net_java_constants', | |
15 # 'type': 'none', | |
16 # 'sources': [ | |
17 # 'net/base/certificate_mime_type_list.h', | |
18 # 'net/android/NetError.template', | |
19 # ], | |
20 # 'variables': { | |
21 # 'package_name': 'org.chromium.net', | |
22 # }, | |
23 # 'includes': [ '../build/java_constants.gypi' ], | |
24 # }, | |
25 # | |
26 # The 'sources' entry should list all input files. The template file | |
27 # itself should use the 'ClassName.template' format, and will generate | |
28 # 'gen/templates/<package-name>/ClassName.java. Other source files | |
29 # are those typically included by the template. Any change to them | |
30 # will force a rebuild of the template, and hence of any source that | |
31 # depends on it. | |
32 # | |
33 | |
34 { | |
35 # Location where all generated Java sources will be placed. | |
36 'variables': { | |
37 'output_dir': '<(SHARED_INTERMEDIATE_DIR)/templates/<(package_name)' | |
38 }, | |
39 # Ensure that the output directory is used in the class path | |
40 # when building targets that depend on this one. | |
41 'direct_dependent_settings': { | |
42 'variables': { | |
43 'generated_src_dirs': [ | |
44 '<(output_dir)/', | |
45 ], | |
46 }, | |
47 }, | |
48 # Define a single rule that will be apply to each .template file | |
49 # listed in 'sources'. | |
50 'rules': [{ | |
bulach
2012/11/27 17:57:12
my understanding is that "rules" are used to map 1
digit1
2012/11/27 22:29:07
Hi Marcus, I think a 'rules' section is appropriat
bulach
2012/11/28 08:57:30
oh, you're right, thanks for the detailed explanat
| |
51 'rule_name': 'generate_java_constants', | |
52 'extension': 'template', | |
53 # Ensure the generated Java file is treated as input to the targets | |
54 # that depend on it. | |
55 'direct_dependent_settings': { | |
56 'variables': { | |
57 'additional_input_paths': [ | |
58 '<(output_dir)/<(RULE_INPUT_ROOT).java' | |
59 ], | |
60 }, | |
61 }, | |
62 'outputs': [ | |
63 '<(output_dir)/<(RULE_INPUT_ROOT).java' | |
64 ], | |
65 'action': [ | |
66 'cpp', # invoke host pre-processor. | |
67 '-x', 'c-header', # treat sources as C header files | |
68 '-P', # disable line markers, i.e. '#line 309' | |
69 '-I', '..', # Add project top-level to include path | |
digit1
2012/11/28 10:58:48
I wonder if we shouldn't use <(DEPTH) instead here
| |
70 '-o', '<@(_outputs)', # Specify output file | |
71 '<(RULE_INPUT_PATH)', # Specify input file | |
72 ], | |
73 'message': 'Generating Java from cpp template <(RULE_INPUT_PATH)', | |
74 'process_outputs_as_sources': 1, | |
75 }], | |
76 'hard_dependency': 1, | |
77 } | |
OLD | NEW |