Mercurial > public > mercurial-scm > hg
diff mercurial/hg.py @ 39848:4ece3cdfd907
localrepo: support shared repo creation
Previously, hg.share() had its own logic for creating a new
repository on the filesystem.
With the recent introduction of the createopts dict for passing
options to influence repository creation, it is now possible
to consolidate the repo creation code for both the normal and
shared use cases.
This commit teaches the repo creation code in localrepo to
recognize when we're creating a shared repo and to act
appropriately.
Meaningful behavior should be identical. However, there are a
few subtle changes:
* The .hg/requires file is written out in sorted order (rather
than having share-related requirements appended at end).
* The .hg directory is created with notindexed=True when a shared
repo is being created.
Differential Revision: https://phab.mercurial-scm.org/D4707
author | Gregory Szorc <gregory.szorc@gmail.com> |
---|---|
date | Wed, 19 Sep 2018 17:05:59 -0700 |
parents | c5e6c1ba1c79 |
children | d3d4b4b5f725 |
line wrap: on
line diff
--- a/mercurial/hg.py Wed Sep 19 16:51:57 2018 -0700 +++ b/mercurial/hg.py Wed Sep 19 17:05:59 2018 -0700 @@ -49,10 +49,6 @@ vfs as vfsmod, ) -from .utils import ( - stringutil, -) - release = lock.release # shared features @@ -261,44 +257,13 @@ rev, checkout = addbranchrevs(srcrepo, srcrepo, branches, None) else: srcrepo = source.local() - origsource = source = srcrepo.url() checkout = None - sharedpath = srcrepo.sharedpath # if our source is already sharing - - destwvfs = vfsmod.vfs(dest, realpath=True) - destvfs = vfsmod.vfs(os.path.join(destwvfs.base, '.hg'), realpath=True) - - if destvfs.lexists(): - raise error.Abort(_('destination already exists')) - - if not destwvfs.isdir(): - destwvfs.makedirs() - destvfs.makedir() + r = repository(ui, dest, create=True, createopts={ + 'sharedrepo': srcrepo, + 'sharedrelative': relative, + }) - requirements = '' - try: - requirements = srcrepo.vfs.read('requires') - except IOError as inst: - if inst.errno != errno.ENOENT: - raise - - if relative: - try: - sharedpath = os.path.relpath(sharedpath, destvfs.base) - requirements += 'relshared\n' - except (IOError, ValueError) as e: - # ValueError is raised on Windows if the drive letters differ on - # each path - raise error.Abort(_('cannot calculate relative path'), - hint=stringutil.forcebytestr(e)) - else: - requirements += 'shared\n' - - destvfs.write('requires', requirements) - destvfs.write('sharedpath', sharedpath) - - r = repository(ui, destwvfs.base) postshare(srcrepo, r, bookmarks=bookmarks, defaultpath=defaultpath) _postshareupdate(r, update, checkout=checkout) return r