Show More
@@ -0,0 +1,62 | |||||
|
1 | # Copyright (C) 2005 by Intevation GmbH | |||
|
2 | # Author(s): | |||
|
3 | # Thomas Arendsen Hein <thomas@intevation.de> | |||
|
4 | # | |||
|
5 | # This program is free software under the GNU GPL (>=v2) | |||
|
6 | # Read the file COPYING coming with the software for details. | |||
|
7 | ||||
|
8 | """ | |||
|
9 | Mercurial version | |||
|
10 | """ | |||
|
11 | ||||
|
12 | import os | |||
|
13 | import os.path | |||
|
14 | import re | |||
|
15 | import time | |||
|
16 | ||||
|
17 | unknown_version = 'unknown' | |||
|
18 | ||||
|
19 | def get_version(): | |||
|
20 | """Return version information if available.""" | |||
|
21 | try: | |||
|
22 | from mercurial.__version__ import version | |||
|
23 | except ImportError: | |||
|
24 | version = unknown_version | |||
|
25 | return version | |||
|
26 | ||||
|
27 | def write_version(version): | |||
|
28 | """Overwrite version file.""" | |||
|
29 | filename = os.path.join(os.path.dirname(__file__), '__version__.py') | |||
|
30 | f = open(filename, 'w') | |||
|
31 | f.write("# This file is auto-generated.\n") | |||
|
32 | f.write("version = %r\n" % version) | |||
|
33 | f.close() | |||
|
34 | ||||
|
35 | def remember_version(): | |||
|
36 | """Store version information.""" | |||
|
37 | f = os.popen("hg identify 2>/dev/null") # use real hg installation | |||
|
38 | ident = f.read()[:-1] | |||
|
39 | if not f.close() and ident: | |||
|
40 | ids = ident.split(' ', 1) | |||
|
41 | version = ids.pop(0) | |||
|
42 | if version[-1] == '+': | |||
|
43 | version = version[:-1] | |||
|
44 | modified = True | |||
|
45 | else: | |||
|
46 | modified = False | |||
|
47 | if version.isalnum() and ids: | |||
|
48 | for tag in ids[0].split('/'): | |||
|
49 | # is a tag is suitable as a version number? | |||
|
50 | if re.match(r'^(\d+\.)+[\w.-]+$', tag): | |||
|
51 | version = tag | |||
|
52 | break | |||
|
53 | if modified: | |||
|
54 | version += time.strftime('+%Y%m%d') | |||
|
55 | else: | |||
|
56 | version = unknown_version | |||
|
57 | write_version(version) | |||
|
58 | ||||
|
59 | def forget_version(): | |||
|
60 | """Remove version information.""" | |||
|
61 | write_version(unknown_version) | |||
|
62 |
@@ -7,4 +7,5 build/.* | |||||
7 | dist/ |
|
7 | dist/ | |
8 | MANIFEST$ |
|
8 | MANIFEST$ | |
9 | .pc/ |
|
9 | .pc/ | |
10 | patches/ No newline at end of file |
|
10 | patches/ | |
|
11 | mercurial/__version__.py$ |
@@ -6,7 +6,7 General: | |||||
6 | - python 2.2 support |
|
6 | - python 2.2 support | |
7 | - better import support |
|
7 | - better import support | |
8 | - export to git |
|
8 | - export to git | |
9 |
- Add standard files: AUTHORS, CREDITS, C |
|
9 | - Add standard files: AUTHORS, CREDITS, ChangeLog? What else? | |
10 | - Code cleanup: apply http://python.org/peps/pep-0008.html |
|
10 | - Code cleanup: apply http://python.org/peps/pep-0008.html | |
11 |
|
11 | |||
12 | Core: |
|
12 | Core: | |
@@ -33,7 +33,6 Commands: | |||||
33 | - hg -v history doesn't show tkmerge as modified (removed). |
|
33 | - hg -v history doesn't show tkmerge as modified (removed). | |
34 | - hg import vs. hg patch in help etc., import is a reserved python |
|
34 | - hg import vs. hg patch in help etc., import is a reserved python | |
35 | word, PEP8 mentions trailing underscore as a convention for this. |
|
35 | word, PEP8 mentions trailing underscore as a convention for this. | |
36 | - version reporting (hg --version / version.py / setup.py etc.) |
|
|||
37 | - hg pull default in a subdir doesn't work, if it is a relative path |
|
36 | - hg pull default in a subdir doesn't work, if it is a relative path | |
38 | - optionally only show merges (two parents or parent != changeset-1, etc.) |
|
37 | - optionally only show merges (two parents or parent != changeset-1, etc.) | |
39 |
|
38 |
@@ -8,7 +8,7 | |||||
8 | import os, re, sys, signal |
|
8 | import os, re, sys, signal | |
9 | import fancyopts, ui, hg |
|
9 | import fancyopts, ui, hg | |
10 | from demandload import * |
|
10 | from demandload import * | |
11 | demandload(globals(), "mdiff time hgweb traceback random signal errno") |
|
11 | demandload(globals(), "mdiff time hgweb traceback random signal errno version") | |
12 |
|
12 | |||
13 | class UnknownCommand(Exception): pass |
|
13 | class UnknownCommand(Exception): pass | |
14 |
|
14 | |||
@@ -134,6 +134,16 def show_changeset(ui, repo, rev=0, chan | |||||
134 | ui.status("summary: %s\n" % description.splitlines()[0]) |
|
134 | ui.status("summary: %s\n" % description.splitlines()[0]) | |
135 | ui.status("\n") |
|
135 | ui.status("\n") | |
136 |
|
136 | |||
|
137 | def show_version(ui): | |||
|
138 | """output version and copyright information""" | |||
|
139 | ui.write("Mercurial version %s\n" % version.get_version()) | |||
|
140 | ui.status( | |||
|
141 | "\nCopyright (C) 2005 Matt Mackall <mpm@selenic.com>\n" | |||
|
142 | "This is free software; see the source for copying conditions. " | |||
|
143 | "There is NO\nwarranty; " | |||
|
144 | "not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.\n" | |||
|
145 | ) | |||
|
146 | ||||
137 | def help(ui, cmd=None): |
|
147 | def help(ui, cmd=None): | |
138 | '''show help for a given command or all commands''' |
|
148 | '''show help for a given command or all commands''' | |
139 | if cmd: |
|
149 | if cmd: | |
@@ -156,7 +166,10 def help(ui, cmd=None): | |||||
156 | ui.warn("hg: unknown command %s\n" % cmd) |
|
166 | ui.warn("hg: unknown command %s\n" % cmd) | |
157 | sys.exit(0) |
|
167 | sys.exit(0) | |
158 | else: |
|
168 | else: | |
159 | ui.status('hg commands:\n\n') |
|
169 | if not ui.quiet: | |
|
170 | show_version(ui) | |||
|
171 | ui.write('\n') | |||
|
172 | ui.write('hg commands:\n\n') | |||
160 |
|
173 | |||
161 | h = {} |
|
174 | h = {} | |
162 | for e in table.values(): |
|
175 | for e in table.values(): | |
@@ -171,7 +184,7 def help(ui, cmd=None): | |||||
171 | fns.sort() |
|
184 | fns.sort() | |
172 | m = max(map(len, fns)) |
|
185 | m = max(map(len, fns)) | |
173 | for f in fns: |
|
186 | for f in fns: | |
174 |
ui. |
|
187 | ui.write(' %-*s %s\n' % (m, f, h[f])) | |
175 |
|
188 | |||
176 | # Commands start here, listed alphabetically |
|
189 | # Commands start here, listed alphabetically | |
177 |
|
190 | |||
@@ -679,7 +692,7 table = { | |||||
679 | "verify": (verify, [], 'hg verify'), |
|
692 | "verify": (verify, [], 'hg verify'), | |
680 | } |
|
693 | } | |
681 |
|
694 | |||
682 |
norepo = "init |
|
695 | norepo = "init version help debugindex debugindexdot" | |
683 |
|
696 | |||
684 | def find(cmd): |
|
697 | def find(cmd): | |
685 | i = None |
|
698 | i = None | |
@@ -704,6 +717,7 def dispatch(args): | |||||
704 | ('q', 'quiet', None, 'quiet'), |
|
717 | ('q', 'quiet', None, 'quiet'), | |
705 | ('p', 'profile', None, 'profile'), |
|
718 | ('p', 'profile', None, 'profile'), | |
706 | ('y', 'noninteractive', None, 'run non-interactively'), |
|
719 | ('y', 'noninteractive', None, 'run non-interactively'), | |
|
720 | ('', 'version', None, 'output version information and exit'), | |||
707 | ] |
|
721 | ] | |
708 |
|
722 | |||
709 | args = fancyopts.fancyopts(args, opts, options, |
|
723 | args = fancyopts.fancyopts(args, opts, options, | |
@@ -717,6 +731,10 def dispatch(args): | |||||
717 | u = ui.ui(options["verbose"], options["debug"], options["quiet"], |
|
731 | u = ui.ui(options["verbose"], options["debug"], options["quiet"], | |
718 | not options["noninteractive"]) |
|
732 | not options["noninteractive"]) | |
719 |
|
733 | |||
|
734 | if options["version"]: | |||
|
735 | show_version(u) | |||
|
736 | sys.exit(0) | |||
|
737 | ||||
720 | try: |
|
738 | try: | |
721 | i = find(cmd) |
|
739 | i = find(cmd) | |
722 | except UnknownCommand: |
|
740 | except UnknownCommand: |
@@ -9,14 +9,18 import glob | |||||
9 | from distutils.core import setup, Extension |
|
9 | from distutils.core import setup, Extension | |
10 | from distutils.command.install_data import install_data |
|
10 | from distutils.command.install_data import install_data | |
11 |
|
11 | |||
|
12 | import mercurial.version | |||
|
13 | ||||
12 | class install_package_data(install_data): |
|
14 | class install_package_data(install_data): | |
13 | def finalize_options(self): |
|
15 | def finalize_options(self): | |
14 | self.set_undefined_options('install', |
|
16 | self.set_undefined_options('install', | |
15 | ('install_lib', 'install_dir')) |
|
17 | ('install_lib', 'install_dir')) | |
16 | install_data.finalize_options(self) |
|
18 | install_data.finalize_options(self) | |
17 |
|
19 | |||
|
20 | try: | |||
|
21 | mercurial.version.remember_version() | |||
18 | setup(name='mercurial', |
|
22 | setup(name='mercurial', | |
19 | version='0.5b', |
|
23 | version=mercurial.version.get_version(), | |
20 | author='Matt Mackall', |
|
24 | author='Matt Mackall', | |
21 | author_email='mpm@selenic.com', |
|
25 | author_email='mpm@selenic.com', | |
22 | url='http://selenic.com/mercurial', |
|
26 | url='http://selenic.com/mercurial', | |
@@ -30,3 +34,5 setup(name='mercurial', | |||||
30 | glob.glob('templates/*.tmpl'))], |
|
34 | glob.glob('templates/*.tmpl'))], | |
31 | cmdclass = { 'install_data' : install_package_data }, |
|
35 | cmdclass = { 'install_data' : install_package_data }, | |
32 | scripts=['hg', 'hgmerge']) |
|
36 | scripts=['hg', 'hgmerge']) | |
|
37 | finally: | |||
|
38 | mercurial.version.forget_version() |
@@ -2,10 +2,10 | |||||
2 |
|
2 | |||
3 | set -x |
|
3 | set -x | |
4 |
|
4 | |||
5 | hg help |
|
5 | hg -q help | |
6 | hg add -h |
|
6 | hg add -h | |
7 | hg help diff |
|
7 | hg help diff | |
8 | hg help foo |
|
8 | hg help foo | |
9 | hg commands |
|
9 | hg -q commands | |
10 |
|
10 | |||
11 | exit 0 No newline at end of file |
|
11 | exit 0 |
@@ -1,4 +1,4 | |||||
1 | + hg help |
|
1 | + hg -q help | |
2 | hg commands: |
|
2 | hg commands: | |
3 |
|
3 | |||
4 | add add the specified files on the next commit |
|
4 | add add the specified files on the next commit | |
@@ -45,7 +45,7 hg diff [-r A] [-r B] [files] | |||||
45 | diff working directory (or selected files) |
|
45 | diff working directory (or selected files) | |
46 | + hg help foo |
|
46 | + hg help foo | |
47 | hg: unknown command foo |
|
47 | hg: unknown command foo | |
48 | + hg commands |
|
48 | + hg -q commands | |
49 | hg: unknown command 'commands' |
|
49 | hg: unknown command 'commands' | |
50 | hg commands: |
|
50 | hg commands: | |
51 |
|
51 |
General Comments 0
You need to be logged in to leave comments.
Login now