diff options
Diffstat (limited to 'subcmds/manifest.py')
| -rw-r--r-- | subcmds/manifest.py | 37 | 
1 files changed, 35 insertions, 2 deletions
| diff --git a/subcmds/manifest.py b/subcmds/manifest.py index 7a8b2ee8..dcd3df17 100644 --- a/subcmds/manifest.py +++ b/subcmds/manifest.py | |||
| @@ -17,6 +17,7 @@ import os | |||
| 17 | import sys | 17 | import sys | 
| 18 | 18 | ||
| 19 | from command import PagedCommand | 19 | from command import PagedCommand | 
| 20 | from manifest_submodule import SubmoduleManifest | ||
| 20 | from manifest_xml import XmlManifest | 21 | from manifest_xml import XmlManifest | 
| 21 | 22 | ||
| 22 | def _doc(name): | 23 | def _doc(name): | 
| @@ -54,6 +55,9 @@ in a Git repository for use during future 'repo init' invocations. | |||
| 54 | 55 | ||
| 55 | def _Options(self, p): | 56 | def _Options(self, p): | 
| 56 | if isinstance(self.manifest, XmlManifest): | 57 | if isinstance(self.manifest, XmlManifest): | 
| 58 | p.add_option('--upgrade', | ||
| 59 | dest='upgrade', action='store_true', | ||
| 60 | help='Upgrade XML manifest to submodule') | ||
| 57 | p.add_option('-r', '--revision-as-HEAD', | 61 | p.add_option('-r', '--revision-as-HEAD', | 
| 58 | dest='peg_rev', action='store_true', | 62 | dest='peg_rev', action='store_true', | 
| 59 | help='Save revisions as current HEAD') | 63 | help='Save revisions as current HEAD') | 
| @@ -62,6 +66,11 @@ in a Git repository for use during future 'repo init' invocations. | |||
| 62 | help='File to save the manifest to', | 66 | help='File to save the manifest to', | 
| 63 | metavar='-|NAME.xml') | 67 | metavar='-|NAME.xml') | 
| 64 | 68 | ||
| 69 | def WantPager(self, opt): | ||
| 70 | if isinstance(self.manifest, XmlManifest) and opt.upgrade: | ||
| 71 | return False | ||
| 72 | return True | ||
| 73 | |||
| 65 | def _Output(self, opt): | 74 | def _Output(self, opt): | 
| 66 | if opt.output_file == '-': | 75 | if opt.output_file == '-': | 
| 67 | fd = sys.stdout | 76 | fd = sys.stdout | 
| @@ -73,12 +82,36 @@ in a Git repository for use during future 'repo init' invocations. | |||
| 73 | if opt.output_file != '-': | 82 | if opt.output_file != '-': | 
| 74 | print >>sys.stderr, 'Saved manifest to %s' % opt.output_file | 83 | print >>sys.stderr, 'Saved manifest to %s' % opt.output_file | 
| 75 | 84 | ||
| 85 | def _Upgrade(self): | ||
| 86 | old = self.manifest | ||
| 87 | |||
| 88 | if isinstance(old, SubmoduleManifest): | ||
| 89 | print >>sys.stderr, 'error: already upgraded' | ||
| 90 | sys.exit(1) | ||
| 91 | |||
| 92 | old._Load() | ||
| 93 | for p in old.projects.values(): | ||
| 94 | if not os.path.exists(p.gitdir) \ | ||
| 95 | or not os.path.exists(p.worktree): | ||
| 96 | print >>sys.stderr, 'fatal: project "%s" missing' % p.relpath | ||
| 97 | sys.exit(1) | ||
| 98 | |||
| 99 | new = SubmoduleManifest(old.repodir) | ||
| 100 | new.FromXml_Local_1(old, checkout=False) | ||
| 101 | new.FromXml_Definition(old) | ||
| 102 | new.FromXml_Local_2(old) | ||
| 103 | print >>sys.stderr, 'upgraded manifest; commit result manually' | ||
| 104 | |||
| 76 | def Execute(self, opt, args): | 105 | def Execute(self, opt, args): | 
| 77 | if args: | 106 | if args: | 
| 78 | self.Usage() | 107 | self.Usage() | 
| 79 | 108 | ||
| 80 | if isinstance(self.manifest, XmlManifest) \ | 109 | if isinstance(self.manifest, XmlManifest): | 
| 81 | and opt.output_file is not None: | 110 | if opt.upgrade: | 
| 111 | self._Upgrade() | ||
| 112 | return | ||
| 113 | |||
| 114 | if opt.output_file is not None: | ||
| 82 | self._Output(opt) | 115 | self._Output(opt) | 
| 83 | return | 116 | return | 
| 84 | 117 | ||
