Commit 937ff1db authored by Andrew Svetlov's avatar Andrew Svetlov

Issue #14200 — now displayhook for IDLE works in non-subprocess mode as well as subprecess.

parent 5b032f41
...@@ -999,6 +999,8 @@ class PyShell(OutputWindow): ...@@ -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 ...@@ -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): ...@@ -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 ...@@ -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): ...@@ -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): ...@@ -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
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment