Patch by Mark Day to allow from __future__ imports. Looks harmless
enough, but may have side-effects because it preallocates a single
codeop.Compiler() to compile all statements the user enters.
Just: please review and retract/modify if necessary.
diff --git a/Mac/Tools/IDE/PyInteractive.py b/Mac/Tools/IDE/PyInteractive.py
index dc75e4b..3ad02c5 100644
--- a/Mac/Tools/IDE/PyInteractive.py
+++ b/Mac/Tools/IDE/PyInteractive.py
@@ -36,7 +36,9 @@
class PyInteractive:
def __init__(self):
+ import codeop
self._pybuf = ""
+ self._compile = codeop.Compile()
def executeline(self, stuff, out = None, env = None):
if env is None:
@@ -72,7 +74,7 @@
return
try:
- code = compile(self._pybuf, "<input>", "single")
+ code = self._compile(self._pybuf, "<input>", "single")
except SyntaxError, err:
pass
except:
@@ -84,12 +86,12 @@
return
try:
- code1 = compile(self._pybuf + "\n", "<input>", "single")
+ code1 = self._compile(self._pybuf + "\n", "<input>", "single")
except SyntaxError, err1:
pass
try:
- code2 = compile(self._pybuf + "\n\n", "<input>", "single")
+ code2 = self._compile(self._pybuf + "\n\n", "<input>", "single")
except SyntaxError, err2:
pass