From 1acbc14c34f264e0158436dc3d0265d500848462 Mon Sep 17 00:00:00 2001 From: Mike Frysinger Date: Wed, 30 Apr 2025 13:29:20 -0400 Subject: manifest: generalize --json as --format= This will make it easier to add more formats without exploding the common --xxx space and checking a large set of boolean flags. Also fill out the test coverage while we're here. Bug: b/412725063 Change-Id: I754013dc6cb3445f8a0979cefec599d55dafdcff Reviewed-on: https://gerrit-review.googlesource.com/c/git-repo/+/471941 Reviewed-by: Gavin Mak Commit-Queue: Mike Frysinger Tested-by: Mike Frysinger --- subcmds/manifest.py | 39 +++++++++++++++++++++++++++++++++------ 1 file changed, 33 insertions(+), 6 deletions(-) (limited to 'subcmds/manifest.py') diff --git a/subcmds/manifest.py b/subcmds/manifest.py index bb6dc930..9786580a 100644 --- a/subcmds/manifest.py +++ b/subcmds/manifest.py @@ -12,7 +12,9 @@ # See the License for the specific language governing permissions and # limitations under the License. +import enum import json +import optparse import os import sys @@ -23,6 +25,16 @@ from repo_logging import RepoLogger logger = RepoLogger(__file__) +class OutputFormat(enum.Enum): + """Type for the requested output format.""" + + # Canonicalized manifest in XML format. + XML = enum.auto() + + # Canonicalized manifest in JSON format. + JSON = enum.auto() + + class Manifest(PagedCommand): COMMON = False helpSummary = "Manifest inspection utility" @@ -42,6 +54,10 @@ revisions set to the current commit hash. These are known as In this case, the 'upstream' attribute is set to the ref we were on when the manifest was generated. The 'dest-branch' attribute is set to indicate the remote ref to push changes to via 'repo upload'. + +Multiple output formats are supported via --format. The default output +is XML, and formats are generally "condensed". Use --pretty for more +human-readable variations. """ @property @@ -86,11 +102,21 @@ to indicate the remote ref to push changes to via 'repo upload'. "(only of use if the branch names for a sha1 manifest are " "sensitive)", ) + # Replaced with --format=json. Kept for backwards compatibility. + # Can delete in Jun 2026 or later. p.add_option( "--json", - default=False, - action="store_true", - help="output manifest in JSON format (experimental)", + action="store_const", + dest="format", + const=OutputFormat.JSON.name.lower(), + help=optparse.SUPPRESS_HELP, + ) + formats = tuple(x.lower() for x in OutputFormat.__members__.keys()) + p.add_option( + "--format", + default=OutputFormat.XML.name.lower(), + choices=formats, + help=f"output format: {', '.join(formats)} (default: %default)", ) p.add_option( "--pretty", @@ -121,6 +147,8 @@ to indicate the remote ref to push changes to via 'repo upload'. if opt.manifest_name: self.manifest.Override(opt.manifest_name, False) + output_format = OutputFormat[opt.format.upper()] + for manifest in self.ManifestList(opt): output_file = opt.output_file if output_file == "-": @@ -135,8 +163,7 @@ to indicate the remote ref to push changes to via 'repo upload'. manifest.SetUseLocalManifests(not opt.ignore_local_manifests) - if opt.json: - logger.warning("warning: --json is experimental!") + if output_format == OutputFormat.JSON: doc = manifest.ToDict( peg_rev=opt.peg_rev, peg_rev_upstream=opt.peg_rev_upstream, @@ -152,7 +179,7 @@ to indicate the remote ref to push changes to via 'repo upload'. "separators": (",", ": ") if opt.pretty else (",", ":"), "sort_keys": True, } - fd.write(json.dumps(doc, **json_settings)) + fd.write(json.dumps(doc, **json_settings) + "\n") else: manifest.Save( fd, -- cgit v1.2.3-54-g00ecf