Skip to content

Commit

Permalink
codegen.py: allow generators to take input arguments (#26147)
Browse files Browse the repository at this point in the history
* Pass in custom options to code generators (e.g. package names, generator filters)

* Fix typo and add impl example for idl_plugin example

* Add documentation for option passing

* Restyle

* Fix unit tests

---------

Co-authored-by: Andrei Litvin <[email protected]>
  • Loading branch information
2 people authored and pull[bot] committed Oct 31, 2023
1 parent e50e816 commit 4183731
Show file tree
Hide file tree
Showing 5 changed files with 34 additions and 12 deletions.
29 changes: 21 additions & 8 deletions scripts/codegen.py
Original file line number Diff line number Diff line change
Expand Up @@ -68,12 +68,16 @@ def write_new_data(self, relative_path: str, content: str):
type=click.Choice(__LOG_LEVELS__.keys(), case_sensitive=False),
help='Determines the verbosity of script output')
@click.option(
'--generator',
'--generator', '-g',
default='java-jni',
help='What code generator to run. The choices are: '+'|'.join(GENERATORS.keys())+'. ' +
'When using custom, provide the plugin path using `--generator custom:<path_to_plugin>:<plugin_module_name>` syntax. ' +
'For example, `--generator custom:./my_plugin:my_plugin_module` will load `./my_plugin/my_plugin_module/__init.py__` ' +
'For example, `--generator custom:./my_plugin:my_plugin_module` will load `./my_plugin/my_plugin_module/__init.py__` ' +
'that defines a subclass of CodeGenerator named CustomGenerator.')
@click.option(
'--option',
multiple=True,
help="Extra generator options, of the form: --option key:value")
@click.option(
'--output-dir',
type=click.Path(exists=False),
Expand All @@ -97,7 +101,7 @@ def write_new_data(self, relative_path: str, content: str):
@click.argument(
'idl_path',
type=click.Path(exists=True))
def main(log_level, generator, output_dir, dry_run, name_only, expected_outputs, idl_path):
def main(log_level, generator, option, output_dir, dry_run, name_only, expected_outputs, idl_path):
"""
Parses MATTER IDL files (.matter) and performs SDK code generation
as set up by the program arguments.
Expand All @@ -121,19 +125,28 @@ def main(log_level, generator, output_dir, dry_run, name_only, expected_outputs,
idl_tree = CreateParser().parse(open(idl_path, "rt").read())

plugin_module = None
if generator.startswith('custom'):
if generator.startswith('custom:'):
# check that the plugin path is provided
if ':' not in generator:
logging.fatal("Custom generator plugin path not provided. Use --generator custom:<path_to_plugin>")
sys.exit(1)
custom_params = generator.split(':')
if len(custom_params) != 3:
logging.fatal("Custom generator format not valid. Please use --generator custom:<path>:<module>")
sys.exit(1)
(generator, plugin_path, plugin_module) = custom_params

logging.info("Using CustomGenerator at plugin path %s.%s" % (plugin_path, plugin_module))
sys.path.append(plugin_path)
generator = 'CUSTOM'

extra_args = {}
for o in option:
if ':' not in o:
logging.fatal("Please specify options as '<key>:<value>'. %r is not valid. " % o)
sys.exit(1)
key, value = o.split(':')
extra_args[key] = value

logging.info("Running code generator %s" % generator)
generator = CodeGenerator.FromString(generator).Create(storage, idl=idl_tree, plugin_module=plugin_module)
generator = CodeGenerator.FromString(generator).Create(storage, idl=idl_tree, plugin_module=plugin_module, **extra_args)
generator.render(dry_run)

if expected_outputs:
Expand Down
8 changes: 6 additions & 2 deletions scripts/py_matter_idl/examples/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -13,9 +13,13 @@ scripts/py_matter_idl/examples/matter_idl_plugin:
"matter_idl_plugin" subdirectory.
4. Execute the `codegen.py` script passing the path to the parent directory of
"matter_idl_plugin" via
`--generator custom:<plugin_path>:<plugin_module_name>` argument.
`--generator custom:<plugin_path>:<plugin_module_name>` argument and package
name like `--option package:com.example.matter.proto`

```
# From top-of-tree in this example
./scripts/codegen.py --generator custom:./scripts/py_matter_idl/examples:matter_idl_plugin ./src/controller/data_model/controller-clusters.matter
./scripts/codegen.py \
--generator custom:./scripts/py_matter_idl/examples:matter_idl_plugin \
--option package:com.example.matter.proto \
./src/controller/data_model/controller-clusters.matter
```
5 changes: 5 additions & 0 deletions scripts/py_matter_idl/examples/matter_idl_plugin/__init__.py
Original file line number Diff line number Diff line change
Expand Up @@ -200,6 +200,10 @@ def __init__(self, storage: GeneratorStorage, idl: Idl, **kargs):
"""
super().__init__(storage, idl, fs_loader_searchpath=os.path.dirname(__file__))

if 'package' not in kargs:
raise Exception('Please provide a "--option package:<name>" argument')
self.package = kargs['package']

# String helpers
self.jinja_env.filters['toLowerSnakeCase'] = toLowerSnakeCase
self.jinja_env.filters['toUpperSnakeCase'] = toUpperSnakeCase
Expand Down Expand Up @@ -238,5 +242,6 @@ def internal_render_all(self):
output_file_name=filename,
vars={
'cluster': cluster,
'package': self.package,
}
)
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,7 @@

syntax = "proto3";

package com.matter.example.proto;
package {{package}};

option java_multiple_files = true;

Expand Down
2 changes: 1 addition & 1 deletion scripts/py_matter_idl/matter_idl/test_generators.py
Original file line number Diff line number Diff line change
Expand Up @@ -128,7 +128,7 @@ def _create_generator(self, storage: GeneratorStorage, idl: Idl):
sys.path.append(os.path.abspath(
os.path.join(os.path.dirname(__file__), '../examples')))
from matter_idl_plugin import CustomGenerator
return CustomGenerator(storage, idl)
return CustomGenerator(storage, idl, package='com.matter.example.proto')
else:
raise Exception("Unknown generator for testing: %s",
self.generator_name.lower())
Expand Down

0 comments on commit 4183731

Please sign in to comment.