Show More
@@ -109,10 +109,27 def logmessage(ui, opts): | |||||
109 | (logfile, inst.strerror)) |
|
109 | (logfile, inst.strerror)) | |
110 | return message |
|
110 | return message | |
111 |
|
111 | |||
112 | def getcommiteditor(edit=False, **opts): |
|
112 | def getcommiteditor(edit=False, finishdesc=None, extramsg=None, **opts): | |
113 |
"""get appropriate commit message editor according to '--edit' option |
|
113 | """get appropriate commit message editor according to '--edit' option | |
114 | if edit: |
|
114 | ||
115 | return commitforceeditor |
|
115 | 'finishdesc' is a function to be called with edited commit message | |
|
116 | (= 'description' of the new changeset) just after editing, but | |||
|
117 | before checking empty-ness. It should return actual text to be | |||
|
118 | stored into history. This allows to change description before | |||
|
119 | storing. | |||
|
120 | ||||
|
121 | 'extramsg' is a extra message to be shown in the editor instead of | |||
|
122 | 'Leave message empty to abort commit' line. 'HG: ' prefix and EOL | |||
|
123 | is automatically added. | |||
|
124 | ||||
|
125 | 'getcommiteditor' returns 'commitforceeditor' regardless of | |||
|
126 | 'edit', if one of 'finishdesc' or 'extramsg' is specified, because | |||
|
127 | they are specific for usage in MQ. | |||
|
128 | """ | |||
|
129 | if edit or finishdesc or extramsg: | |||
|
130 | return lambda r, c, s: commitforceeditor(r, c, s, | |||
|
131 | finishdesc=finishdesc, | |||
|
132 | extramsg=extramsg) | |||
116 | else: |
|
133 | else: | |
117 | return commiteditor |
|
134 | return commiteditor | |
118 |
|
135 | |||
@@ -2130,7 +2147,7 def commiteditor(repo, ctx, subs): | |||||
2130 | return ctx.description() |
|
2147 | return ctx.description() | |
2131 | return commitforceeditor(repo, ctx, subs) |
|
2148 | return commitforceeditor(repo, ctx, subs) | |
2132 |
|
2149 | |||
2133 | def commitforceeditor(repo, ctx, subs): |
|
2150 | def commitforceeditor(repo, ctx, subs, finishdesc=None, extramsg=None): | |
2134 | edittext = [] |
|
2151 | edittext = [] | |
2135 | modified, added, removed = ctx.modified(), ctx.added(), ctx.removed() |
|
2152 | modified, added, removed = ctx.modified(), ctx.added(), ctx.removed() | |
2136 | if ctx.description(): |
|
2153 | if ctx.description(): | |
@@ -2139,6 +2156,9 def commitforceeditor(repo, ctx, subs): | |||||
2139 | edittext.append("") # Empty line between message and comments. |
|
2156 | edittext.append("") # Empty line between message and comments. | |
2140 | edittext.append(_("HG: Enter commit message." |
|
2157 | edittext.append(_("HG: Enter commit message." | |
2141 | " Lines beginning with 'HG:' are removed.")) |
|
2158 | " Lines beginning with 'HG:' are removed.")) | |
|
2159 | if extramsg: | |||
|
2160 | edittext.append("HG: %s" % extramsg) | |||
|
2161 | else: | |||
2142 | edittext.append(_("HG: Leave message empty to abort commit.")) |
|
2162 | edittext.append(_("HG: Leave message empty to abort commit.")) | |
2143 | edittext.append("HG: --") |
|
2163 | edittext.append("HG: --") | |
2144 | edittext.append(_("HG: user: %s") % ctx.user()) |
|
2164 | edittext.append(_("HG: user: %s") % ctx.user()) | |
@@ -2162,6 +2182,8 def commitforceeditor(repo, ctx, subs): | |||||
2162 | text = re.sub("(?m)^HG:.*(\n|$)", "", text) |
|
2182 | text = re.sub("(?m)^HG:.*(\n|$)", "", text) | |
2163 | os.chdir(olddir) |
|
2183 | os.chdir(olddir) | |
2164 |
|
2184 | |||
|
2185 | if finishdesc: | |||
|
2186 | text = finishdesc(text) | |||
2165 | if not text.strip(): |
|
2187 | if not text.strip(): | |
2166 | raise util.Abort(_("empty commit message")) |
|
2188 | raise util.Abort(_("empty commit message")) | |
2167 |
|
2189 |
General Comments 0
You need to be logged in to leave comments.
Login now