diff options
author | Guido van Rossum <guido@python.org> | 1996-06-28 17:28:51 (GMT) |
---|---|---|
committer | Guido van Rossum <guido@python.org> | 1996-06-28 17:28:51 (GMT) |
commit | cd6aab91a5fb9607ba8b731f906c5738a2409384 (patch) | |
tree | 38513c8c9ad8182fc81a18d4b5b70413d7233155 /Lib/rexec.py | |
parent | 7d844a7c8a865f534d8c5bfb2b2fdc2c2e0d9dd6 (diff) | |
download | cpython-cd6aab91a5fb9607ba8b731f906c5738a2409384.zip cpython-cd6aab91a5fb9607ba8b731f906c5738a2409384.tar.gz cpython-cd6aab91a5fb9607ba8b731f906c5738a2409384.tar.bz2 |
Fixed restore_files(); added reset_files(); made these more flexible.
Diffstat (limited to 'Lib/rexec.py')
-rw-r--r-- | Lib/rexec.py | 39 |
1 files changed, 31 insertions, 8 deletions
diff --git a/Lib/rexec.py b/Lib/rexec.py index b4ec0f2..3f34153 100644 --- a/Lib/rexec.py +++ b/Lib/rexec.py @@ -33,6 +33,8 @@ class FileBase: class FileWrapper(FileBase): + # XXX This is just like a Bastion -- should use that! + def __init__(self, f): self.f = f for m in self.ok_file_methods: @@ -278,22 +280,43 @@ class RExec(ihooks._Verbose): # The s_* methods are similar but also swap std{in,out,err} + def make_delegate_files(self): + s = self.modules['sys'] + self.delegate_stdin = FileDelegate(s, 'stdin') + self.delegate_stdout = FileDelegate(s, 'stdout') + self.delegate_stderr = FileDelegate(s, 'stderr') + self.restricted_stdin = FileWrapper(sys.stdin) + self.restricted_stdout = FileWrapper(sys.stdout) + self.restricted_stderr = FileWrapper(sys.stderr) + def set_files(self): + if not hasattr(self, 'save_stdin'): + self.save_files() + if not hasattr(self, 'delegate_stdin'): + self.make_delegate_files() s = self.modules['sys'] - s.stdin = FileWrapper(sys.stdin) - s.stdout = FileWrapper(sys.stdout) - s.stderr = FileWrapper(sys.stderr) - sys.stdin = FileDelegate(s, 'stdin') - sys.stdout = FileDelegate(s, 'stdout') - sys.stderr = FileDelegate(s, 'stderr') + s.stdin = self.restricted_stdin + s.stdout = self.restricted_stdout + s.stderr = self.restricted_stdout + sys.stdin = self.delegate_stdin + sys.stdout = self.delegate_stdout + sys.stderr = self.delegate_stderr + + def reset_files(self): + self.restore_files() + s = self.modules['sys'] + self.restricted_stdin = s.stdin + self.restricted_stdout = s.stdout + self.restricted_stdout = s.stderr + def save_files(self): self.save_stdin = sys.stdin self.save_stdout = sys.stdout self.save_stderr = sys.stderr - def restore_files(files): - sys.stdin = self.save_sydin + def restore_files(self): + sys.stdin = self.save_stdin sys.stdout = self.save_stdout sys.stderr = self.save_stderr |