Show More
@@ -326,12 +326,13 b' def get(context, mapping, args):' | |||
|
326 | 326 | yield dictarg.get(key) |
|
327 | 327 | |
|
328 | 328 | def _evalifliteral(arg, context, mapping): |
|
329 | t = stringify(arg[0](context, mapping, arg[1])) | |
|
330 | if arg[0] == runstring or arg[0] == runrawstring: | |
|
329 | # get back to token tag to reinterpret string as template | |
|
330 | strtoken = {runstring: 'string', runrawstring: 'rawstring'}.get(arg[0]) | |
|
331 | if strtoken: | |
|
331 | 332 | yield runtemplate(context, mapping, |
|
332 |
compiletemplate( |
|
|
333 | compiletemplate(arg[1], context, strtoken)) | |
|
333 | 334 | else: |
|
334 | yield t | |
|
335 | yield stringify(arg[0](context, mapping, arg[1])) | |
|
335 | 336 | |
|
336 | 337 | def if_(context, mapping, args): |
|
337 | 338 | """:if(expr, then[, else]): Conditionally execute based on the result of |
@@ -2284,6 +2284,17 b' Test leading backslashes:' | |||
|
2284 | 2284 | \{rev} \{file} \\\head1 |
|
2285 | 2285 | $ cd .. |
|
2286 | 2286 | |
|
2287 | Test leading backslashes in "if" expression (issue4714): | |
|
2288 | ||
|
2289 | $ cd latesttag | |
|
2290 | $ hg log -r 2 -T '{if("1", "\{rev}")} {if("1", r"\{rev}")}\n' | |
|
2291 | {rev} \2 | |
|
2292 | $ hg log -r 2 -T '{if("1", "\\{rev}")} {if("1", r"\\{rev}")}\n' | |
|
2293 | \2 \\2 | |
|
2294 | $ hg log -r 2 -T '{if("1", "\\\{rev}")} {if("1", r"\\\{rev}")}\n' | |
|
2295 | \{rev} \\\2 | |
|
2296 | $ cd .. | |
|
2297 | ||
|
2287 | 2298 | "string-escape"-ed "\x5c\x786e" becomes r"\x6e" (once) or r"n" (twice) |
|
2288 | 2299 | |
|
2289 | 2300 | $ hg log -R a -r 0 --template '{if("1", "\x5c\x786e", "NG")}\n' |
General Comments 0
You need to be logged in to leave comments.
Login now