mirror of
https://github.com/python/cpython.git
synced 2025-11-25 12:44:13 +00:00
Issue #14200 — now displayhook for IDLE works in non-subprocess mode as well as subprecess.
This commit is contained in:
parent
1a7742eb4d
commit
cd49d53238
3 changed files with 22 additions and 21 deletions
|
|
@ -999,6 +999,8 @@ class PyShell(OutputWindow):
|
||||||
return False
|
return False
|
||||||
else:
|
else:
|
||||||
nosub = "==== No Subprocess ===="
|
nosub = "==== No Subprocess ===="
|
||||||
|
sys.displayhook = rpc.displayhook
|
||||||
|
|
||||||
self.write("Python %s on %s\n%s\n%s" %
|
self.write("Python %s on %s\n%s\n%s" %
|
||||||
(sys.version, sys.platform, self.COPYRIGHT, nosub))
|
(sys.version, sys.platform, self.COPYRIGHT, nosub))
|
||||||
self.showprompt()
|
self.showprompt()
|
||||||
|
|
|
||||||
|
|
@ -40,6 +40,7 @@ import traceback
|
||||||
import copyreg
|
import copyreg
|
||||||
import types
|
import types
|
||||||
import marshal
|
import marshal
|
||||||
|
import builtins
|
||||||
|
|
||||||
|
|
||||||
def unpickle_code(ms):
|
def unpickle_code(ms):
|
||||||
|
|
@ -603,3 +604,21 @@ class MethodProxy(object):
|
||||||
|
|
||||||
# XXX KBK 09Sep03 We need a proper unit test for this module. Previously
|
# XXX KBK 09Sep03 We need a proper unit test for this module. Previously
|
||||||
# existing test code was removed at Rev 1.27 (r34098).
|
# existing test code was removed at Rev 1.27 (r34098).
|
||||||
|
|
||||||
|
def displayhook(value):
|
||||||
|
"""Override standard display hook to use non-locale encoding"""
|
||||||
|
if value is None:
|
||||||
|
return
|
||||||
|
# Set '_' to None to avoid recursion
|
||||||
|
builtins._ = None
|
||||||
|
text = repr(value)
|
||||||
|
try:
|
||||||
|
sys.stdout.write(text)
|
||||||
|
except UnicodeEncodeError:
|
||||||
|
# let's use ascii while utf8-bmp codec doesn't present
|
||||||
|
encoding = 'ascii'
|
||||||
|
bytes = text.encode(encoding, 'backslashreplace')
|
||||||
|
text = bytes.decode(encoding, 'strict')
|
||||||
|
sys.stdout.write(text)
|
||||||
|
sys.stdout.write("\n")
|
||||||
|
builtins._ = value
|
||||||
|
|
|
||||||
|
|
@ -6,7 +6,6 @@ import traceback
|
||||||
import _thread as thread
|
import _thread as thread
|
||||||
import threading
|
import threading
|
||||||
import queue
|
import queue
|
||||||
import builtins
|
|
||||||
|
|
||||||
from idlelib import CallTips
|
from idlelib import CallTips
|
||||||
from idlelib import AutoComplete
|
from idlelib import AutoComplete
|
||||||
|
|
@ -262,25 +261,6 @@ class MyRPCServer(rpc.RPCServer):
|
||||||
thread.interrupt_main()
|
thread.interrupt_main()
|
||||||
|
|
||||||
|
|
||||||
def displayhook(value):
|
|
||||||
"""Override standard display hook to use non-locale encoding"""
|
|
||||||
if value is None:
|
|
||||||
return
|
|
||||||
# Set '_' to None to avoid recursion
|
|
||||||
builtins._ = None
|
|
||||||
text = repr(value)
|
|
||||||
try:
|
|
||||||
sys.stdout.write(text)
|
|
||||||
except UnicodeEncodeError:
|
|
||||||
# let's use ascii while utf8-bmp codec doesn't present
|
|
||||||
encoding = 'ascii'
|
|
||||||
bytes = text.encode(encoding, 'backslashreplace')
|
|
||||||
text = bytes.decode(encoding, 'strict')
|
|
||||||
sys.stdout.write(text)
|
|
||||||
sys.stdout.write("\n")
|
|
||||||
builtins._ = value
|
|
||||||
|
|
||||||
|
|
||||||
class MyHandler(rpc.RPCHandler):
|
class MyHandler(rpc.RPCHandler):
|
||||||
|
|
||||||
def handle(self):
|
def handle(self):
|
||||||
|
|
@ -290,7 +270,7 @@ class MyHandler(rpc.RPCHandler):
|
||||||
sys.stdin = self.console = self.get_remote_proxy("stdin")
|
sys.stdin = self.console = self.get_remote_proxy("stdin")
|
||||||
sys.stdout = self.get_remote_proxy("stdout")
|
sys.stdout = self.get_remote_proxy("stdout")
|
||||||
sys.stderr = self.get_remote_proxy("stderr")
|
sys.stderr = self.get_remote_proxy("stderr")
|
||||||
sys.displayhook = displayhook
|
sys.displayhook = rpc.displayhook
|
||||||
# page help() text to shell.
|
# page help() text to shell.
|
||||||
import pydoc # import must be done here to capture i/o binding
|
import pydoc # import must be done here to capture i/o binding
|
||||||
pydoc.pager = pydoc.plainpager
|
pydoc.pager = pydoc.plainpager
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue