blob: f0a0d0696a01dd0075fd52e6778057ac669c3268 [file] [log] [blame]
Mike Frysingerf6013762019-06-13 02:30:51 -04001# -*- coding:utf-8 -*-
Shawn O. Pearce43c3d9e2009-03-04 14:26:50 -08002#
3# Copyright (C) 2009 The Android Open Source Project
4#
5# Licensed under the Apache License, Version 2.0 (the "License");
6# you may not use this file except in compliance with the License.
7# You may obtain a copy of the License at
8#
9# http://www.apache.org/licenses/LICENSE-2.0
10#
11# Unless required by applicable law or agreed to in writing, software
12# distributed under the License is distributed on an "AS IS" BASIS,
13# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14# See the License for the specific language governing permissions and
15# limitations under the License.
16
Sarah Owenscecd1d82012-11-01 22:59:27 -070017from __future__ import print_function
Shawn O. Pearce43c3d9e2009-03-04 14:26:50 -080018import os
19import sys
20
Shawn O. Pearcec7a4eef2009-03-05 10:32:38 -080021from command import PagedCommand
Shawn O. Pearce43c3d9e2009-03-04 14:26:50 -080022
David Pursehouse819827a2020-02-12 15:20:19 +090023
Shawn O. Pearcec7a4eef2009-03-05 10:32:38 -080024class Manifest(PagedCommand):
Shawn O. Pearce43c3d9e2009-03-04 14:26:50 -080025 common = False
Shawn O. Pearcec7a4eef2009-03-05 10:32:38 -080026 helpSummary = "Manifest inspection utility"
Shawn O. Pearce43c3d9e2009-03-04 14:26:50 -080027 helpUsage = """
Sean McAllisterd38300c2020-02-20 13:49:01 -070028%prog [-o {-|NAME.xml}] [-m MANIFEST.xml] [-r]
Shawn O. Pearce43c3d9e2009-03-04 14:26:50 -080029"""
30 _helpDescription = """
Shawn O. Pearcec7a4eef2009-03-05 10:32:38 -080031
32With the -o option, exports the current manifest for inspection.
Mike Frysinger4e1fc102020-09-06 14:42:47 -040033The manifest and (if present) local_manifests/ are combined
Shawn O. Pearcec7a4eef2009-03-05 10:32:38 -080034together to produce a single manifest file. This file can be stored
35in a Git repository for use during future 'repo init' invocations.
36
Sean McAllister74e8ed42020-04-15 12:24:43 -060037The -r option can be used to generate a manifest file with project
38revisions set to the current commit hash. These are known as
39"revision locked manifests", as they don't follow a particular branch.
40In this case, the 'upstream' attribute is set to the ref we were on
Sean McAllisteraf908cb2020-04-20 08:41:58 -060041when the manifest was generated. The 'dest-branch' attribute is set
42to indicate the remote ref to push changes to via 'repo upload'.
Shawn O. Pearce43c3d9e2009-03-04 14:26:50 -080043"""
44
45 @property
46 def helpDescription(self):
David Pursehouse8a68ff92012-09-24 12:15:13 +090047 helptext = self._helpDescription + '\n'
Shawn O. Pearce43c3d9e2009-03-04 14:26:50 -080048 r = os.path.dirname(__file__)
49 r = os.path.dirname(r)
Mike Frysinger3164d402019-11-11 05:40:22 -050050 with open(os.path.join(r, 'docs', 'manifest-format.md')) as fd:
51 for line in fd:
52 helptext += line
David Pursehouse8a68ff92012-09-24 12:15:13 +090053 return helptext
Shawn O. Pearce43c3d9e2009-03-04 14:26:50 -080054
Shawn O. Pearcec7a4eef2009-03-05 10:32:38 -080055 def _Options(self, p):
56 p.add_option('-r', '--revision-as-HEAD',
57 dest='peg_rev', action='store_true',
58 help='Save revisions as current HEAD')
Sean McAllisterd38300c2020-02-20 13:49:01 -070059 p.add_option('-m', '--manifest-name',
60 help='temporary manifest to use for this sync', metavar='NAME.xml')
Brian Harring14a66742012-09-28 20:21:57 -070061 p.add_option('--suppress-upstream-revision', dest='peg_rev_upstream',
62 default=True, action='store_false',
63 help='If in -r mode, do not write the upstream field. '
64 'Only of use if the branch names for a sha1 manifest are '
65 'sensitive.')
Sean McAllisteraf908cb2020-04-20 08:41:58 -060066 p.add_option('--suppress-dest-branch', dest='peg_rev_dest_branch',
67 default=True, action='store_false',
68 help='If in -r mode, do not write the dest-branch field. '
69 'Only of use if the branch names for a sha1 manifest are '
70 'sensitive.')
Shawn O. Pearcec7a4eef2009-03-05 10:32:38 -080071 p.add_option('-o', '--output-file',
72 dest='output_file',
Conley Owens918ff852012-08-07 10:44:01 -070073 default='-',
Shawn O. Pearcec7a4eef2009-03-05 10:32:38 -080074 help='File to save the manifest to',
75 metavar='-|NAME.xml')
76
77 def _Output(self, opt):
Sean McAllisterd38300c2020-02-20 13:49:01 -070078 # If alternate manifest is specified, override the manifest file that we're using.
79 if opt.manifest_name:
80 self.manifest.Override(opt.manifest_name, False)
81
Shawn O. Pearcec7a4eef2009-03-05 10:32:38 -080082 if opt.output_file == '-':
83 fd = sys.stdout
84 else:
85 fd = open(opt.output_file, 'w')
86 self.manifest.Save(fd,
David Pursehousee5913ae2020-02-12 13:56:59 +090087 peg_rev=opt.peg_rev,
Sean McAllisteraf908cb2020-04-20 08:41:58 -060088 peg_rev_upstream=opt.peg_rev_upstream,
89 peg_rev_dest_branch=opt.peg_rev_dest_branch)
Shawn O. Pearcec7a4eef2009-03-05 10:32:38 -080090 fd.close()
91 if opt.output_file != '-':
Sarah Owenscecd1d82012-11-01 22:59:27 -070092 print('Saved manifest to %s' % opt.output_file, file=sys.stderr)
Shawn O. Pearcec7a4eef2009-03-05 10:32:38 -080093
Mike Frysingerae6cb082019-08-27 01:10:59 -040094 def ValidateOptions(self, opt, args):
Shawn O. Pearcec7a4eef2009-03-05 10:32:38 -080095 if args:
96 self.Usage()
97
Mike Frysingerae6cb082019-08-27 01:10:59 -040098 def Execute(self, opt, args):
99 self._Output(opt)