mirror of
				https://github.com/python/cpython.git
				synced 2025-11-04 03:44:55 +00:00 
			
		
		
		
	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
					
				
					 1 changed files with 54 additions and 12 deletions
				
			
		| 
						 | 
					@ -110,14 +110,9 @@ class Editor(W.Window):
 | 
				
			||||||
		self._buf = ""  # for write method
 | 
							self._buf = ""  # for write method
 | 
				
			||||||
		self.debugging = 0
 | 
							self.debugging = 0
 | 
				
			||||||
		self.profiling = 0
 | 
							self.profiling = 0
 | 
				
			||||||
		if self.settings.has_key("run_as_main"):
 | 
							self.run_as_main = self.settings.get("run_as_main", 0)
 | 
				
			||||||
			self.run_as_main = self.settings["run_as_main"]
 | 
							self.run_with_interpreter = self.settings.get("run_with_interpreter", 0)
 | 
				
			||||||
		else:
 | 
							self.run_with_cl_interpreter = self.settings.get("run_with_cl_interpreter", 0)
 | 
				
			||||||
			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._threadstate = (0, 0)
 | 
							self._threadstate = (0, 0)
 | 
				
			||||||
		self._thread = None
 | 
							self._thread = None
 | 
				
			||||||
	
 | 
						
 | 
				
			||||||
| 
						 | 
					@ -161,6 +156,7 @@ class Editor(W.Window):
 | 
				
			||||||
		self.settings["tabsize"] = self.editgroup.editor.gettabsettings()
 | 
							self.settings["tabsize"] = self.editgroup.editor.gettabsettings()
 | 
				
			||||||
		self.settings["run_as_main"] = self.run_as_main
 | 
							self.settings["run_as_main"] = self.run_as_main
 | 
				
			||||||
		self.settings["run_with_interpreter"] = self.run_with_interpreter
 | 
							self.settings["run_with_interpreter"] = self.run_with_interpreter
 | 
				
			||||||
 | 
							self.settings["run_with_cl_interpreter"] = self.run_with_cl_interpreter
 | 
				
			||||||
	
 | 
						
 | 
				
			||||||
	def get(self):
 | 
						def get(self):
 | 
				
			||||||
		return self.editgroup.editor.get()
 | 
							return self.editgroup.editor.get()
 | 
				
			||||||
| 
						 | 
					@ -230,8 +226,9 @@ class Editor(W.Window):
 | 
				
			||||||
				("Save options\xc9", self.domenu_options),
 | 
									("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_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),
 | 
									('Modularize', self.domenu_modularize),
 | 
				
			||||||
				('Browse namespace\xc9', self.domenu_browsenamespace), 
 | 
									('Browse namespace\xc9', self.domenu_browsenamespace), 
 | 
				
			||||||
				'-']
 | 
									'-']
 | 
				
			||||||
| 
						 | 
					@ -250,11 +247,19 @@ class Editor(W.Window):
 | 
				
			||||||
	def domenu_toggle_run_as_main(self):
 | 
						def domenu_toggle_run_as_main(self):
 | 
				
			||||||
		self.run_as_main = not self.run_as_main
 | 
							self.run_as_main = not self.run_as_main
 | 
				
			||||||
		self.run_with_interpreter = 0
 | 
							self.run_with_interpreter = 0
 | 
				
			||||||
 | 
							self.run_with_cl_interpreter = 0
 | 
				
			||||||
		self.editgroup.editor.selectionchanged()
 | 
							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_with_interpreter = not self.run_with_interpreter
 | 
				
			||||||
		self.run_as_main = 0
 | 
							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()
 | 
							self.editgroup.editor.selectionchanged()
 | 
				
			||||||
	
 | 
						
 | 
				
			||||||
	def showbreakpoints(self, onoff):
 | 
						def showbreakpoints(self, onoff):
 | 
				
			||||||
| 
						 | 
					@ -514,6 +519,26 @@ class Editor(W.Window):
 | 
				
			||||||
			if not self.path:
 | 
								if not self.path:
 | 
				
			||||||
				raise W.AlertError, "Can't run unsaved file"
 | 
									raise W.AlertError, "Can't run unsaved file"
 | 
				
			||||||
			self._run_with_interpreter()
 | 
								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:
 | 
							else:
 | 
				
			||||||
			pytext = self.editgroup.editor.get()
 | 
								pytext = self.editgroup.editor.get()
 | 
				
			||||||
			globals, file, modname = self.getenvironment()
 | 
								globals, file, modname = self.getenvironment()
 | 
				
			||||||
| 
						 | 
					@ -526,6 +551,23 @@ class Editor(W.Window):
 | 
				
			||||||
		import findertools
 | 
							import findertools
 | 
				
			||||||
		XXX
 | 
							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):
 | 
						def runselection(self):
 | 
				
			||||||
		if self._threadstate == (0, 0):
 | 
							if self._threadstate == (0, 0):
 | 
				
			||||||
			self._runselection()
 | 
								self._runselection()
 | 
				
			||||||
| 
						 | 
					@ -537,7 +579,7 @@ class Editor(W.Window):
 | 
				
			||||||
			self.setthreadstate((1, 1))
 | 
								self.setthreadstate((1, 1))
 | 
				
			||||||
	
 | 
						
 | 
				
			||||||
	def _runselection(self):
 | 
						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"
 | 
								raise W.AlertError, "Can't run selection with Interpreter"
 | 
				
			||||||
		globals, file, modname = self.getenvironment()
 | 
							globals, file, modname = self.getenvironment()
 | 
				
			||||||
		locals = globals
 | 
							locals = globals
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue