summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--Lib/idlelib/ScriptBinding.py4
-rw-r--r--Lib/idlelib/run.py14
2 files changed, 14 insertions, 4 deletions
diff --git a/Lib/idlelib/ScriptBinding.py b/Lib/idlelib/ScriptBinding.py
index 68f9cd7..6d4c652 100644
--- a/Lib/idlelib/ScriptBinding.py
+++ b/Lib/idlelib/ScriptBinding.py
@@ -144,10 +144,11 @@ class ScriptBinding:
filename = self.getfilename()
if not filename:
return
-
flist = self.editwin.flist
shell = flist.open_shell()
interp = shell.interp
+ # clear the subprocess environment before every Run/F5 invocation
+ interp.rpcclt.remotecall("exec", "clear_the_environment", (), {})
# XXX Too often this discards arguments the user just set...
interp.runcommand("""if 1:
_filename = %s
@@ -155,6 +156,7 @@ class ScriptBinding:
from os.path import basename as _basename
if (not _sys.argv or
_basename(_sys.argv[0]) != _basename(_filename)):
+ # XXX 25 July 2002 KBK should this be sys.argv not _sys.argv?
_sys.argv = [_filename]
del _filename, _sys, _basename
\n""" % `filename`)
diff --git a/Lib/idlelib/run.py b/Lib/idlelib/run.py
index 5db652e..cc3edf1 100644
--- a/Lib/idlelib/run.py
+++ b/Lib/idlelib/run.py
@@ -1,6 +1,7 @@
import sys
import time
import socket
+import __main__
import rpc
def main():
@@ -55,11 +56,18 @@ class Executive:
def __init__(self, rpchandler):
self.rpchandler = rpchandler
- import __main__
- self.locals = __main__.__dict__
+ self.base_env_keys = __main__.__dict__.keys()
def runcode(self, code):
- exec code in self.locals
+ exec code in __main__.__dict__
+
+ def clear_the_environment(self):
+ global __main__
+ env = __main__.__dict__
+ for key in env.keys():
+ if key not in self.base_env_keys:
+ del env[key]
+ env['__doc__'] = None
def start_the_debugger(self, gui_adap_oid):
import RemoteDebugger