# HG changeset patch # User Sean Farley <s...@farley.io> # Date 1497572003 25200 # Thu Jun 15 17:13:23 2017 -0700 # Branch fix-old-git # Node ID 8e8e4eb5d74ec4ed2ea59db3defa9819ddc0db8b # Parent 07d5a503124caed05e1300a5208240764882c831 hghave: add has_git_range for testing if git understands ext::sh
Even on CentOS 7, git is at version 1.8. It seems git 1.9 is when ext::sh was introduced so we a check for that. The way these functions are written follows the same style and format for the way we check svn and bzr versions. diff --git a/tests/hghave.py b/tests/hghave.py index 09b8dbe..2cb0d1f 100644 --- a/tests/hghave.py +++ b/tests/hghave.py @@ -276,10 +276,21 @@ def has_gettext(): @check("git", "git command line client") def has_git(): return matchoutput('git --version 2>&1', br'^git version') +def getgitversion(): + m = matchoutput('git --version 2>&1', br'git version (\d+)\.(\d+)') + if not m: + return (0, 0) + return (int(m.group(1)), int(m.group(2))) + +@checkvers("git", "git client (with ext::sh support) version >= %s", (1.9,)) +def has_git_range(v): + major, minor = v.split('.')[0:2] + return getgitversion() >= (int(major), int(minor)) + @check("docutils", "Docutils text processing library") def has_docutils(): try: import docutils.core docutils.core.publish_cmdline # silence unused import _______________________________________________ Mercurial-devel mailing list Mercurial-devel@mercurial-scm.org https://www.mercurial-scm.org/mailman/listinfo/mercurial-devel