blob: 3c1e5857a0d701fd844827b189a08719fbc49b49 [file] [log] [blame]
Andrew Grievee6c6bb382021-04-27 21:47:081#!/usr/bin/env python3
Nate Fischerac07b2622020-10-01 20:20:142#
Avi Drissman73a09d12022-09-08 20:33:383# Copyright 2020 The Chromium Authors
Nate Fischerac07b2622020-10-01 20:20:144# Use of this source code is governed by a BSD-style license that can be
5# found in the LICENSE file.
6
7import argparse
Nate Fischerac07b2622020-10-01 20:20:148import re
9import sys
10import zipfile
11
Andrew Grieve74ce1002025-06-23 15:29:1412from util import build_utils # pylint: disable=unused-import
Nate Fischerac07b2622020-10-01 20:20:1413from util import java_cpp_utils
Andrew Grieve4bc50e2d2023-03-31 02:25:5714import action_helpers # build_utils adds //build to sys.path.
Andrew Grieve3dec3462023-03-31 20:31:2915import zip_helpers
Nate Fischerac07b2622020-10-01 20:20:1416
17
18class FeatureParserDelegate(java_cpp_utils.CppConstantParser.Delegate):
Daniel Chengdc644a12022-09-19 23:21:3719 # Ex. 'BASE_FEATURE(kConstantName, "StringNameOfTheFeature", ...);'
20 # would parse as:
21 # ExtractConstantName() -> 'ConstantName'
22 # ExtractValue() -> '"StringNameOfTheFeature"'
23 FEATURE_RE = re.compile(r'BASE_FEATURE\(k([^,]+),')
Nate Fischerac07b2622020-10-01 20:20:1424 VALUE_RE = re.compile(r'\s*("(?:\"|[^"])*")\s*,')
25
26 def ExtractConstantName(self, line):
27 match = FeatureParserDelegate.FEATURE_RE.match(line)
Nate Fischerac07b2622020-10-01 20:20:1428 return match.group(1) if match else None
29
30 def ExtractValue(self, line):
31 match = FeatureParserDelegate.VALUE_RE.search(line)
32 return match.group(1) if match else None
33
34 def CreateJavaConstant(self, name, value, comments):
35 return java_cpp_utils.JavaString(name, value, comments)
36
37
Andrew Grieve6262d382025-06-23 18:37:0638def _GenerateOutput(template, source_paths, features):
Nate Fischerac07b2622020-10-01 20:20:1439 description_template = """
40 // This following string constants were inserted by
41 // {SCRIPT_NAME}
42 // From
43 // {SOURCE_PATHS}
Nate Fischerac07b2622020-10-01 20:20:1444
45"""
46 values = {
47 'SCRIPT_NAME': java_cpp_utils.GetScriptName(),
48 'SOURCE_PATHS': ',\n // '.join(source_paths),
Nate Fischerac07b2622020-10-01 20:20:1449 }
50 description = description_template.format(**values)
51 native_features = '\n\n'.join(x.Format() for x in features)
52
Andrew Grieve6262d382025-06-23 18:37:0653 # TODO(agrieve): Remove {{ and }} from input templates.
54 template = template.replace('{{', '{').replace('}}', '}')
55 return template.replace('{NATIVE_FEATURES}', description + native_features)
Nate Fischerac07b2622020-10-01 20:20:1456
57
58def _ParseFeatureFile(path):
Andrew Grieve74ce1002025-06-23 15:29:1459 with open(path, encoding='utf-8') as f:
Nate Fischerac07b2622020-10-01 20:20:1460 feature_file_parser = java_cpp_utils.CppConstantParser(
61 FeatureParserDelegate(), f.readlines())
62 return feature_file_parser.Parse()
63
64
Andrew Grieve6262d382025-06-23 18:37:0665def _Generate(source_paths, template):
66 package, class_name = java_cpp_utils.ParseTemplateFile(template)
Nate Fischerac07b2622020-10-01 20:20:1467 output_path = java_cpp_utils.GetJavaFilePath(package, class_name)
68
69 features = []
70 for source_path in source_paths:
71 features.extend(_ParseFeatureFile(source_path))
72
Andrew Grieve6262d382025-06-23 18:37:0673 output = _GenerateOutput(template, source_paths, features)
Nate Fischerac07b2622020-10-01 20:20:1474 return output, output_path
75
76
77def _Main(argv):
78 parser = argparse.ArgumentParser()
Nate Fischerac07b2622020-10-01 20:20:1479 parser.add_argument('--srcjar',
80 required=True,
81 help='The path at which to generate the .srcjar file')
Nate Fischerac07b2622020-10-01 20:20:1482 parser.add_argument('--template',
Nate Fischerac07b2622020-10-01 20:20:1483 help='The template file with which to generate the Java '
84 'class. Must have "{NATIVE_FEATURES}" somewhere in '
85 'the template.')
Andrew Grieve6262d382025-06-23 18:37:0686 parser.add_argument('--class-name', help='FQN of Java class to generate')
Nate Fischerac07b2622020-10-01 20:20:1487 parser.add_argument('inputs',
88 nargs='+',
89 help='Input file(s)',
90 metavar='INPUTFILE')
91 args = parser.parse_args(argv)
92
Andrew Grieve6262d382025-06-23 18:37:0693 if args.template:
94 with open(args.template, encoding='utf-8') as f:
95 template = f.read()
96 else:
97 template = java_cpp_utils.CreateDefaultTemplate(args.class_name,
98 '{NATIVE_FEATURES}')
99
Andrew Grieve4bc50e2d2023-03-31 02:25:57100 with action_helpers.atomic_output(args.srcjar) as f:
Nate Fischerac07b2622020-10-01 20:20:14101 with zipfile.ZipFile(f, 'w', zipfile.ZIP_STORED) as srcjar:
Andrew Grieve6262d382025-06-23 18:37:06102 data, path = _Generate(args.inputs, template)
Andrew Grieve3dec3462023-03-31 20:31:29103 zip_helpers.add_to_zip_hermetic(srcjar, path, data=data)
Nate Fischerac07b2622020-10-01 20:20:14104
105
106if __name__ == '__main__':
107 _Main(sys.argv[1:])