Mercurial > hg
annotate hgext/interhg.py @ 19439:f4148c36f0aa
merge: deprecate the --force option
The --force option in merge does not make what people think it does so
it may not be visible to everyone.
I have local changes and want to pull one's changes which made 2 heads.
The --force option in help says
-f --force force a merge with outstanding changes
so I can expect that I can use it to force the merge and commit it in my
local repository without taking my local changes into account. But
merging with -f keeps local changes and "add" them: they must be
committed or reverted before doing the merge commit. The merge -f cannot
be reverted so it leads my repository in a bad state: cannot commit
merge and don't want to revert/commit local changes yet.
Message in help have been updated to emphasize the fact that local
changes are included in the merge.
author | Florence Laguzet <florence.laguzet@gmail.com> |
---|---|
date | Wed, 17 Jul 2013 23:58:04 +0200 |
parents | 38caf405d010 |
children |
rev | line source |
---|---|
4817
0ac6b537893f
interhg extension allows you to change changelog text like InterWiki.
OHASHI Hideya <ohachige@gmail.com>
parents:
diff
changeset
|
1 # interhg.py - interhg |
0ac6b537893f
interhg extension allows you to change changelog text like InterWiki.
OHASHI Hideya <ohachige@gmail.com>
parents:
diff
changeset
|
2 # |
0ac6b537893f
interhg extension allows you to change changelog text like InterWiki.
OHASHI Hideya <ohachige@gmail.com>
parents:
diff
changeset
|
3 # Copyright 2007 OHASHI Hideya <ohachige@gmail.com> |
0ac6b537893f
interhg extension allows you to change changelog text like InterWiki.
OHASHI Hideya <ohachige@gmail.com>
parents:
diff
changeset
|
4 # |
5288
18091102a633
interhg: allow more flexible pattern specification (fixes 2/3 of issue699)
Edward Lee <edward.lee@engineering.uiuc.edu>
parents:
4817
diff
changeset
|
5 # Contributor(s): |
18091102a633
interhg: allow more flexible pattern specification (fixes 2/3 of issue699)
Edward Lee <edward.lee@engineering.uiuc.edu>
parents:
4817
diff
changeset
|
6 # Edward Lee <edward.lee@engineering.uiuc.edu> |
18091102a633
interhg: allow more flexible pattern specification (fixes 2/3 of issue699)
Edward Lee <edward.lee@engineering.uiuc.edu>
parents:
4817
diff
changeset
|
7 # |
8225
46293a0c7e9f
updated license to be explicit about GPL version 2
Martin Geisler <mg@lazybytes.net>
parents:
7216
diff
changeset
|
8 # This software may be used and distributed according to the terms of the |
10263 | 9 # GNU General Public License version 2 or any later version. |
8824
67ee7587abea
interhg: upgrade comments to online help and improve them
Cédric Duval <cedricduval@free.fr>
parents:
8225
diff
changeset
|
10 |
67ee7587abea
interhg: upgrade comments to online help and improve them
Cédric Duval <cedricduval@free.fr>
parents:
8225
diff
changeset
|
11 '''expand expressions into changelog and summaries |
67ee7587abea
interhg: upgrade comments to online help and improve them
Cédric Duval <cedricduval@free.fr>
parents:
8225
diff
changeset
|
12 |
9263
2dd1ed9e44db
interhg: wrap docstrings at 70 characters
Martin Geisler <mg@lazybytes.net>
parents:
9211
diff
changeset
|
13 This extension allows the use of a special syntax in summaries, which |
2dd1ed9e44db
interhg: wrap docstrings at 70 characters
Martin Geisler <mg@lazybytes.net>
parents:
9211
diff
changeset
|
14 will be automatically expanded into links or any other arbitrary |
2dd1ed9e44db
interhg: wrap docstrings at 70 characters
Martin Geisler <mg@lazybytes.net>
parents:
9211
diff
changeset
|
15 expression, much like InterWiki does. |
8824
67ee7587abea
interhg: upgrade comments to online help and improve them
Cédric Duval <cedricduval@free.fr>
parents:
8225
diff
changeset
|
16 |
9263
2dd1ed9e44db
interhg: wrap docstrings at 70 characters
Martin Geisler <mg@lazybytes.net>
parents:
9211
diff
changeset
|
17 A few example patterns (link to bug tracking, etc.) that may be used |
2dd1ed9e44db
interhg: wrap docstrings at 70 characters
Martin Geisler <mg@lazybytes.net>
parents:
9211
diff
changeset
|
18 in your hgrc:: |
8824
67ee7587abea
interhg: upgrade comments to online help and improve them
Cédric Duval <cedricduval@free.fr>
parents:
8225
diff
changeset
|
19 |
67ee7587abea
interhg: upgrade comments to online help and improve them
Cédric Duval <cedricduval@free.fr>
parents:
8225
diff
changeset
|
20 [interhg] |
8910
0c610f77ae1a
interhg: escape backslashes in docstring
Martin Geisler <mg@lazybytes.net>
parents:
8909
diff
changeset
|
21 issues = s!issue(\\d+)!<a href="http://bts/issue\\1">issue\\1</a>! |
0c610f77ae1a
interhg: escape backslashes in docstring
Martin Geisler <mg@lazybytes.net>
parents:
8909
diff
changeset
|
22 bugzilla = s!((?:bug|b=|(?=#?\\d{4,}))(?:\\s*#?)(\\d+))!<a..=\\2">\\1</a>!i |
0c610f77ae1a
interhg: escape backslashes in docstring
Martin Geisler <mg@lazybytes.net>
parents:
8909
diff
changeset
|
23 boldify = s!(^|\\s)#(\\d+)\\b! <b>#\\2</b>! |
8824
67ee7587abea
interhg: upgrade comments to online help and improve them
Cédric Duval <cedricduval@free.fr>
parents:
8225
diff
changeset
|
24 ''' |
4817
0ac6b537893f
interhg extension allows you to change changelog text like InterWiki.
OHASHI Hideya <ohachige@gmail.com>
parents:
diff
changeset
|
25 |
0ac6b537893f
interhg extension allows you to change changelog text like InterWiki.
OHASHI Hideya <ohachige@gmail.com>
parents:
diff
changeset
|
26 import re |
0ac6b537893f
interhg extension allows you to change changelog text like InterWiki.
OHASHI Hideya <ohachige@gmail.com>
parents:
diff
changeset
|
27 from mercurial.hgweb import hgweb_mod |
7216
292fb2ad2846
extensions: use new wrapper functions
Matt Mackall <mpm@selenic.com>
parents:
6962
diff
changeset
|
28 from mercurial import templatefilters, extensions |
6962
2af657eafeba
i18n: mark strings for translation in interhg extension
Martin Geisler <mg@daimi.au.dk>
parents:
5976
diff
changeset
|
29 from mercurial.i18n import _ |
4817
0ac6b537893f
interhg extension allows you to change changelog text like InterWiki.
OHASHI Hideya <ohachige@gmail.com>
parents:
diff
changeset
|
30 |
16743
38caf405d010
hgext: mark all first-party extensions as such
Augie Fackler <raf@durin42.com>
parents:
12766
diff
changeset
|
31 testedwith = 'internal' |
38caf405d010
hgext: mark all first-party extensions as such
Augie Fackler <raf@durin42.com>
parents:
12766
diff
changeset
|
32 |
4817
0ac6b537893f
interhg extension allows you to change changelog text like InterWiki.
OHASHI Hideya <ohachige@gmail.com>
parents:
diff
changeset
|
33 interhg_table = [] |
0ac6b537893f
interhg extension allows you to change changelog text like InterWiki.
OHASHI Hideya <ohachige@gmail.com>
parents:
diff
changeset
|
34 |
12766
21a50fe47a92
interhg: use uisetup() instead of module-load side effects
Augie Fackler <durin42@gmail.com>
parents:
10472
diff
changeset
|
35 def uisetup(ui): |
21a50fe47a92
interhg: use uisetup() instead of module-load side effects
Augie Fackler <durin42@gmail.com>
parents:
10472
diff
changeset
|
36 orig_escape = templatefilters.filters["escape"] |
4817
0ac6b537893f
interhg extension allows you to change changelog text like InterWiki.
OHASHI Hideya <ohachige@gmail.com>
parents:
diff
changeset
|
37 |
12766
21a50fe47a92
interhg: use uisetup() instead of module-load side effects
Augie Fackler <durin42@gmail.com>
parents:
10472
diff
changeset
|
38 def interhg_escape(x): |
21a50fe47a92
interhg: use uisetup() instead of module-load side effects
Augie Fackler <durin42@gmail.com>
parents:
10472
diff
changeset
|
39 escstr = orig_escape(x) |
21a50fe47a92
interhg: use uisetup() instead of module-load side effects
Augie Fackler <durin42@gmail.com>
parents:
10472
diff
changeset
|
40 for regexp, format in interhg_table: |
21a50fe47a92
interhg: use uisetup() instead of module-load side effects
Augie Fackler <durin42@gmail.com>
parents:
10472
diff
changeset
|
41 escstr = regexp.sub(format, escstr) |
21a50fe47a92
interhg: use uisetup() instead of module-load side effects
Augie Fackler <durin42@gmail.com>
parents:
10472
diff
changeset
|
42 return escstr |
21a50fe47a92
interhg: use uisetup() instead of module-load side effects
Augie Fackler <durin42@gmail.com>
parents:
10472
diff
changeset
|
43 |
21a50fe47a92
interhg: use uisetup() instead of module-load side effects
Augie Fackler <durin42@gmail.com>
parents:
10472
diff
changeset
|
44 templatefilters.filters["escape"] = interhg_escape |
4817
0ac6b537893f
interhg extension allows you to change changelog text like InterWiki.
OHASHI Hideya <ohachige@gmail.com>
parents:
diff
changeset
|
45 |
10472
9126d13bad7a
interhg: fixes regression introduced by 38170eeed18c
Wagner Bruna <wbruna@yahoo.com>
parents:
10263
diff
changeset
|
46 def interhg_refresh(orig, self, *args, **kwargs): |
4817
0ac6b537893f
interhg extension allows you to change changelog text like InterWiki.
OHASHI Hideya <ohachige@gmail.com>
parents:
diff
changeset
|
47 interhg_table[:] = [] |
5288
18091102a633
interhg: allow more flexible pattern specification (fixes 2/3 of issue699)
Edward Lee <edward.lee@engineering.uiuc.edu>
parents:
4817
diff
changeset
|
48 for key, pattern in self.repo.ui.configitems('interhg'): |
18091102a633
interhg: allow more flexible pattern specification (fixes 2/3 of issue699)
Edward Lee <edward.lee@engineering.uiuc.edu>
parents:
4817
diff
changeset
|
49 # grab the delimiter from the character after the "s" |
18091102a633
interhg: allow more flexible pattern specification (fixes 2/3 of issue699)
Edward Lee <edward.lee@engineering.uiuc.edu>
parents:
4817
diff
changeset
|
50 unesc = pattern[1] |
18091102a633
interhg: allow more flexible pattern specification (fixes 2/3 of issue699)
Edward Lee <edward.lee@engineering.uiuc.edu>
parents:
4817
diff
changeset
|
51 delim = re.escape(unesc) |
18091102a633
interhg: allow more flexible pattern specification (fixes 2/3 of issue699)
Edward Lee <edward.lee@engineering.uiuc.edu>
parents:
4817
diff
changeset
|
52 |
18091102a633
interhg: allow more flexible pattern specification (fixes 2/3 of issue699)
Edward Lee <edward.lee@engineering.uiuc.edu>
parents:
4817
diff
changeset
|
53 # identify portions of the pattern, taking care to avoid escaped |
18091102a633
interhg: allow more flexible pattern specification (fixes 2/3 of issue699)
Edward Lee <edward.lee@engineering.uiuc.edu>
parents:
4817
diff
changeset
|
54 # delimiters. the replace format and flags are optional, but delimiters |
18091102a633
interhg: allow more flexible pattern specification (fixes 2/3 of issue699)
Edward Lee <edward.lee@engineering.uiuc.edu>
parents:
4817
diff
changeset
|
55 # are required. |
18091102a633
interhg: allow more flexible pattern specification (fixes 2/3 of issue699)
Edward Lee <edward.lee@engineering.uiuc.edu>
parents:
4817
diff
changeset
|
56 match = re.match(r'^s%s(.+)(?:(?<=\\\\)|(?<!\\))%s(.*)%s([ilmsux])*$' |
18091102a633
interhg: allow more flexible pattern specification (fixes 2/3 of issue699)
Edward Lee <edward.lee@engineering.uiuc.edu>
parents:
4817
diff
changeset
|
57 % (delim, delim, delim), pattern) |
18091102a633
interhg: allow more flexible pattern specification (fixes 2/3 of issue699)
Edward Lee <edward.lee@engineering.uiuc.edu>
parents:
4817
diff
changeset
|
58 if not match: |
6962
2af657eafeba
i18n: mark strings for translation in interhg extension
Martin Geisler <mg@daimi.au.dk>
parents:
5976
diff
changeset
|
59 self.repo.ui.warn(_("interhg: invalid pattern for %s: %s\n") |
5288
18091102a633
interhg: allow more flexible pattern specification (fixes 2/3 of issue699)
Edward Lee <edward.lee@engineering.uiuc.edu>
parents:
4817
diff
changeset
|
60 % (key, pattern)) |
18091102a633
interhg: allow more flexible pattern specification (fixes 2/3 of issue699)
Edward Lee <edward.lee@engineering.uiuc.edu>
parents:
4817
diff
changeset
|
61 continue |
18091102a633
interhg: allow more flexible pattern specification (fixes 2/3 of issue699)
Edward Lee <edward.lee@engineering.uiuc.edu>
parents:
4817
diff
changeset
|
62 |
18091102a633
interhg: allow more flexible pattern specification (fixes 2/3 of issue699)
Edward Lee <edward.lee@engineering.uiuc.edu>
parents:
4817
diff
changeset
|
63 # we need to unescape the delimiter for regexp and format |
18091102a633
interhg: allow more flexible pattern specification (fixes 2/3 of issue699)
Edward Lee <edward.lee@engineering.uiuc.edu>
parents:
4817
diff
changeset
|
64 delim_re = re.compile(r'(?<!\\)\\%s' % delim) |
18091102a633
interhg: allow more flexible pattern specification (fixes 2/3 of issue699)
Edward Lee <edward.lee@engineering.uiuc.edu>
parents:
4817
diff
changeset
|
65 regexp = delim_re.sub(unesc, match.group(1)) |
18091102a633
interhg: allow more flexible pattern specification (fixes 2/3 of issue699)
Edward Lee <edward.lee@engineering.uiuc.edu>
parents:
4817
diff
changeset
|
66 format = delim_re.sub(unesc, match.group(2)) |
18091102a633
interhg: allow more flexible pattern specification (fixes 2/3 of issue699)
Edward Lee <edward.lee@engineering.uiuc.edu>
parents:
4817
diff
changeset
|
67 |
18091102a633
interhg: allow more flexible pattern specification (fixes 2/3 of issue699)
Edward Lee <edward.lee@engineering.uiuc.edu>
parents:
4817
diff
changeset
|
68 # the pattern allows for 6 regexp flags, so set them if necessary |
18091102a633
interhg: allow more flexible pattern specification (fixes 2/3 of issue699)
Edward Lee <edward.lee@engineering.uiuc.edu>
parents:
4817
diff
changeset
|
69 flagin = match.group(3) |
18091102a633
interhg: allow more flexible pattern specification (fixes 2/3 of issue699)
Edward Lee <edward.lee@engineering.uiuc.edu>
parents:
4817
diff
changeset
|
70 flags = 0 |
18091102a633
interhg: allow more flexible pattern specification (fixes 2/3 of issue699)
Edward Lee <edward.lee@engineering.uiuc.edu>
parents:
4817
diff
changeset
|
71 if flagin: |
18091102a633
interhg: allow more flexible pattern specification (fixes 2/3 of issue699)
Edward Lee <edward.lee@engineering.uiuc.edu>
parents:
4817
diff
changeset
|
72 for flag in flagin.upper(): |
18091102a633
interhg: allow more flexible pattern specification (fixes 2/3 of issue699)
Edward Lee <edward.lee@engineering.uiuc.edu>
parents:
4817
diff
changeset
|
73 flags |= re.__dict__[flag] |
18091102a633
interhg: allow more flexible pattern specification (fixes 2/3 of issue699)
Edward Lee <edward.lee@engineering.uiuc.edu>
parents:
4817
diff
changeset
|
74 |
18091102a633
interhg: allow more flexible pattern specification (fixes 2/3 of issue699)
Edward Lee <edward.lee@engineering.uiuc.edu>
parents:
4817
diff
changeset
|
75 try: |
18091102a633
interhg: allow more flexible pattern specification (fixes 2/3 of issue699)
Edward Lee <edward.lee@engineering.uiuc.edu>
parents:
4817
diff
changeset
|
76 regexp = re.compile(regexp, flags) |
18091102a633
interhg: allow more flexible pattern specification (fixes 2/3 of issue699)
Edward Lee <edward.lee@engineering.uiuc.edu>
parents:
4817
diff
changeset
|
77 interhg_table.append((regexp, format)) |
18091102a633
interhg: allow more flexible pattern specification (fixes 2/3 of issue699)
Edward Lee <edward.lee@engineering.uiuc.edu>
parents:
4817
diff
changeset
|
78 except re.error: |
6962
2af657eafeba
i18n: mark strings for translation in interhg extension
Martin Geisler <mg@daimi.au.dk>
parents:
5976
diff
changeset
|
79 self.repo.ui.warn(_("interhg: invalid regexp for %s: %s\n") |
5288
18091102a633
interhg: allow more flexible pattern specification (fixes 2/3 of issue699)
Edward Lee <edward.lee@engineering.uiuc.edu>
parents:
4817
diff
changeset
|
80 % (key, regexp)) |
10472
9126d13bad7a
interhg: fixes regression introduced by 38170eeed18c
Wagner Bruna <wbruna@yahoo.com>
parents:
10263
diff
changeset
|
81 return orig(self, *args, **kwargs) |
4817
0ac6b537893f
interhg extension allows you to change changelog text like InterWiki.
OHASHI Hideya <ohachige@gmail.com>
parents:
diff
changeset
|
82 |
7216
292fb2ad2846
extensions: use new wrapper functions
Matt Mackall <mpm@selenic.com>
parents:
6962
diff
changeset
|
83 extensions.wrapfunction(hgweb_mod.hgweb, 'refresh', interhg_refresh) |