mirror of
https://github.com/Dev-Wiki/git-repo.git
synced 2025-09-27 11:12:14 +08:00
sync: Support upgrading manifest formats
If the manifest format changes during init or sync we need to do a full reparse of the manifest, and possibly allow the new object to reconfigure the local workspace to match its expectations. Signed-off-by: Shawn O. Pearce <sop@google.com>
This commit is contained in:
@@ -22,6 +22,7 @@ from error import ManifestParseError
|
||||
from project import SyncBuffer
|
||||
from git_command import git_require, MIN_GIT_VERSION
|
||||
from manifest_xml import XmlManifest
|
||||
from subcmds.sync import _ReloadManifest
|
||||
|
||||
class Init(InteractiveCommand, MirrorSafeCommand):
|
||||
common = True
|
||||
@@ -143,9 +144,17 @@ to update the working directory files.
|
||||
print >>sys.stderr, 'fatal: cannot obtain manifest %s' % r.url
|
||||
sys.exit(1)
|
||||
|
||||
if not is_new:
|
||||
# Force the manifest to load if it exists, the old graph
|
||||
# may be needed inside of _ReloadManifest().
|
||||
#
|
||||
self.manifest.projects
|
||||
|
||||
syncbuf = SyncBuffer(m.config)
|
||||
m.Sync_LocalHalf(syncbuf)
|
||||
syncbuf.Finish()
|
||||
_ReloadManifest(self)
|
||||
self._ApplyOptions(opt, is_new)
|
||||
|
||||
if not self.manifest.InitBranch():
|
||||
print >>sys.stderr, 'fatal: cannot create branch in manifest'
|
||||
|
@@ -215,8 +215,9 @@ uncommitted changes are present' % project.relpath
|
||||
mp.Sync_LocalHalf(syncbuf)
|
||||
if not syncbuf.Finish():
|
||||
sys.exit(1)
|
||||
_ReloadManifest(self)
|
||||
mp = self.manifest.manifestProject
|
||||
|
||||
self.GetManifest(reparse=True)
|
||||
all = self.GetProjects(args, missing_ok=True)
|
||||
missing = []
|
||||
for project in all:
|
||||
@@ -243,6 +244,13 @@ uncommitted changes are present' % project.relpath
|
||||
if not syncbuf.Finish():
|
||||
sys.exit(1)
|
||||
|
||||
def _ReloadManifest(cmd):
|
||||
old = cmd.manifest
|
||||
new = cmd.GetManifest(reparse=True)
|
||||
|
||||
if old.__class__ != new.__class__:
|
||||
print >>sys.stderr, 'NOTICE: manifest format has changed ***'
|
||||
new.Upgrade_Local(old)
|
||||
|
||||
def _PostRepoUpgrade(manifest):
|
||||
for project in manifest.projects.values():
|
||||
|
Reference in New Issue
Block a user