blob: 08905cb4427ada718e970451bb12bf3374b4a456 [file] [log] [blame]
Shawn O. Pearce43c3d9e2009-03-04 14:26:50 -08001# Copyright (C) 2009 The Android Open Source Project
2#
3# Licensed under the Apache License, Version 2.0 (the "License");
4# you may not use this file except in compliance with the License.
5# You may obtain a copy of the License at
6#
7# http://www.apache.org/licenses/LICENSE-2.0
8#
9# Unless required by applicable law or agreed to in writing, software
10# distributed under the License is distributed on an "AS IS" BASIS,
11# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12# See the License for the specific language governing permissions and
13# limitations under the License.
14
Mike Frysinger23411d32020-09-02 04:31:10 -040015import json
Shawn O. Pearce43c3d9e2009-03-04 14:26:50 -080016import os
17import sys
LaMont Jonescc879a92021-11-18 22:40:18 +000018import optparse
Shawn O. Pearce43c3d9e2009-03-04 14:26:50 -080019
Shawn O. Pearcec7a4eef2009-03-05 10:32:38 -080020from command import PagedCommand
Shawn O. Pearce43c3d9e2009-03-04 14:26:50 -080021
David Pursehouse819827a2020-02-12 15:20:19 +090022
Shawn O. Pearcec7a4eef2009-03-05 10:32:38 -080023class Manifest(PagedCommand):
Mike Frysinger4f210542021-06-14 16:05:19 -040024 COMMON = False
Shawn O. Pearcec7a4eef2009-03-05 10:32:38 -080025 helpSummary = "Manifest inspection utility"
Shawn O. Pearce43c3d9e2009-03-04 14:26:50 -080026 helpUsage = """
Sean McAllisterd38300c2020-02-20 13:49:01 -070027%prog [-o {-|NAME.xml}] [-m MANIFEST.xml] [-r]
Shawn O. Pearce43c3d9e2009-03-04 14:26:50 -080028"""
29 _helpDescription = """
Shawn O. Pearcec7a4eef2009-03-05 10:32:38 -080030
31With the -o option, exports the current manifest for inspection.
Mike Frysinger4e1fc102020-09-06 14:42:47 -040032The manifest and (if present) local_manifests/ are combined
Shawn O. Pearcec7a4eef2009-03-05 10:32:38 -080033together to produce a single manifest file. This file can be stored
34in a Git repository for use during future 'repo init' invocations.
35
Sean McAllister74e8ed42020-04-15 12:24:43 -060036The -r option can be used to generate a manifest file with project
37revisions set to the current commit hash. These are known as
38"revision locked manifests", as they don't follow a particular branch.
39In this case, the 'upstream' attribute is set to the ref we were on
Sean McAllisteraf908cb2020-04-20 08:41:58 -060040when the manifest was generated. The 'dest-branch' attribute is set
41to indicate the remote ref to push changes to via 'repo upload'.
Shawn O. Pearce43c3d9e2009-03-04 14:26:50 -080042"""
43
44 @property
45 def helpDescription(self):
David Pursehouse8a68ff92012-09-24 12:15:13 +090046 helptext = self._helpDescription + '\n'
Shawn O. Pearce43c3d9e2009-03-04 14:26:50 -080047 r = os.path.dirname(__file__)
48 r = os.path.dirname(r)
Mike Frysinger3164d402019-11-11 05:40:22 -050049 with open(os.path.join(r, 'docs', 'manifest-format.md')) as fd:
50 for line in fd:
51 helptext += line
David Pursehouse8a68ff92012-09-24 12:15:13 +090052 return helptext
Shawn O. Pearce43c3d9e2009-03-04 14:26:50 -080053
Shawn O. Pearcec7a4eef2009-03-05 10:32:38 -080054 def _Options(self, p):
55 p.add_option('-r', '--revision-as-HEAD',
56 dest='peg_rev', action='store_true',
Mike Frysingerc177f942021-05-04 08:06:36 -040057 help='save revisions as current HEAD')
Sean McAllisterd38300c2020-02-20 13:49:01 -070058 p.add_option('-m', '--manifest-name',
59 help='temporary manifest to use for this sync', metavar='NAME.xml')
Brian Harring14a66742012-09-28 20:21:57 -070060 p.add_option('--suppress-upstream-revision', dest='peg_rev_upstream',
61 default=True, action='store_false',
Mike Frysingerc177f942021-05-04 08:06:36 -040062 help='if in -r mode, do not write the upstream field '
63 '(only of use if the branch names for a sha1 manifest are '
64 'sensitive)')
Sean McAllisteraf908cb2020-04-20 08:41:58 -060065 p.add_option('--suppress-dest-branch', dest='peg_rev_dest_branch',
66 default=True, action='store_false',
Mike Frysingerc177f942021-05-04 08:06:36 -040067 help='if in -r mode, do not write the dest-branch field '
68 '(only of use if the branch names for a sha1 manifest are '
69 'sensitive)')
Mike Frysinger23411d32020-09-02 04:31:10 -040070 p.add_option('--json', default=False, action='store_true',
Mike Frysingerc177f942021-05-04 08:06:36 -040071 help='output manifest in JSON format (experimental)')
Mike Frysinger23411d32020-09-02 04:31:10 -040072 p.add_option('--pretty', default=False, action='store_true',
Mike Frysingerc177f942021-05-04 08:06:36 -040073 help='format output for humans to read')
Michael Kellyc34b91c2021-07-02 09:25:48 -070074 p.add_option('--no-local-manifests', default=False, action='store_true',
75 dest='ignore_local_manifests', help='ignore local manifests')
Shawn O. Pearcec7a4eef2009-03-05 10:32:38 -080076 p.add_option('-o', '--output-file',
77 dest='output_file',
Conley Owens918ff852012-08-07 10:44:01 -070078 default='-',
LaMont Jonescc879a92021-11-18 22:40:18 +000079 help='file to save the manifest to. (Filename prefix for multi-tree.)',
Shawn O. Pearcec7a4eef2009-03-05 10:32:38 -080080 metavar='-|NAME.xml')
81
82 def _Output(self, opt):
Sean McAllisterd38300c2020-02-20 13:49:01 -070083 # If alternate manifest is specified, override the manifest file that we're using.
84 if opt.manifest_name:
85 self.manifest.Override(opt.manifest_name, False)
86
LaMont Jonescc879a92021-11-18 22:40:18 +000087 for manifest in self.ManifestList(opt):
88 output_file = opt.output_file
89 if output_file == '-':
90 fd = sys.stdout
91 else:
92 if manifest.path_prefix:
93 output_file = f'{opt.output_file}:{manifest.path_prefix.replace("/", "%2f")}'
94 fd = open(output_file, 'w')
Michael Kellyc34b91c2021-07-02 09:25:48 -070095
LaMont Jonescc879a92021-11-18 22:40:18 +000096 manifest.SetUseLocalManifests(not opt.ignore_local_manifests)
Michael Kellyc34b91c2021-07-02 09:25:48 -070097
LaMont Jonescc879a92021-11-18 22:40:18 +000098 if opt.json:
99 print('warning: --json is experimental!', file=sys.stderr)
100 doc = manifest.ToDict(peg_rev=opt.peg_rev,
101 peg_rev_upstream=opt.peg_rev_upstream,
102 peg_rev_dest_branch=opt.peg_rev_dest_branch)
Mike Frysinger23411d32020-09-02 04:31:10 -0400103
LaMont Jonescc879a92021-11-18 22:40:18 +0000104 json_settings = {
105 # JSON style guide says Uunicode characters are fully allowed.
106 'ensure_ascii': False,
107 # We use 2 space indent to match JSON style guide.
108 'indent': 2 if opt.pretty else None,
109 'separators': (',', ': ') if opt.pretty else (',', ':'),
110 'sort_keys': True,
111 }
112 fd.write(json.dumps(doc, **json_settings))
113 else:
114 manifest.Save(fd,
115 peg_rev=opt.peg_rev,
116 peg_rev_upstream=opt.peg_rev_upstream,
117 peg_rev_dest_branch=opt.peg_rev_dest_branch)
118 if output_file != '-':
119 fd.close()
120 if manifest.path_prefix:
121 print(f'Saved {manifest.path_prefix} submanifest to {output_file}',
122 file=sys.stderr)
123 else:
124 print(f'Saved manifest to {output_file}', file=sys.stderr)
125
Shawn O. Pearcec7a4eef2009-03-05 10:32:38 -0800126
Mike Frysingerae6cb082019-08-27 01:10:59 -0400127 def ValidateOptions(self, opt, args):
Shawn O. Pearcec7a4eef2009-03-05 10:32:38 -0800128 if args:
129 self.Usage()
130
Mike Frysingerae6cb082019-08-27 01:10:59 -0400131 def Execute(self, opt, args):
132 self._Output(opt)