D7633: clone: extract helper for checking mutually exclusive args
martinvonz (Martin von Zweigbergk)
phabricator at mercurial-scm.org
Fri Dec 13 07:56:21 UTC 2019
martinvonz created this revision.
Herald added a subscriber: mercurial-devel.
Herald added a reviewer: hg-reviewers.
REVISION SUMMARY
We have some duplicated code for aborting if the user provided
mutually exclusive arguments. Extensions surely have more such
code. We also have duplicated translations and inconsistent output in
this area.
This patch introduces a simpler helper for checking if more than one
option among a given set was given on the command line. I've made the
clone code call the function to show that it works.
The function has no good way of checking arguments with hyphens in
them. I'll add that later if necessary. The function still won't be
applicable in all cases, but I think it's still better than nothing.
REPOSITORY
rHG Mercurial
BRANCH
default
REVISION DETAIL
https://phab.mercurial-scm.org/D7633
AFFECTED FILES
mercurial/cmdutil.py
mercurial/commands.py
CHANGE DETAILS
diff --git a/mercurial/commands.py b/mercurial/commands.py
--- a/mercurial/commands.py
+++ b/mercurial/commands.py
@@ -1889,8 +1889,7 @@
Returns 0 on success.
"""
opts = pycompat.byteskwargs(opts)
- if opts.get(b'noupdate') and opts.get(b'updaterev'):
- raise error.Abort(_(b"cannot specify both --noupdate and --updaterev"))
+ cmdutil.check_unique_argument(opts, b'noupdate', b'updaterev')
# --include/--exclude can come from narrow or sparse.
includepats, excludepats = None, None
diff --git a/mercurial/cmdutil.py b/mercurial/cmdutil.py
--- a/mercurial/cmdutil.py
+++ b/mercurial/cmdutil.py
@@ -260,6 +260,18 @@
_linebelow = b"^HG: ------------------------ >8 ------------------------$"
+def check_unique_argument(opts, *args):
+ """abort if more than one of the arguments are in opts"""
+ previous = None
+ for x in args:
+ if opts.get(x):
+ if previous:
+ raise error.Abort(
+ _(b'cannot specify both --%s and --%s') % (previous, x)
+ )
+ previous = x
+
+
def resolvecommitoptions(ui, opts):
"""modify commit options dict to handle related options
To: martinvonz, #hg-reviewers
Cc: mercurial-devel
More information about the Mercurial-devel
mailing list