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

Side by Side Diff: build/android/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/net.gyp » ('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/android/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': [
51 {
52 'rule_name': 'generate_java_constants',
53 'extension': 'template',
54 'inputs': [
55 '<(RULE_INPUT_PATH)',
56 ],
57 'outputs': [
58 '<(output_dir)/<(RULE_INPUT_ROOT).java'
59 ],
60 'action': [
61 'cpp', # invoke host pre-processor.
62 '-x', 'c-header', # treat sources as C header files
63 '-P', # disable line markers, i.e. '#line 309'
64 '-I', '<(DEPTH)', # Add project top-level to include path
65 '-o', '<@(_outputs)', # Specify output file
66 '<(RULE_INPUT_PATH)', # Specify input file
67 ],
68 'message': 'Generating Java from cpp template <(RULE_INPUT_PATH)',
69 }
70 ],
71 }
OLDNEW
« no previous file with comments | « no previous file | net/android/java/NetError.template » ('j') | net/net.gyp » ('J')

Powered by Google App Engine
This is Rietveld 408576698