diff options
| author | Gal Pressman <gal@nvidia.com> | 2025-11-18 16:32:07 +0200 |
|---|---|---|
| committer | Paolo Abeni <pabeni@redhat.com> | 2025-11-20 15:43:04 +0100 |
| commit | bc1bc1b357cdae75d17ecde0aabe1b95ce08c7a5 (patch) | |
| tree | ef0a6d2e6916a864d752cd257ac19412d76e31d2 /tools/net | |
| parent | 2a2d5a3392b63ef5141c158117dba4f3b9b3ac22 (diff) | |
tools: ynl: cli: Parse nested attributes in --list-attrs output
Enhance the --list-attrs option to recursively display nested attributes
instead of just showing "nest" as the type.
Nested attributes now show their attribute set name and expand to
display their contents.
# ./cli.py --family ethtool --list-attrs rss-get
[..]
Do request attributes:
- header: nest -> header
- dev-index: u32
- dev-name: string
- flags: u32 (enum: header-flags)
- phy-index: u32
- context: u32
[..]
Reviewed-by: Nimrod Oren <noren@nvidia.com>
Signed-off-by: Gal Pressman <gal@nvidia.com>
Reviewed-by: Donald Hunter <donald.hunter@gmail.com>
Link: https://patch.msgid.link/20251118143208.2380814-3-gal@nvidia.com
Signed-off-by: Paolo Abeni <pabeni@redhat.com>
Diffstat (limited to 'tools/net')
| -rwxr-xr-x | tools/net/ynl/pyynl/cli.py | 35 |
1 files changed, 26 insertions, 9 deletions
diff --git a/tools/net/ynl/pyynl/cli.py b/tools/net/ynl/pyynl/cli.py index 4d91a2cee381..6655ee61081a 100755 --- a/tools/net/ynl/pyynl/cli.py +++ b/tools/net/ynl/pyynl/cli.py @@ -40,35 +40,52 @@ class YnlEncoder(json.JSONEncoder): return json.JSONEncoder.default(self, obj) -def print_attr_list(attr_names, attr_set): +def print_attr_list(ynl, attr_names, attr_set, indent=2): """Print a list of attributes with their types and documentation.""" + prefix = ' ' * indent for attr_name in attr_names: if attr_name in attr_set.attrs: attr = attr_set.attrs[attr_name] - attr_info = f' - {attr_name}: {attr.type}' + attr_info = f'{prefix}- {attr_name}: {attr.type}' if 'enum' in attr.yaml: attr_info += f" (enum: {attr.yaml['enum']})" + + # Show nested attributes reference and recursively display them + nested_set_name = None + if attr.type == 'nest' and 'nested-attributes' in attr.yaml: + nested_set_name = attr.yaml['nested-attributes'] + attr_info += f" -> {nested_set_name}" + if attr.yaml.get('doc'): - doc_text = textwrap.indent(attr.yaml['doc'], ' ') + doc_text = textwrap.indent(attr.yaml['doc'], prefix + ' ') attr_info += f"\n{doc_text}" print(attr_info) + # Recursively show nested attributes + if nested_set_name in ynl.attr_sets: + nested_set = ynl.attr_sets[nested_set_name] + # Filter out 'unspec' and other unused attrs + nested_names = [n for n in nested_set.attrs.keys() + if nested_set.attrs[n].type != 'unused'] + if nested_names: + print_attr_list(ynl, nested_names, nested_set, indent + 4) + -def print_mode_attrs(mode, mode_spec, attr_set, print_request=True): +def print_mode_attrs(ynl, mode, mode_spec, attr_set, print_request=True): """Print a given mode (do/dump/event/notify).""" mode_title = mode.capitalize() if print_request and 'request' in mode_spec and 'attributes' in mode_spec['request']: print(f'\n{mode_title} request attributes:') - print_attr_list(mode_spec['request']['attributes'], attr_set) + print_attr_list(ynl, mode_spec['request']['attributes'], attr_set) if 'reply' in mode_spec and 'attributes' in mode_spec['reply']: print(f'\n{mode_title} reply attributes:') - print_attr_list(mode_spec['reply']['attributes'], attr_set) + print_attr_list(ynl, mode_spec['reply']['attributes'], attr_set) if 'attributes' in mode_spec: print(f'\n{mode_title} attributes:') - print_attr_list(mode_spec['attributes'], attr_set) + print_attr_list(ynl, mode_spec['attributes'], attr_set) def main(): @@ -180,13 +197,13 @@ def main(): for mode in ['do', 'dump', 'event']: if mode in op.yaml: - print_mode_attrs(mode, op.yaml[mode], op.attr_set, True) + print_mode_attrs(ynl, mode, op.yaml[mode], op.attr_set, True) if 'notify' in op.yaml: mode_spec = op.yaml['notify'] ref_spec = ynl.msgs.get(mode_spec).yaml.get('do') if ref_spec: - print_mode_attrs('notify', ref_spec, op.attr_set, False) + print_mode_attrs(ynl, 'notify', ref_spec, op.attr_set, False) if 'mcgrp' in op.yaml: print(f"\nMulticast group: {op.yaml['mcgrp']}") |
