[PATCH v3] version: show enabled extensions (issue4209)

anatoly techtonik techtonik at gmail.com
Fri Jun 13 16:21:31 CDT 2014


# HG changeset patch
# User anatoly techtonik <techtonik at gmail.com>
# Date 1402397077 -10800
#      Tue Jun 10 13:44:37 2014 +0300
# Branch stable
# Node ID c490acacbf9869e1c8e9ed5cb5d281c0643190ec
# Parent  14560418856dbd2b1b5d0bf1b4ae3bceffc4eef0
version: show enabled extensions (issue4209)

This code is based by hg-versions extension (GPLv2)
by Markus Zapke-Gruendemann <info at keimlink.de>


http://mercurial.selenic.com/wiki/VersionsExtension

diff -r 14560418856d -r c490acacbf98 mercurial/commands.py
--- a/mercurial/commands.py	Mon May 26 19:02:11 2014 +0200
+++ b/mercurial/commands.py	Tue Jun 10 13:44:37 2014 +0300
@@ -14,6 +14,7 @@
 import patch, help, encoding, templatekw, discovery
 import archival, changegroup, cmdutil, hbisect
 import sshserver, hgweb, commandserver
+import extensions
 from hgweb import server as hgweb_server
 import merge as mergemod
 import minirst, revset, fileset
@@ -5921,6 +5922,19 @@
         "not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.\n"
     ))
 
+    ui.note(_("\nEnabled extensions:\n\n"))
+    if ui.verbose:
+        # format names and versions into columns
+        names = []
+        vers = []
+        for name, module in extensions.extensions():
+            names.append(name)
+            vers.append(extensions.moduleversion(module))
+        maxnamelen = max(len(n) for n in names)
+        for i, name in enumerate(names):
+            ui.write("  %*s  %s\n" % (maxnamelen, name, vers[i]))
+
+
 norepo = ("clone init version help debugcommands debugcomplete"
           " debugdate debuginstall debugfsinfo debugpushkey debugwireargs"
           " debugknown debuggetbundle debugbundle")
diff -r 14560418856d -r c490acacbf98 mercurial/extensions.py
--- a/mercurial/extensions.py	Mon May 26 19:02:11 2014 +0200
+++ b/mercurial/extensions.py	Tue Jun 10 13:44:37 2014 +0300
@@ -367,3 +367,16 @@
         exts[ename] = doc.splitlines()[0].strip()
 
     return exts
+
+def moduleversion(module):
+    '''return version information from given module as a string'''
+    if (util.safehasattr(module, 'get_version')
+          and callable(module.get_version)):
+        version = module.get_version()
+    elif util.safehasattr(module, '__version__'):
+        version = module.__version__
+    else:
+        version = ''
+    if isinstance(version, (list, tuple)):
+        version = '.'.join(str(o) for o in version)
+    return version


More information about the Mercurial-devel mailing list