Mercurial > evolve
changeset 205:7ba30bd95a88
obsolete: fix rollback wrapper for 2.2-rc
author | Pierre-Yves David <pierre-yves.david@logilab.fr> |
---|---|
date | Mon, 23 Apr 2012 14:54:06 +0200 |
parents | 50039b9b535e |
children | 80f602e6ae8a |
files | hgext/obsolete.py |
diffstat | 1 files changed, 18 insertions(+), 7 deletions(-) [+] |
line wrap: on
line diff
--- a/hgext/obsolete.py Fri Apr 20 17:12:38 2012 +0200 +++ b/hgext/obsolete.py Mon Apr 23 14:54:06 2012 +0200 @@ -369,8 +369,7 @@ # /!\ api change in Hg 2.2 (97efd26eb9576f39590812ea9) /!\ if util.safehasattr(repo, '_journalfiles'): # Hg 2.2 o_journalfiles = repo._journalfiles - else: # XXX remove this bloc while breaking support to Hg 2.1 - o_writejournal = repo._writejournal + o_writejournal = repo._writejournal class obsoletingrepo(repo.__class__): @@ -543,9 +542,20 @@ # /!\ api change in Hg 2.2 (97efd26eb9576f39590812ea9) /!\ if util.safehasattr(repo, '_journalfiles'): # Hg 2.2 def _journalfiles(self): - return o_journalfiles() + ('journal.obsolete-relations',) + return o_journalfiles() + (self.join('journal.obsolete-relations'),) + + def _writejournal(self, desc): + """wrapped version of _writejournal that save obsolete data""" + o_writejournal(desc) + filename = 'obsolete-relations' + filepath = self.join(filename) + if os.path.exists(filepath): + journalname = 'journal.' + filename + journalpath = self.join(journalname) + util.copyfile(filepath, journalpath) + else: # XXX remove this bloc while breaking support to Hg 2.1 - def _writejournal(self, desc): + def _writejournal(self, desc): """wrapped version of _writejournal that save obsolete data""" entries = list(o_writejournal(desc)) filename = 'obsolete-relations' @@ -557,15 +567,16 @@ entries.append(journalpath) return tuple(entries) - def _rollback(self, dryrun=False, **kwargs): + def _rollback(self, dryrun, force): """wrapped version of _rollback that restore obsolete data""" - ret = o_rollback(dryrun, **kwargs) + ret = o_rollback(dryrun, force) if not (ret or dryrun): #rollback did not failed src = self.join('undo.obsolete-relations') dst = self.join('obsolete-relations') if os.path.exists(src): util.rename(src, dst) - elif os.path.exists(dst): #unlink in any case + elif os.path.exists(dst): + # If no state was saved because the file did not existed before. os.unlink(dst) # invalidate cache self.__dict__.pop('_obssubrels', None)