##// END OF EJS Templates
procutil: bulk-replace util.std* to point to new module
Yuya Nishihara -
r37137:d4a2e0d5 default
parent child Browse files
Show More
@@ -61,6 +61,10 b' from . import ('
61 util,
61 util,
62 )
62 )
63
63
64 from .utils import (
65 procutil,
66 )
67
64 _log = commandserver.log
68 _log = commandserver.log
65
69
66 def _hashlist(items):
70 def _hashlist(items):
@@ -200,7 +204,7 b' def _newchgui(srcui, csystem, attachio):'
200 # these situations and will behave differently (write to stdout).
204 # these situations and will behave differently (write to stdout).
201 if (out is not self.fout
205 if (out is not self.fout
202 or not util.safehasattr(self.fout, 'fileno')
206 or not util.safehasattr(self.fout, 'fileno')
203 or self.fout.fileno() != util.stdout.fileno()):
207 or self.fout.fileno() != procutil.stdout.fileno()):
204 return util.system(cmd, environ=environ, cwd=cwd, out=out)
208 return util.system(cmd, environ=environ, cwd=cwd, out=out)
205 self.flush()
209 self.flush()
206 return self._csystem(cmd, util.shellenviron(environ), cwd)
210 return self._csystem(cmd, util.shellenviron(environ), cwd)
@@ -29,6 +29,9 b' from . import ('
29 pycompat,
29 pycompat,
30 util,
30 util,
31 )
31 )
32 from .utils import (
33 procutil,
34 )
32
35
33 logfile = None
36 logfile = None
34
37
@@ -308,8 +311,8 b' def _protectio(ui):'
308 ui.flush()
311 ui.flush()
309 newfiles = []
312 newfiles = []
310 nullfd = os.open(os.devnull, os.O_RDWR)
313 nullfd = os.open(os.devnull, os.O_RDWR)
311 for f, sysf, mode in [(ui.fin, util.stdin, r'rb'),
314 for f, sysf, mode in [(ui.fin, procutil.stdin, r'rb'),
312 (ui.fout, util.stdout, r'wb')]:
315 (ui.fout, procutil.stdout, r'wb')]:
313 if f is sysf:
316 if f is sysf:
314 newfd = os.dup(f.fileno())
317 newfd = os.dup(f.fileno())
315 os.dup2(nullfd, f.fileno())
318 os.dup2(nullfd, f.fileno())
@@ -42,6 +42,7 b' from . import ('
42 )
42 )
43
43
44 from .utils import (
44 from .utils import (
45 procutil,
45 stringutil,
46 stringutil,
46 )
47 )
47
48
@@ -127,8 +128,8 b' if pycompat.ispy3:'
127 pass
128 pass
128 # Otherwise mark it as closed to silence "Exception ignored in"
129 # Otherwise mark it as closed to silence "Exception ignored in"
129 # message emitted by the interpreter finalizer. Be careful to
130 # message emitted by the interpreter finalizer. Be careful to
130 # not close util.stdout, which may be a fdopen-ed file object and
131 # not close procutil.stdout, which may be a fdopen-ed file object
131 # its close() actually closes the underlying file descriptor.
132 # and its close() actually closes the underlying file descriptor.
132 try:
133 try:
133 fp.close()
134 fp.close()
134 except IOError:
135 except IOError:
@@ -180,7 +181,7 b' def dispatch(req):'
180 elif req.ui:
181 elif req.ui:
181 ferr = req.ui.ferr
182 ferr = req.ui.ferr
182 else:
183 else:
183 ferr = util.stderr
184 ferr = procutil.stderr
184
185
185 try:
186 try:
186 if not req.ui:
187 if not req.ui:
@@ -15,13 +15,17 b' from .. import ('
15 util,
15 util,
16 )
16 )
17
17
18 from ..utils import (
19 procutil,
20 )
21
18 from . import (
22 from . import (
19 common,
23 common,
20 )
24 )
21
25
22 def launch(application):
26 def launch(application):
23 util.setbinary(util.stdin)
27 util.setbinary(procutil.stdin)
24 util.setbinary(util.stdout)
28 util.setbinary(procutil.stdout)
25
29
26 environ = dict(encoding.environ.iteritems())
30 environ = dict(encoding.environ.iteritems())
27 environ.setdefault(r'PATH_INFO', '')
31 environ.setdefault(r'PATH_INFO', '')
@@ -31,12 +35,12 b' def launch(application):'
31 if environ[r'PATH_INFO'].startswith(scriptname):
35 if environ[r'PATH_INFO'].startswith(scriptname):
32 environ[r'PATH_INFO'] = environ[r'PATH_INFO'][len(scriptname):]
36 environ[r'PATH_INFO'] = environ[r'PATH_INFO'][len(scriptname):]
33
37
34 stdin = util.stdin
38 stdin = procutil.stdin
35 if environ.get(r'HTTP_EXPECT', r'').lower() == r'100-continue':
39 if environ.get(r'HTTP_EXPECT', r'').lower() == r'100-continue':
36 stdin = common.continuereader(stdin, util.stdout.write)
40 stdin = common.continuereader(stdin, procutil.stdout.write)
37
41
38 environ[r'wsgi.input'] = stdin
42 environ[r'wsgi.input'] = stdin
39 environ[r'wsgi.errors'] = util.stderr
43 environ[r'wsgi.errors'] = procutil.stderr
40 environ[r'wsgi.version'] = (1, 0)
44 environ[r'wsgi.version'] = (1, 0)
41 environ[r'wsgi.multithread'] = False
45 environ[r'wsgi.multithread'] = False
42 environ[r'wsgi.multiprocess'] = True
46 environ[r'wsgi.multiprocess'] = True
@@ -49,7 +53,7 b' def launch(application):'
49
53
50 headers_set = []
54 headers_set = []
51 headers_sent = []
55 headers_sent = []
52 out = util.stdout
56 out = procutil.stdout
53
57
54 def write(data):
58 def write(data):
55 if not headers_set:
59 if not headers_set:
@@ -19,6 +19,9 b' from . import ('
19 pycompat,
19 pycompat,
20 util,
20 util,
21 )
21 )
22 from .utils import (
23 procutil,
24 )
22
25
23 def _pythonhook(ui, repo, htype, hname, funcname, args, throw):
26 def _pythonhook(ui, repo, htype, hname, funcname, args, throw):
24 '''call python hook. hook is callable object, looked up as
27 '''call python hook. hook is callable object, looked up as
@@ -222,11 +225,11 b' def runhooks(ui, repo, htype, hooks, thr'
222 for hname, cmd in hooks:
225 for hname, cmd in hooks:
223 if oldstdout == -1 and _redirect:
226 if oldstdout == -1 and _redirect:
224 try:
227 try:
225 stdoutno = util.stdout.fileno()
228 stdoutno = procutil.stdout.fileno()
226 stderrno = util.stderr.fileno()
229 stderrno = procutil.stderr.fileno()
227 # temporarily redirect stdout to stderr, if possible
230 # temporarily redirect stdout to stderr, if possible
228 if stdoutno >= 0 and stderrno >= 0:
231 if stdoutno >= 0 and stderrno >= 0:
229 util.stdout.flush()
232 procutil.stdout.flush()
230 oldstdout = os.dup(stdoutno)
233 oldstdout = os.dup(stdoutno)
231 os.dup2(stderrno, stdoutno)
234 os.dup2(stderrno, stdoutno)
232 except (OSError, AttributeError):
235 except (OSError, AttributeError):
@@ -269,10 +272,10 b' def runhooks(ui, repo, htype, hooks, thr'
269 # The stderr is fully buffered on Windows when connected to a pipe.
272 # The stderr is fully buffered on Windows when connected to a pipe.
270 # A forcible flush is required to make small stderr data in the
273 # A forcible flush is required to make small stderr data in the
271 # remote side available to the client immediately.
274 # remote side available to the client immediately.
272 util.stderr.flush()
275 procutil.stderr.flush()
273
276
274 if _redirect and oldstdout >= 0:
277 if _redirect and oldstdout >= 0:
275 util.stdout.flush() # write hook output to stderr fd
278 procutil.stdout.flush() # write hook output to stderr fd
276 os.dup2(oldstdout, stdoutno)
279 os.dup2(oldstdout, stdoutno)
277 os.close(oldstdout)
280 os.close(oldstdout)
278
281
@@ -97,6 +97,9 b' from . import ('
97 urllibcompat,
97 urllibcompat,
98 util,
98 util,
99 )
99 )
100 from .utils import (
101 procutil,
102 )
100
103
101 httplib = util.httplib
104 httplib = util.httplib
102 urlerr = util.urlerr
105 urlerr = util.urlerr
@@ -635,14 +638,14 b' def continuity(url):'
635 def comp(N, url):
638 def comp(N, url):
636 print(' making %i connections to:\n %s' % (N, url))
639 print(' making %i connections to:\n %s' % (N, url))
637
640
638 util.stdout.write(' first using the normal urllib handlers')
641 procutil.stdout.write(' first using the normal urllib handlers')
639 # first use normal opener
642 # first use normal opener
640 opener = urlreq.buildopener()
643 opener = urlreq.buildopener()
641 urlreq.installopener(opener)
644 urlreq.installopener(opener)
642 t1 = fetch(N, url)
645 t1 = fetch(N, url)
643 print(' TIME: %.3f s' % t1)
646 print(' TIME: %.3f s' % t1)
644
647
645 util.stdout.write(' now using the keepalive handler ')
648 procutil.stdout.write(' now using the keepalive handler ')
646 # now install the keepalive handler and try again
649 # now install the keepalive handler and try again
647 opener = urlreq.buildopener(HTTPHandler())
650 opener = urlreq.buildopener(HTTPHandler())
648 urlreq.installopener(opener)
651 urlreq.installopener(opener)
@@ -687,11 +690,11 b' def test_timeout(url):'
687 i = 20
690 i = 20
688 print(" waiting %i seconds for the server to close the connection" % i)
691 print(" waiting %i seconds for the server to close the connection" % i)
689 while i > 0:
692 while i > 0:
690 util.stdout.write('\r %2i' % i)
693 procutil.stdout.write('\r %2i' % i)
691 util.stdout.flush()
694 procutil.stdout.flush()
692 time.sleep(1)
695 time.sleep(1)
693 i -= 1
696 i -= 1
694 util.stderr.write('\r')
697 procutil.stderr.write('\r')
695
698
696 print(" fetching the file a second time")
699 print(" fetching the file a second time")
697 fo = urlreq.urlopen(url)
700 fo = urlreq.urlopen(url)
@@ -22,6 +22,10 b' from . import ('
22 util,
22 util,
23 )
23 )
24
24
25 from .utils import (
26 procutil,
27 )
28
25 def runservice(opts, parentfn=None, initfn=None, runfn=None, logfile=None,
29 def runservice(opts, parentfn=None, initfn=None, runfn=None, logfile=None,
26 runargs=None, appendpid=False):
30 runargs=None, appendpid=False):
27 '''Run a command as a service.'''
31 '''Run a command as a service.'''
@@ -87,8 +91,8 b' def runservice(opts, parentfn=None, init'
87 raise error.Abort(_('invalid value for --daemon-postexec: %s')
91 raise error.Abort(_('invalid value for --daemon-postexec: %s')
88 % inst)
92 % inst)
89 util.hidewindow()
93 util.hidewindow()
90 util.stdout.flush()
94 procutil.stdout.flush()
91 util.stderr.flush()
95 procutil.stderr.flush()
92
96
93 nullfd = os.open(os.devnull, os.O_RDWR)
97 nullfd = os.open(os.devnull, os.O_RDWR)
94 logfilefd = nullfd
98 logfilefd = nullfd
@@ -39,6 +39,7 b' from . import ('
39 )
39 )
40 from .utils import (
40 from .utils import (
41 dateutil,
41 dateutil,
42 procutil,
42 stringutil,
43 stringutil,
43 )
44 )
44
45
@@ -250,9 +251,9 b' class ui(object):'
250 self.httppasswordmgrdb = src.httppasswordmgrdb
251 self.httppasswordmgrdb = src.httppasswordmgrdb
251 self._blockedtimes = src._blockedtimes
252 self._blockedtimes = src._blockedtimes
252 else:
253 else:
253 self.fout = util.stdout
254 self.fout = procutil.stdout
254 self.ferr = util.stderr
255 self.ferr = procutil.stderr
255 self.fin = util.stdin
256 self.fin = procutil.stdin
256 self.pageractive = False
257 self.pageractive = False
257 self._disablepager = False
258 self._disablepager = False
258 self._tweaked = False
259 self._tweaked = False
@@ -1099,7 +1100,7 b' class ui(object):'
1099 pager = subprocess.Popen(
1100 pager = subprocess.Popen(
1100 command, shell=shell, bufsize=-1,
1101 command, shell=shell, bufsize=-1,
1101 close_fds=util.closefds, stdin=subprocess.PIPE,
1102 close_fds=util.closefds, stdin=subprocess.PIPE,
1102 stdout=util.stdout, stderr=util.stderr,
1103 stdout=procutil.stdout, stderr=procutil.stderr,
1103 env=util.shellenviron(env))
1104 env=util.shellenviron(env))
1104 except OSError as e:
1105 except OSError as e:
1105 if e.errno == errno.ENOENT and not shell:
1106 if e.errno == errno.ENOENT and not shell:
@@ -1109,20 +1110,20 b' class ui(object):'
1109 raise
1110 raise
1110
1111
1111 # back up original file descriptors
1112 # back up original file descriptors
1112 stdoutfd = os.dup(util.stdout.fileno())
1113 stdoutfd = os.dup(procutil.stdout.fileno())
1113 stderrfd = os.dup(util.stderr.fileno())
1114 stderrfd = os.dup(procutil.stderr.fileno())
1114
1115
1115 os.dup2(pager.stdin.fileno(), util.stdout.fileno())
1116 os.dup2(pager.stdin.fileno(), procutil.stdout.fileno())
1116 if self._isatty(util.stderr):
1117 if self._isatty(procutil.stderr):
1117 os.dup2(pager.stdin.fileno(), util.stderr.fileno())
1118 os.dup2(pager.stdin.fileno(), procutil.stderr.fileno())
1118
1119
1119 @self.atexit
1120 @self.atexit
1120 def killpager():
1121 def killpager():
1121 if util.safehasattr(signal, "SIGINT"):
1122 if util.safehasattr(signal, "SIGINT"):
1122 signal.signal(signal.SIGINT, signal.SIG_IGN)
1123 signal.signal(signal.SIGINT, signal.SIG_IGN)
1123 # restore original fds, closing pager.stdin copies in the process
1124 # restore original fds, closing pager.stdin copies in the process
1124 os.dup2(stdoutfd, util.stdout.fileno())
1125 os.dup2(stdoutfd, procutil.stdout.fileno())
1125 os.dup2(stderrfd, util.stderr.fileno())
1126 os.dup2(stderrfd, procutil.stderr.fileno())
1126 pager.stdin.close()
1127 pager.stdin.close()
1127 pager.wait()
1128 pager.wait()
1128
1129
@@ -35,6 +35,7 b' from . import ('
35 )
35 )
36
36
37 from .utils import (
37 from .utils import (
38 procutil,
38 stringutil,
39 stringutil,
39 )
40 )
40
41
@@ -519,7 +520,7 b' def options(cmd, keys, others):'
519 opts[k] = others[k]
520 opts[k] = others[k]
520 del others[k]
521 del others[k]
521 if others:
522 if others:
522 util.stderr.write("warning: %s ignored unexpected arguments %s\n"
523 procutil.stderr.write("warning: %s ignored unexpected arguments %s\n"
523 % (cmd, ",".join(others)))
524 % (cmd, ",".join(others)))
524 return opts
525 return opts
525
526
@@ -1081,14 +1082,14 b' def unbundle(repo, proto, heads):'
1081 try:
1082 try:
1082 raise
1083 raise
1083 except error.Abort:
1084 except error.Abort:
1084 # The old code we moved used util.stderr directly.
1085 # The old code we moved used procutil.stderr directly.
1085 # We did not change it to minimise code change.
1086 # We did not change it to minimise code change.
1086 # This need to be moved to something proper.
1087 # This need to be moved to something proper.
1087 # Feel free to do it.
1088 # Feel free to do it.
1088 util.stderr.write("abort: %s\n" % exc)
1089 procutil.stderr.write("abort: %s\n" % exc)
1089 if exc.hint is not None:
1090 if exc.hint is not None:
1090 util.stderr.write("(%s)\n" % exc.hint)
1091 procutil.stderr.write("(%s)\n" % exc.hint)
1091 util.stderr.flush()
1092 procutil.stderr.flush()
1092 return pushres(0, output.getvalue() if output else '')
1093 return pushres(0, output.getvalue() if output else '')
1093 except error.PushRaced:
1094 except error.PushRaced:
1094 return pusherr(pycompat.bytestr(exc),
1095 return pusherr(pycompat.bytestr(exc),
@@ -900,7 +900,9 b' This tests that translated help message '
900 > from __future__ import absolute_import
900 > from __future__ import absolute_import
901 > from mercurial import (
901 > from mercurial import (
902 > pycompat,
902 > pycompat,
903 > util,
903 > )
904 > from mercurial.utils import (
905 > procutil,
904 > )
906 > )
905 > def escape(c):
907 > def escape(c):
906 > o = ord(c)
908 > o = ord(c)
@@ -908,8 +910,9 b' This tests that translated help message '
908 > return c
910 > return c
909 > else:
911 > else:
910 > return br'\x%02x' % o # escape char setting MSB
912 > return br'\x%02x' % o # escape char setting MSB
911 > for l in util.stdin:
913 > for l in procutil.stdin:
912 > util.stdout.write(b''.join(escape(c) for c in pycompat.iterbytestr(l)))
914 > procutil.stdout.write(
915 > b''.join(escape(c) for c in pycompat.iterbytestr(l)))
913 > EOF
916 > EOF
914
917
915 $ hg commit -i --encoding cp932 2>&1 <<EOF | $PYTHON $TESTTMP/escape.py | grep '^y - '
918 $ hg commit -i --encoding cp932 2>&1 <<EOF | $PYTHON $TESTTMP/escape.py | grep '^y - '
@@ -11,6 +11,10 b' from mercurial import ('
11 util,
11 util,
12 )
12 )
13
13
14 from mercurial.utils import (
15 procutil,
16 )
17
14 testtmp = encoding.environ[b'TESTTMP']
18 testtmp = encoding.environ[b'TESTTMP']
15
19
16 # prepare hgrc files
20 # prepare hgrc files
@@ -41,9 +45,9 b' def printconfigs(env):'
41 ui = uimod.ui.load()
45 ui = uimod.ui.load()
42 for section, name, value in ui.walkconfig():
46 for section, name, value in ui.walkconfig():
43 source = ui.configsource(section, name)
47 source = ui.configsource(section, name)
44 util.stdout.write(b'%s.%s=%s # %s\n'
48 procutil.stdout.write(b'%s.%s=%s # %s\n'
45 % (section, name, value, util.pconvert(source)))
49 % (section, name, value, util.pconvert(source)))
46 util.stdout.write(b'\n')
50 procutil.stdout.write(b'\n')
47
51
48 # environment variable overrides
52 # environment variable overrides
49 printconfigs({})
53 printconfigs({})
General Comments 0
You need to be logged in to leave comments. Login now