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

Side by Side Diff: build/java_cpp_template.gypi

Issue 11415152: build/java_cpp_template.gypi: new build rules. (Closed) Base URL: http://git.chromium.org/chromium/src.git@master
Patch Set: Created 8 years 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
« no previous file with comments | « no previous file | net/android/java/NetError.template » ('j') | net/android/java/NetError.template » ('J')
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
(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 }
OLDNEW
« no previous file with comments | « no previous file | net/android/java/NetError.template » ('j') | net/android/java/NetError.template » ('J')

Powered by Google App Engine
This is Rietveld 408576698