From 1ba32187c0737b3b8ae63b9ea215be7c2d423e6d Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Martin=20v=2E=20L=C3=B6wis?= Date: Wed, 11 Jul 2012 08:49:58 +0200 Subject: [PATCH] Don't use TextIOBase implementations in _RPCFile. --- Lib/idlelib/run.py | 10 ++++++++-- 1 file changed, 8 insertions(+), 2 deletions(-) diff --git a/Lib/idlelib/run.py b/Lib/idlelib/run.py index c1b974a5e22..831235de858 100644 --- a/Lib/idlelib/run.py +++ b/Lib/idlelib/run.py @@ -251,12 +251,18 @@ class MyRPCServer(rpc.RPCServer): class _RPCFile(io.TextIOBase): """Wrapper class for the RPC proxy to typecheck arguments - that may not support pickling.""" + that may not support pickling. The base class is there only + to support type tests; all implementations come from the remote + object.""" def __init__(self, rpc): super.__setattr__(self, 'rpc', rpc) - def __getattr__(self, name): + def __getattribute__(self, name): + # When accessing the 'rpc' attribute, use ours + if name == 'rpc': + return io.TextIOBase.__getattribute__(self, name) + # Else only look into the remote object only return getattr(self.rpc, name) def __setattr__(self, name, value):