diff options
author | Martin v. Löwis <martin@v.loewis.de> | 2012-07-09 18:48:56 (GMT) |
---|---|---|
committer | Martin v. Löwis <martin@v.loewis.de> | 2012-07-09 18:48:56 (GMT) |
commit | 79007fa05d1a4bb0553244b362f2ca378e0b331a (patch) | |
tree | 4538005758aecbac06cd8684e7013de404390912 /Lib/idlelib/run.py | |
parent | 3adc7b75a5f35003b3b91de113b5212748dc1a1d (diff) | |
parent | 9ae3f7a189e3d05bf14835e9e2b8aff77661c1ba (diff) | |
download | cpython-79007fa05d1a4bb0553244b362f2ca378e0b331a.zip cpython-79007fa05d1a4bb0553244b362f2ca378e0b331a.tar.gz cpython-79007fa05d1a4bb0553244b362f2ca378e0b331a.tar.bz2 |
merge 3.2
Diffstat (limited to 'Lib/idlelib/run.py')
-rw-r--r-- | Lib/idlelib/run.py | 24 |
1 files changed, 21 insertions, 3 deletions
diff --git a/Lib/idlelib/run.py b/Lib/idlelib/run.py index 7124c72..6c91ae4 100644 --- a/Lib/idlelib/run.py +++ b/Lib/idlelib/run.py @@ -1,4 +1,5 @@ import sys +import io import linecache import time import socket @@ -257,6 +258,23 @@ class MyRPCServer(rpc.RPCServer): quitting = True thread.interrupt_main() +class _RPCFile(io.TextIOBase): + """Wrapper class for the RPC proxy to typecheck arguments + that may not support pickling.""" + + def __init__(self, rpc): + super.__setattr__(self, 'rpc', rpc) + + def __getattr__(self, name): + return getattr(self.rpc, name) + + def __setattr__(self, name, value): + return setattr(self.rpc, name, value) + + def write(self, s): + if not isinstance(s, str): + raise TypeError('must be str, not ' + type(s).__name__) + return self.rpc.write(s) class MyHandler(rpc.RPCHandler): @@ -264,9 +282,9 @@ class MyHandler(rpc.RPCHandler): """Override base method""" executive = Executive(self) self.register("exec", executive) - sys.stdin = self.console = self.get_remote_proxy("stdin") - sys.stdout = self.get_remote_proxy("stdout") - sys.stderr = self.get_remote_proxy("stderr") + sys.stdin = self.console = _RPCFile(self.get_remote_proxy("stdin")) + sys.stdout = _RPCFile(self.get_remote_proxy("stdout")) + sys.stderr = _RPCFile(self.get_remote_proxy("stderr")) sys.displayhook = rpc.displayhook # page help() text to shell. import pydoc # import must be done here to capture i/o binding |