]>
git.saurik.com Git - wxWidgets.git/blob - wxPython/wxPython/lib/PyCrust/interpreter.py
3474fe2885a11adfc0de1d07031c6969f451f31f
   1 """PyCrust Interpreter executes Python commands.""" 
   3 __author__ 
= "Patrick K. O'Brien <pobrien@orbtech.com>" 
   5 __date__ 
= "July 1, 2001" 
   6 __version__ 
= "$Revision$"[11:-2] 
  10 from code 
import InteractiveInterpreter
 
  14 class Interpreter(InteractiveInterpreter
): 
  15     """PyCrust Interpreter based on code.InteractiveInterpreter.""" 
  17     revision 
= __version__
 
  19     def __init__(self
, locals=None, rawin
=None, \
 
  20                  stdin
=sys
.stdin
, stdout
=sys
.stdout
, stderr
=sys
.stderr
): 
  21         """Create an interactive interpreter object.""" 
  22         InteractiveInterpreter
.__init
__(self
, locals=locals) 
  28             __builtin__
.raw_input = rawin
 
  31             'Type "copyright", "credits" or "license" for more information.' 
  32         self
.introText 
= 'Python %s on %s%s%s' % \
 
  33                          (sys
.version
, sys
.platform
, os
.linesep
, copyright
) 
  36         except AttributeError: 
  40         except AttributeError: 
  43         # List of lists to support recursive push(). 
  44         self
.commandBuffer 
= [] 
  45         self
.startupScript 
= os
.environ
.get('PYTHONSTARTUP') 
  47     def push(self
, command
): 
  48         """Send command to the interpreter to be executed. 
  50         Because this may be called recursively, we append a new list 
  51         onto the commandBuffer list and then append commands into 
  52         that. If the passed in command is part of a multi-line command 
  53         we keep appending the pieces to the last list in commandBuffer 
  54         until we have a complete command, then, finally, we delete 
  56         if not self
.more
: self
.commandBuffer
.append([]) 
  57         self
.commandBuffer
[-1].append(command
) 
  58         source 
= '\n'.join(self
.commandBuffer
[-1]) 
  59         self
.more 
= self
.runsource(source
) 
  60         if not self
.more
: del self
.commandBuffer
[-1] 
  63     def runsource(self
, source
): 
  64         """Compile and run source code in the interpreter.""" 
  65         stdin
, stdout
, stderr 
= sys
.stdin
, sys
.stdout
, sys
.stderr
 
  66         sys
.stdin 
= self
.stdin
 
  67         sys
.stdout 
= self
.stdout
 
  68         sys
.stderr 
= self
.stderr
 
  69         more 
= InteractiveInterpreter
.runsource(self
, source
) 
  70         # If sys.std* is still what we set it to, then restore it. 
  71         # But, if the executed source changed sys.std*, assume it 
  72         # was meant to be changed and leave it. Power to the people. 
  73         if sys
.stdin 
== self
.stdin
: 
  75         if sys
.stdout 
== self
.stdout
: 
  77         if sys
.stderr 
== self
.stderr
: 
  81     def getAutoCompleteList(self
, command
='', *args
, **kwds
): 
  82         """Return list of auto-completion options for a command. 
  84         The list of options will be based on the locals namespace.""" 
  85         return introspect
.getAutoCompleteList(command
, self
.locals, *args
, **kwds
) 
  87     def getCallTip(self
, command
='', *args
, **kwds
): 
  88         """Return call tip text for a command. 
  90         The call tip information will be based on the locals namespace.""" 
  91         return introspect
.getCallTip(command
, self
.locals, *args
, **kwds
) 
  94 class InterpreterAlaCarte(Interpreter
): 
  95     """PyCrustAlaCarte Demo Interpreter.""" 
  97     def __init__(self
, locals, rawin
, stdin
, stdout
, stderr
, \
 
  98                  ps1
='main prompt', ps2
='continuation prompt'): 
  99         """Create an interactive interpreter object.""" 
 100         Interpreter
.__init
__(self
, locals=locals, rawin
=rawin
, \
 
 101                              stdin
=stdin
, stdout
=stdout
, stderr
=stderr
)