Re: [PATCH 2 of 2] ui: add explicit path to write prompt text bypassing buffers

2018-02-07 Thread Augie Fackler


> On Feb 5, 2018, at 13:11, Yuya Nishihara  wrote:
> 
> # HG changeset patch
> # User Yuya Nishihara 
> # Date 1517831331 -32400
> #  Mon Feb 05 20:48:51 2018 +0900
> # Node ID 59869758acd7b38d9de045d5a72f5196cc80f047
> # Parent  9be8a0f8d48502734066a66e3d5b9b22e460ae70
> ui: add explicit path to write prompt text bypassing buffers

queued, thanks
___
Mercurial-devel mailing list
Mercurial-devel@mercurial-scm.org
https://www.mercurial-scm.org/mailman/listinfo/mercurial-devel


[PATCH 2 of 2] ui: add explicit path to write prompt text bypassing buffers

2018-02-05 Thread Yuya Nishihara
# HG changeset patch
# User Yuya Nishihara 
# Date 1517831331 -32400
#  Mon Feb 05 20:48:51 2018 +0900
# Node ID 59869758acd7b38d9de045d5a72f5196cc80f047
# Parent  9be8a0f8d48502734066a66e3d5b9b22e460ae70
ui: add explicit path to write prompt text bypassing buffers

The prompt= flag was added at e35d7f131483, when colorui had its own write()
function. Since we've merged colorui to ui, we can simply call the unbuffered
write() function.

diff --git a/mercurial/ui.py b/mercurial/ui.py
--- a/mercurial/ui.py
+++ b/mercurial/ui.py
@@ -886,13 +886,17 @@ class ui(object):
 "cmdname.type" is recommended. For example, status issues
 a label of "status.modified" for modified files.
 '''
-if self._buffers and not opts.get(r'prompt', False):
+if self._buffers:
 if self._bufferapplylabels:
 label = opts.get(r'label', '')
 self._buffers[-1].extend(self.label(a, label) for a in args)
 else:
 self._buffers[-1].extend(args)
-elif self._colormode == 'win32':
+else:
+self._writenobuf(*args, **opts)
+
+def _writenobuf(self, *args, **opts):
+if self._colormode == 'win32':
 # windows color printing is its own can of crab, defer to
 # the color module and that is it.
 color.win32print(self, self._write, *args, **opts)
@@ -1276,7 +1280,7 @@ class ui(object):
 if not self.interactive():
 self.write(msg, ' ', default or '', "\n")
 return default
-self.write(msg, label='ui.prompt', prompt=True)
+self._writenobuf(msg, label='ui.prompt')
 self.flush()
 try:
 r = self._readline()
___
Mercurial-devel mailing list
Mercurial-devel@mercurial-scm.org
https://www.mercurial-scm.org/mailman/listinfo/mercurial-devel