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:
Shawn O. Pearce 2009-07-03 16:37:30 -07:00
parent 5f947bba69
commit 87bda12e85
3 changed files with 22 additions and 1 deletions

View File

@ -15,6 +15,7 @@
import os
from error import ManifestParseError
from editor import Editor
from git_config import GitConfig
from project import MetaProject
@ -45,3 +46,6 @@ class Manifest(object):
def SetMRefs(self, project):
pass
def Upgrade_Local(self, old):
raise ManifestParseError, 'unsupported upgrade path'

View File

@ -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'

View File

@ -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():