mirror of https://github.com/python/cpython.git
Added a "run with commandline Python" flag. Works in MachoPython, should work
in OSX MacPython (untested), and should be disabled/removed in OS9 (but that doesn't happen yet).
This commit is contained in:
parent
767f83539d
commit
ff773eba36
|
@ -110,14 +110,9 @@ def __init__(self, path = "", title = ""):
|
|||
self._buf = "" # for write method
|
||||
self.debugging = 0
|
||||
self.profiling = 0
|
||||
if self.settings.has_key("run_as_main"):
|
||||
self.run_as_main = self.settings["run_as_main"]
|
||||
else:
|
||||
self.run_as_main = 0
|
||||
if self.settings.has_key("run_with_interpreter"):
|
||||
self.run_with_interpreter = self.settings["run_with_interpreter"]
|
||||
else:
|
||||
self.run_with_interpreter = 0
|
||||
self.run_as_main = self.settings.get("run_as_main", 0)
|
||||
self.run_with_interpreter = self.settings.get("run_with_interpreter", 0)
|
||||
self.run_with_cl_interpreter = self.settings.get("run_with_cl_interpreter", 0)
|
||||
self._threadstate = (0, 0)
|
||||
self._thread = None
|
||||
|
||||
|
@ -161,6 +156,7 @@ def getsettings(self):
|
|||
self.settings["tabsize"] = self.editgroup.editor.gettabsettings()
|
||||
self.settings["run_as_main"] = self.run_as_main
|
||||
self.settings["run_with_interpreter"] = self.run_with_interpreter
|
||||
self.settings["run_with_cl_interpreter"] = self.run_with_cl_interpreter
|
||||
|
||||
def get(self):
|
||||
return self.editgroup.editor.get()
|
||||
|
@ -230,8 +226,9 @@ def makeoptionsmenu(self):
|
|||
("Save options\xc9", self.domenu_options),
|
||||
'-',
|
||||
('\0' + chr(self.run_as_main) + 'Run as __main__', self.domenu_toggle_run_as_main),
|
||||
#('\0' + chr(self.run_with_interpreter) + 'Run with Interpreter', self.domenu_toggle_run_with_interpreter),
|
||||
#'-',
|
||||
#('\0' + chr(self.run_with_interpreter) + 'Run with Interpreter', self.domenu_dtoggle_run_with_interpreter),
|
||||
('\0' + chr(self.run_with_cl_interpreter) + 'Run with commandline Python', self.domenu_toggle_run_with_cl_interpreter),
|
||||
'-',
|
||||
('Modularize', self.domenu_modularize),
|
||||
('Browse namespace\xc9', self.domenu_browsenamespace),
|
||||
'-']
|
||||
|
@ -250,11 +247,19 @@ def makeoptionsmenu(self):
|
|||
def domenu_toggle_run_as_main(self):
|
||||
self.run_as_main = not self.run_as_main
|
||||
self.run_with_interpreter = 0
|
||||
self.run_with_cl_interpreter = 0
|
||||
self.editgroup.editor.selectionchanged()
|
||||
|
||||
def domenu_toggle_run_with_interpreter(self):
|
||||
def XXdomenu_toggle_run_with_interpreter(self):
|
||||
self.run_with_interpreter = not self.run_with_interpreter
|
||||
self.run_as_main = 0
|
||||
self.run_with_cl_interpreter = 0
|
||||
self.editgroup.editor.selectionchanged()
|
||||
|
||||
def domenu_toggle_run_with_cl_interpreter(self):
|
||||
self.run_with_cl_interpreter = not self.run_with_cl_interpreter
|
||||
self.run_as_main = 0
|
||||
self.run_with_interpreter = 0
|
||||
self.editgroup.editor.selectionchanged()
|
||||
|
||||
def showbreakpoints(self, onoff):
|
||||
|
@ -514,6 +519,26 @@ def _run(self):
|
|||
if not self.path:
|
||||
raise W.AlertError, "Can't run unsaved file"
|
||||
self._run_with_interpreter()
|
||||
elif self.run_with_cl_interpreter:
|
||||
# Until universal newline support
|
||||
if self._eoln != '\n':
|
||||
import EasyDialogs
|
||||
ok = EasyDialogs.AskYesNoCancel('Warning: "%s" does not have Unix line-endings'
|
||||
% self.title, 1, yes='OK', no='')
|
||||
if not ok:
|
||||
return
|
||||
if self.editgroup.editor.changed:
|
||||
import EasyDialogs
|
||||
import Qd; Qd.InitCursor()
|
||||
save = EasyDialogs.AskYesNoCancel('Save "%s" before running?' % self.title, 1)
|
||||
if save > 0:
|
||||
if self.domenu_save():
|
||||
return
|
||||
elif save < 0:
|
||||
return
|
||||
if not self.path:
|
||||
raise W.AlertError, "Can't run unsaved file"
|
||||
self._run_with_cl_interpreter()
|
||||
else:
|
||||
pytext = self.editgroup.editor.get()
|
||||
globals, file, modname = self.getenvironment()
|
||||
|
@ -526,6 +551,23 @@ def _run_with_interpreter(self):
|
|||
import findertools
|
||||
XXX
|
||||
|
||||
def _run_with_cl_interpreter(self):
|
||||
import Terminal
|
||||
interp_path = os.path.join(sys.exec_prefix, "bin", "python")
|
||||
file_path = self.path
|
||||
if not os.path.exists(interp_path):
|
||||
# This "can happen" if we are running IDE under MacPython. Try
|
||||
# the standard location.
|
||||
interp_path = "/Library/Frameworks/Python.framework/Versions/2.3/bin/python"
|
||||
try:
|
||||
fsr = macfs.FSRef(interp_path)
|
||||
except macfs.Error:
|
||||
raise W.AlertError, "Can't find command-line Python"
|
||||
file_path = macfs.FSRef(macfs.FSSpec(self.path)).as_pathname()
|
||||
cmd = '"%s" "%s" ; exit' % (interp_path, file_path)
|
||||
t = Terminal.Terminal()
|
||||
t.do_script(with_command=cmd)
|
||||
|
||||
def runselection(self):
|
||||
if self._threadstate == (0, 0):
|
||||
self._runselection()
|
||||
|
@ -537,7 +579,7 @@ def runselection(self):
|
|||
self.setthreadstate((1, 1))
|
||||
|
||||
def _runselection(self):
|
||||
if self.run_with_interpreter:
|
||||
if self.run_with_interpreter or self.run_with_cl_interpreter:
|
||||
raise W.AlertError, "Can't run selection with Interpreter"
|
||||
globals, file, modname = self.getenvironment()
|
||||
locals = globals
|
||||
|
|
Loading…
Reference in New Issue