##// END OF EJS Templates
shelve: move possible shelve file extensions to a single place...
Kostia Balytskyi -
r30378:c5126aab default
parent child Browse files
Show More
@@ -62,6 +62,7 testedwith = 'ships-with-hg-core'
62
62
63 backupdir = 'shelve-backup'
63 backupdir = 'shelve-backup'
64 shelvedir = 'shelved'
64 shelvedir = 'shelved'
65 shelvefileextensions = ['hg', 'patch']
65
66
66 class shelvedfile(object):
67 class shelvedfile(object):
67 """Helper for the file storing a single shelve
68 """Helper for the file storing a single shelve
@@ -221,7 +222,7 def cleanupoldbackups(repo):
221 # keep it, because timestamp can't decide exact order of backups
222 # keep it, because timestamp can't decide exact order of backups
222 continue
223 continue
223 base = f[:-3]
224 base = f[:-3]
224 for ext in 'hg patch'.split():
225 for ext in shelvefileextensions:
225 try:
226 try:
226 vfs.unlink(base + '.' + ext)
227 vfs.unlink(base + '.' + ext)
227 except OSError as err:
228 except OSError as err:
@@ -399,7 +400,7 def cleanupcmd(ui, repo):
399 with repo.wlock():
400 with repo.wlock():
400 for (name, _type) in repo.vfs.readdir(shelvedir):
401 for (name, _type) in repo.vfs.readdir(shelvedir):
401 suffix = name.rsplit('.', 1)[-1]
402 suffix = name.rsplit('.', 1)[-1]
402 if suffix in ('hg', 'patch'):
403 if suffix in shelvefileextensions:
403 shelvedfile(repo, name).movetobackup()
404 shelvedfile(repo, name).movetobackup()
404 cleanupoldbackups(repo)
405 cleanupoldbackups(repo)
405
406
@@ -410,8 +411,15 def deletecmd(ui, repo, pats):
410 with repo.wlock():
411 with repo.wlock():
411 try:
412 try:
412 for name in pats:
413 for name in pats:
413 for suffix in 'hg patch'.split():
414 for suffix in shelvefileextensions:
414 shelvedfile(repo, name, suffix).movetobackup()
415 shfile = shelvedfile(repo, name, suffix)
416 # patch file is necessary, as it should
417 # be present for any kind of shelve,
418 # but the .hg file is optional as in future we
419 # will add obsolete shelve with does not create a
420 # bundle
421 if shfile.exists() or suffix == 'patch':
422 shfile.movetobackup()
415 cleanupoldbackups(repo)
423 cleanupoldbackups(repo)
416 except OSError as err:
424 except OSError as err:
417 if err.errno != errno.ENOENT:
425 if err.errno != errno.ENOENT:
@@ -557,8 +565,10 def restorebranch(ui, repo, branchtorest
557 def unshelvecleanup(ui, repo, name, opts):
565 def unshelvecleanup(ui, repo, name, opts):
558 """remove related files after an unshelve"""
566 """remove related files after an unshelve"""
559 if not opts.get('keep'):
567 if not opts.get('keep'):
560 for filetype in 'hg patch'.split():
568 for filetype in shelvefileextensions:
561 shelvedfile(repo, name, filetype).movetobackup()
569 shfile = shelvedfile(repo, name, filetype)
570 if shfile.exists():
571 shfile.movetobackup()
562 cleanupoldbackups(repo)
572 cleanupoldbackups(repo)
563
573
564 def unshelvecontinue(ui, repo, state, opts):
574 def unshelvecontinue(ui, repo, state, opts):
General Comments 0
You need to be logged in to leave comments. Login now