diff options
author | Lorry <lorry@roadtrain.codethink.co.uk> | 2012-08-22 14:49:51 +0100 |
---|---|---|
committer | Lorry <lorry@roadtrain.codethink.co.uk> | 2012-08-22 14:49:51 +0100 |
commit | a498da43c7fdb9f24b73680c02a4a3588cc62d9a (patch) | |
tree | daf8119dae1749b5165b68033a1b23a7375ce9ce /mercurial/pushkey.py | |
download | mercurial-tarball-a498da43c7fdb9f24b73680c02a4a3588cc62d9a.tar.gz |
Tarball conversion
Diffstat (limited to 'mercurial/pushkey.py')
-rw-r--r-- | mercurial/pushkey.py | 39 |
1 files changed, 39 insertions, 0 deletions
diff --git a/mercurial/pushkey.py b/mercurial/pushkey.py new file mode 100644 index 0000000..7d692d0 --- /dev/null +++ b/mercurial/pushkey.py @@ -0,0 +1,39 @@ +# pushkey.py - dispatching for pushing and pulling keys +# +# Copyright 2010 Matt Mackall <mpm@selenic.com> +# +# This software may be used and distributed according to the terms of the +# GNU General Public License version 2 or any later version. + +import bookmarks, phases, obsolete + +def _nslist(repo): + n = {} + for k in _namespaces: + n[k] = "" + if not obsolete._enabled: + n.pop('obsolete') + return n + +_namespaces = {"namespaces": (lambda *x: False, _nslist), + "bookmarks": (bookmarks.pushbookmark, bookmarks.listbookmarks), + "phases": (phases.pushphase, phases.listphases), + "obsolete": (obsolete.pushmarker, obsolete.listmarkers), + } + +def register(namespace, pushkey, listkeys): + _namespaces[namespace] = (pushkey, listkeys) + +def _get(namespace): + return _namespaces.get(namespace, (lambda *x: False, lambda *x: {})) + +def push(repo, namespace, key, old, new): + '''should succeed iff value was old''' + pk = _get(namespace)[0] + return pk(repo, key, old, new) + +def list(repo, namespace): + '''return a dict''' + lk = _get(namespace)[1] + return lk(repo) + |