Mercurial > hg
annotate mercurial/templates/map-cmdline.xml @ 45095:8e04607023e5
procutil: ensure that procutil.std{out,err}.write() writes all bytes
Python 3 offers different kind of streams and it’s not guaranteed for all of
them that calling write() writes all bytes.
When Python is started in unbuffered mode, sys.std{out,err}.buffer are
instances of io.FileIO, whose write() can write less bytes for
platform-specific reasons (e.g. Linux has a 0x7ffff000 bytes maximum and could
write less if interrupted by a signal; when writing to Windows consoles, it’s
limited to 32767 bytes to avoid the "not enough space" error). This can lead to
silent loss of data, both when using sys.std{out,err}.buffer (which may in fact
not be a buffered stream) and when using the text streams sys.std{out,err}
(I’ve created a CPython bug report for that:
https://bugs.python.org/issue41221).
Python may fix the problem at some point. For now, we implement our own wrapper
for procutil.std{out,err} that calls the raw stream’s write() method until all
bytes have been written. We don’t use sys.std{out,err} for larger writes, so I
think it’s not worth the effort to patch them.
author | Manuel Jacob <me@manueljacob.de> |
---|---|
date | Fri, 10 Jul 2020 12:27:58 +0200 |
parents | f4aeb952ab77 |
children |
rev | line source |
---|---|
34714
f4aeb952ab77
templater: load template fragments from [templates] section in map file
Yuya Nishihara <yuya@tcha.org>
parents:
26222
diff
changeset
|
1 [templates] |
26222
3095b1027661
templater: add new docheader/footer components for XML (issue4135)
Matt Mackall <mpm@selenic.com>
parents:
13387
diff
changeset
|
2 docheader = '<?xml version="1.0"?>\n<log>\n' |
3095b1027661
templater: add new docheader/footer components for XML (issue4135)
Matt Mackall <mpm@selenic.com>
parents:
13387
diff
changeset
|
3 docfooter = '</log>\n' |
10153 | 4 |
13387
0be2fe6a0843
templates: add bookmarks to command line styles
David Soria Parra <dsp@php.net>
parents:
10159
diff
changeset
|
5 changeset = '<logentry revision="{rev}" node="{node}">\n{branches}{bookmarks}{tags}{parents}<author email="{author|email|xmlescape}">{author|person|xmlescape}</author>\n<date>{date|rfc3339date}</date>\n<msg xml:space="preserve">{desc|xmlescape}</msg>\n</logentry>\n' |
0be2fe6a0843
templates: add bookmarks to command line styles
David Soria Parra <dsp@php.net>
parents:
10159
diff
changeset
|
6 changeset_verbose = '<logentry revision="{rev}" node="{node}">\n{branches}{bookmarks}{tags}{parents}<author email="{author|email|xmlescape}">{author|person|xmlescape}</author>\n<date>{date|rfc3339date}</date>\n<msg xml:space="preserve">{desc|xmlescape}</msg>\n<paths>\n{file_adds}{file_dels}{file_mods}</paths>\n{file_copies}</logentry>\n' |
0be2fe6a0843
templates: add bookmarks to command line styles
David Soria Parra <dsp@php.net>
parents:
10159
diff
changeset
|
7 changeset_debug = '<logentry revision="{rev}" node="{node}">\n{branches}{bookmarks}{tags}{parents}<author email="{author|email|xmlescape}">{author|person|xmlescape}</author>\n<date>{date|rfc3339date}</date>\n<msg xml:space="preserve">{desc|xmlescape}</msg>\n<paths>\n{file_adds}{file_dels}{file_mods}</paths>\n{file_copies}{extras}</logentry>\n' |
10153 | 8 |
9 file_add = '<path action="A">{file_add|xmlescape}</path>\n' | |
10 file_mod = '<path action="M">{file_mod|xmlescape}</path>\n' | |
11 file_del = '<path action="R">{file_del|xmlescape}</path>\n' | |
12 | |
13 start_file_copies = '<copies>\n' | |
14 file_copy = '<copy source="{source|xmlescape}">{name|xmlescape}</copy>\n' | |
15 end_file_copies = '</copies>\n' | |
16 | |
17 parent = '<parent revision="{rev}" node="{node}" />\n' | |
18 branch = '<branch>{branch|xmlescape}</branch>\n' | |
19 tag = '<tag>{tag|xmlescape}</tag>\n' | |
13387
0be2fe6a0843
templates: add bookmarks to command line styles
David Soria Parra <dsp@php.net>
parents:
10159
diff
changeset
|
20 bookmark = '<bookmark>{bookmark|xmlescape}</bookmark>\n' |
10159
182416227722
Added output of "extras" to hg log XML output
Robert Bachmann <rbachm@gmail.com>
parents:
10153
diff
changeset
|
21 extra = '<extra key="{key|xmlescape}">{value|xmlescape}</extra>\n' |