The Interpreter class This class manage the python interpreter and hold a lot helper functions for handling python stuff. More...
#include <Interpreter.h>
Public Member Functions | |
InterpreterSingleton () | |
~InterpreterSingleton () | |
execution methods | |
std::string | runString (const char *psCmd) |
Run a statement on the python interpreter and gives back a string with the representation of the result. More... | |
Py::Object | runStringObject (const char *sCmd) |
Run a statement on the python interpreter and return back the result object. More... | |
void | runInteractiveString (const char *psCmd) |
Run a statement on the python interpreter and gives back a string with the representation of the result. More... | |
void | runFile (const char *pxFileName, bool local) |
Run file (script) on the python interpreter. More... | |
void | runStringArg (const char *psCom,...) |
Run a statement with arguments on the python interpreter. More... | |
void | runMethodVoid (PyObject *pobject, const char *method) |
runs a python object method with no return value and no arguments More... | |
PyObject * | runMethodObject (PyObject *pobject, const char *method) |
runs a python object method which returns a arbitrary object More... | |
void | runMethod (PyObject *pobject, const char *method, const char *resfmt=0, void *cresult=0, const char *argfmt="()",...) |
runs a python method with arbitrary params More... | |
Cleanup | |
int | cleanup (void(*func)(void)) |
Register a cleanup function to be called by finalize(). More... | |
void | finalize () |
This calls the registered cleanup functions. More... | |
void | systemExit () |
This shuts down the application. More... | |
external wrapper libs | |
here we can access external dynamically loaded wrapper libs done e.g. by SWIG or SIP | |
PyObject * | createSWIGPointerObj (const char *Modole, const char *TypeName, void *Pointer, int own) |
generate a SWIG object More... | |
bool | convertSWIGPointerObj (const char *Module, const char *TypeName, PyObject *obj, void **ptr, int flags) |
void | cleanupSWIG (const char *TypeName) |
methods for debugging facility | |
void | dbgObserveFile (const char *sFileName="") |
sets the file name which should be debugged More... | |
void | dbgSetBreakPoint (unsigned int uiLineNumber) |
sets a break point to a special line number in the current file More... | |
void | dbgUnsetBreakPoint (unsigned int uiLineNumber) |
unsets a break point to a special line number in the current file More... | |
void | dbgStep (void) |
One step further. More... | |
Module handling | |
bool | loadModule (const char *psModName) |
void | addPythonPath (const char *Path) |
Add an additional python path. More... | |
static void | addType (PyTypeObject *Type, PyObject *Module, const char *Name) |
startup and singletons | |
const char * | init (int argc, char *argv[]) |
init the interpreter and returns the module search path More... | |
int | runCommandLine (const char *prompt) |
void | replaceStdOutput () |
static InterpreterSingleton & | Instance (void) |
static void | Destruct (void) |
static helper functions | |
PyObject * | getValue (const char *key, const char *result_var) |
static const std::string | strToPython (const char *Str) |
replaces all char with escapes for usage in python console More... | |
static const std::string | strToPython (const std::string &Str) |
Detailed Description
The Interpreter class This class manage the python interpreter and hold a lot helper functions for handling python stuff.
Constructor & Destructor Documentation
◆ InterpreterSingleton()
InterpreterSingleton::InterpreterSingleton | ( | ) |
Referenced by Instance().
◆ ~InterpreterSingleton()
InterpreterSingleton::~InterpreterSingleton | ( | ) |
Member Function Documentation
◆ addPythonPath()
void InterpreterSingleton::addPythonPath | ( | const char * | Path | ) |
Add an additional python path.
◆ addType()
|
static |
References PyType_Object::o.
Referenced by Gui::Application::Application(), and Fem::SMESH_HypothesisPy< StdMeshers_Deflection1DPy >::init_type().
◆ cleanup()
int InterpreterSingleton::cleanup | ( | void(*)(void) | func | ) |
Register a cleanup function to be called by finalize().
The cleanup function will be called with no arguments and should return no value. At most 32 cleanup functions can be registered. When the registration is successful 0 is returned; on failure -1 is returned. The cleanup function registered last is called first. Each cleanup function will be called at most once. Since Python's internal finalization will have completed before the cleanup function, no Python APIs should be called by func.
Referenced by PathScripts.PathDressupPathBoundaryGui.TaskPanel::abort(), PathScripts.PathDressupTagGui.PathDressupTagTaskPanel::abort(), PathScripts.PathDressupPathBoundaryGui.TaskPanel::accept(), PathScripts.PathDressupTagGui.PathDressupTagTaskPanel::accept(), PathScripts.PathJobGui.TaskPanel::accept(), PathScripts.PathOpGui.TaskPanel::accept(), PathScripts.PathDressupPathBoundaryGui.TaskPanel::reject(), PathScripts.PathDressupTagGui.PathDressupTagTaskPanel::reject(), PathScripts.PathJobGui.TaskPanel::reject(), and PathScripts.PathOpGui.TaskPanel::reject().
◆ cleanupSWIG()
void InterpreterSingleton::cleanupSWIG | ( | const char * | TypeName | ) |
◆ convertSWIGPointerObj()
bool InterpreterSingleton::convertSWIGPointerObj | ( | const char * | Module, |
const char * | TypeName, | ||
PyObject * | obj, | ||
void ** | ptr, | ||
int | flags | ||
) |
References Swig_python::convertSWIGPointerObj_T(), Swig_1_3_25::convertSWIGPointerObj_T(), Swig_1_3_33::convertSWIGPointerObj_T(), Swig_1_3_36::convertSWIGPointerObj_T(), Swig_1_3_38::convertSWIGPointerObj_T(), and Swig_1_3_40::convertSWIGPointerObj_T().
Referenced by Gui::ViewProviderPy::addDisplayMode(), Gui::View3DInventorPy::addDraggerCallback(), Gui::View3DInventorPy::addEventCallbackPivy(), Gui::View3DInventorPy::dumpNode(), Gui::ViewProviderPythonFeatureImp::getDetail(), Gui::AxisOriginPy::getDetailPath(), Gui::ViewProviderPythonFeatureImp::getDetailPath(), Gui::LinkViewPy::getDetailPath(), Gui::AxisOriginPy::getElementPicked(), Gui::LinkViewPy::getElementPicked(), Gui::View3DInventorPy::removeDraggerCallback(), Gui::View3DInventorPy::removeEventCallbackPivy(), Gui::Application::sCoinRemoveAllChildren(), Gui::View3DInventorViewerPy::setSceneGraph(), and Gui::View3DInventorViewerPy::setupEditingRoot().
◆ createSWIGPointerObj()
PyObject * InterpreterSingleton::createSWIGPointerObj | ( | const char * | Modole, |
const char * | TypeName, | ||
void * | Pointer, | ||
int | own | ||
) |
generate a SWIG object
References Swig_python::createSWIGPointerObj_T(), Swig_1_3_25::createSWIGPointerObj_T(), Swig_1_3_33::createSWIGPointerObj_T(), Swig_1_3_36::createSWIGPointerObj_T(), Swig_1_3_38::createSWIGPointerObj_T(), and Swig_1_3_40::createSWIGPointerObj_T().
Referenced by Gui::FreeCADGui_subgraphFromObject(), Gui::ViewProviderPy::getAnnotation(), Gui::View3DInventorPy::getCameraNode(), Gui::AxisOriginPy::getDetailPath(), Gui::ViewProviderPythonFeatureImp::getDetailPath(), Gui::LinkViewPy::getDetailPath(), Gui::ViewProviderPythonFeatureImp::getElement(), Gui::ViewProviderPythonFeatureImp::getElementPicked(), Gui::AxisOriginPy::getNode(), Gui::LinkViewPy::getRootNode(), Gui::ViewProviderPy::getRootNode(), Gui::View3DInventorViewerPy::getSceneGraph(), Gui::View3DInventorPy::getSceneGraph(), Gui::View3DInventorViewerPy::getSoEventManager(), and Gui::View3DInventorViewerPy::getSoRenderManager().
◆ dbgObserveFile()
void InterpreterSingleton::dbgObserveFile | ( | const char * | sFileName = "" | ) |
sets the file name which should be debugged
◆ dbgSetBreakPoint()
void InterpreterSingleton::dbgSetBreakPoint | ( | unsigned int | uiLineNumber | ) |
sets a break point to a special line number in the current file
◆ dbgStep()
void InterpreterSingleton::dbgStep | ( | void | ) |
One step further.
◆ dbgUnsetBreakPoint()
void InterpreterSingleton::dbgUnsetBreakPoint | ( | unsigned int | uiLineNumber | ) |
unsets a break point to a special line number in the current file
◆ Destruct()
|
static |
◆ finalize()
void InterpreterSingleton::finalize | ( | ) |
This calls the registered cleanup functions.
- See also
- cleanup() for more details.
Referenced by App::Application::destruct(), and draftguitools.gui_trackers.ghostTracker::update().
◆ getValue()
PyObject * InterpreterSingleton::getValue | ( | const char * | key, |
const char * | result_var | ||
) |
◆ init()
const char * InterpreterSingleton::init | ( | int | argc, |
char * | argv[] | ||
) |
init the interpreter and returns the module search path
References PythonStdOutput::init_type().
Referenced by DocumentObject.DocumentObject::onChanged().
◆ Instance()
|
static |
References InterpreterSingleton().
Referenced by Base::Interpreter().
◆ loadModule()
bool InterpreterSingleton::loadModule | ( | const char * | psModName | ) |
◆ replaceStdOutput()
void InterpreterSingleton::replaceStdOutput | ( | ) |
◆ runCommandLine()
int InterpreterSingleton::runCommandLine | ( | const char * | prompt | ) |
Referenced by StdCmdCommandLine::activated(), and App::Application::runApplication().
◆ runFile()
void InterpreterSingleton::runFile | ( | const char * | pxFileName, |
bool | local | ||
) |
Run file (script) on the python interpreter.
References Base::FileInfo::toStdWString().
Referenced by TechDraw::DrawParametricTemplate::execute(), App::Application::processFiles(), and Gui::MacroManager::run().
◆ runInteractiveString()
void InterpreterSingleton::runInteractiveString | ( | const char * | psCmd | ) |
Run a statement on the python interpreter and gives back a string with the representation of the result.
References Base::Exception::setMessage().
◆ runMethod()
void InterpreterSingleton::runMethod | ( | PyObject * | pobject, |
const char * | method, | ||
const char * | resfmt = 0 , |
||
void * | cresult = 0 , |
||
const char * | argfmt = "()" , |
||
... | |||
) |
runs a python method with arbitrary params
Referenced by Gui::PythonCommand::activated().
◆ runMethodObject()
runs a python object method which returns a arbitrary object
Referenced by Gui::PythonCommand::getHelpUrl(), Gui::PythonCommand::PythonCommand(), and Gui::PythonGroupCommand::PythonGroupCommand().
◆ runMethodVoid()
void InterpreterSingleton::runMethodVoid | ( | PyObject * | pobject, |
const char * | method | ||
) |
runs a python object method with no return value and no arguments
Runs a member method of an object with no parameter and no return value void (void).
There are other methods to run with returns
Referenced by Gui::PythonCommand::activated().
◆ runString()
std::string InterpreterSingleton::runString | ( | const char * | psCmd | ) |
Run a statement on the python interpreter and gives back a string with the representation of the result.
References Base::PyException::ThrowException().
Referenced by Gui::Command::addModule(), TechDraw::DrawViewDraft::execute(), TechDraw::DrawViewArch::execute(), StartGui::Workbench::loadStartPage(), TestGui::UnitTestDialog::on_startButton_clicked(), Import::ImpExpDxfRead::OnReadDimension(), DraftUtils::DraftDxfRead::OnReadDimension(), Gui::GestureNavigationStyle::onRollGesture(), App::Application::processCmdLineFiles(), Sandbox::PythonThread::run(), App::Application::runApplication(), Gui::Application::runInitGuiScript(), Web::AppServer::runPython(), runStringArg(), Gui::Application::setActiveDocument(), Gui::Application::sOpen(), PartDesignGui::TaskPrimitiveParameters::TaskPrimitiveParameters(), and Robot::Module::~Module().
◆ runStringArg()
void InterpreterSingleton::runStringArg | ( | const char * | psCom, |
... | |||
) |
Run a statement with arguments on the python interpreter.
References runString().
Referenced by TechDraw::DrawViewDraft::execute(), TechDraw::DrawViewArch::execute(), TechDraw::DrawDimHelper::makeDistDim(), TechDraw::DrawDimHelper::makeExtentDim(), Import::ImpExpDxfRead::OnReadDimension(), DraftUtils::DraftDxfRead::OnReadDimension(), App::Application::processCmdLineFiles(), App::Application::processFiles(), TechDraw::DrawViewCollection::unsetupObject(), TechDraw::DrawPage::unsetupObject(), and TechDraw::DrawViewPart::unsetupObject().
◆ runStringObject()
Py::Object InterpreterSingleton::runStringObject | ( | const char * | sCmd | ) |
Run a statement on the python interpreter and return back the result object.
◆ strToPython() [1/2]
|
static |
replaces all char with escapes for usage in python console
Referenced by Gui::PropertyEditor::PropertyStringListItem::setValue(), and Gui::Command::strToPython().
◆ strToPython() [2/2]
|
static |
References strToPython().
Referenced by strToPython().
◆ systemExit()
void InterpreterSingleton::systemExit | ( | ) |
This shuts down the application.
The documentation for this class was generated from the following files:
- src/Base/Interpreter.h
- src/Base/Interpreter.cpp