comparison mercurial/ui.py @ 39678:50f46b771921

py3: partially fix pager spawning on Windows Previously, spinning up the pager crashed because the command and environment was in bytes. (See also 543a788eea2d.) Now it aborts with an invalid handle: $ HGMODULEPOLICY=py py -3 ../hg --traceback --config extensions.evolve=! Traceback (most recent call last): File "c:\Users\Matt\projects\hg\mercurial\ui.py", line 967, in _write self.fout.write(''.join(msgs)) File "c:\Users\Matt\projects\hg\mercurial\windows.py", line 173, in write self.fp.write(s[start:end]) OSError: [WinError 6] The handle is invalid During handling of the above exception, another exception occurred: Traceback (most recent call last): File "c:\Users\Matt\projects\hg\mercurial\scmutil.py", line 164, in callcatch return func() File "c:\Users\Matt\projects\hg\mercurial\dispatch.py", line 350, in _runcatchfunc return _dispatch(req) File "c:\Users\Matt\projects\hg\mercurial\dispatch.py", line 930, in _dispatch return commands.help_(ui, 'shortlist') File "c:\Users\Matt\projects\hg\mercurial\commands.py", line 2930, in help_ ui.write(formatted) File "c:\Users\Matt\projects\hg\mercurial\ui.py", line 948, in write self._writenobuf(*args, **opts) File "c:\Users\Matt\projects\hg\mercurial\ui.py", line 960, in _writenobuf self._write(*msgs, **opts) File "c:\Users\Matt\projects\hg\mercurial\ui.py", line 969, in _write raise error.StdioError(err) mercurial.error.StdioError: [Errno 9] The handle is invalid abort: The handle is invalid The interesting bit here is that the abort message is marked with ANSI color, but the OSError is not.
author Matt Harbison <matt_harbison@yahoo.com>
date Sat, 15 Sep 2018 13:31:41 -0400
parents 6f38284b23f4
children 24e493ec2229
comparison
equal deleted inserted replaced
39677:8bfbb25859f1 39678:50f46b771921
1128 1128
1129 command = fullcmd 1129 command = fullcmd
1130 1130
1131 try: 1131 try:
1132 pager = subprocess.Popen( 1132 pager = subprocess.Popen(
1133 command, shell=shell, bufsize=-1, 1133 procutil.tonativestr(command), shell=shell, bufsize=-1,
1134 close_fds=procutil.closefds, stdin=subprocess.PIPE, 1134 close_fds=procutil.closefds, stdin=subprocess.PIPE,
1135 stdout=procutil.stdout, stderr=procutil.stderr, 1135 stdout=procutil.stdout, stderr=procutil.stderr,
1136 env=procutil.shellenviron(env)) 1136 env=procutil.tonativeenv(procutil.shellenviron(env)))
1137 except OSError as e: 1137 except OSError as e:
1138 if e.errno == errno.ENOENT and not shell: 1138 if e.errno == errno.ENOENT and not shell:
1139 self.warn(_("missing pager command '%s', skipping pager\n") 1139 self.warn(_("missing pager command '%s', skipping pager\n")
1140 % command) 1140 % command)
1141 return False 1141 return False