ctkAbstractPythonManager.h 4.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130
  1. /*=========================================================================
  2. Library: CTK
  3. Copyright (c) Kitware Inc.
  4. Licensed under the Apache License, Version 2.0 (the "License");
  5. you may not use this file except in compliance with the License.
  6. You may obtain a copy of the License at
  7. http://www.apache.org/licenses/LICENSE-2.0.txt
  8. Unless required by applicable law or agreed to in writing, software
  9. distributed under the License is distributed on an "AS IS" BASIS,
  10. WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  11. See the License for the specific language governing permissions and
  12. limitations under the License.
  13. =========================================================================*/
  14. #ifndef __ctkAbstractPythonManager_h
  15. #define __ctkAbstractPythonManager_h
  16. // Qt includes
  17. #include <QObject>
  18. #include <QList>
  19. #include <QStringList>
  20. // CTK includes
  21. #include "ctkScriptingPythonCoreExport.h"
  22. class ctkAbstractPythonManagerPrivate;
  23. class PythonQtObjectPtr;
  24. /// \ingroup Scripting_Python_Core
  25. class CTK_SCRIPTING_PYTHON_CORE_EXPORT ctkAbstractPythonManager : public QObject
  26. {
  27. Q_OBJECT
  28. public:
  29. typedef QObject Superclass;
  30. ctkAbstractPythonManager(QObject* _parent=NULL);
  31. virtual ~ctkAbstractPythonManager();
  32. PythonQtObjectPtr mainContext();
  33. void addObjectToPythonMain(const QString& name, QObject* obj);
  34. void registerPythonQtDecorator(QObject* decorator);
  35. void registerClassForPythonQt(const QMetaObject* metaobject);
  36. void registerCPPClassForPythonQt(const char* name);
  37. /// This enum maps to Py_eval_input, Py_file_input and Py_single_input
  38. /// \see http://docs.python.org/c-api/veryhigh.html#Py_eval_input
  39. /// \see http://docs.python.org/c-api/veryhigh.html#Py_file_input
  40. /// \see http://docs.python.org/c-api/veryhigh.html#Py_single_input
  41. enum ExecuteStringMode
  42. {
  43. EvalInput = 0,
  44. FileInput,
  45. SingleInput
  46. };
  47. /// Execute a python of python code (can be multiple lines separated with newline)
  48. /// and return the result as a QVariant.
  49. QVariant executeString(const QString& code, ExecuteStringMode mode = FileInput);
  50. /// Gets the value of the variable looking in the __main__ module.
  51. /// If the variable is not found returns a default initialized QVariant.
  52. QVariant getVariable(const QString& varName);
  53. /// Execute a python script with the given filename.
  54. void executeFile(const QString& filename);
  55. /// Set function that is initialized after preInitialization and before executeInitializationScripts
  56. /// \sa preInitialization executeInitializationScripts
  57. void setInitializationFunction(void (*initFunction)());
  58. /// Given a python variable name, lookup its attributes and return them in a string list.
  59. /// By default the attributes are looked up from \c __main__.
  60. /// If the argument \c appendParenthesis is set to True, "()" will be appended to attributes
  61. /// being Python callable.
  62. QStringList pythonAttributes(const QString& pythonVariableName,
  63. const QString& module = QLatin1String("__main__"),
  64. bool appendParenthesis = false) const;
  65. /// Returns True if python is initialized
  66. /// \sa pythonInitialized
  67. bool isPythonInitialized()const;
  68. /// Returns True if a python error occured.
  69. /// \sa PythonQt::errorOccured()
  70. bool pythonErrorOccured()const;
  71. Q_SIGNALS:
  72. /// This signal is emitted after python is pre-initialized. Observers can listen
  73. /// for this signal to handle additional initialization steps.
  74. /// \sa preInitialization
  75. void pythonPreInitialized();
  76. /// This signal is emitted after python is initialized and scripts are executed
  77. /// \sa preInitialization
  78. /// \sa executeScripts
  79. void pythonInitialized();
  80. protected Q_SLOTS:
  81. void printStderr(const QString&);
  82. void printStdout(const QString&);
  83. protected:
  84. void initPythonQt();
  85. virtual QStringList pythonPaths();
  86. /// Overload this function to load Decorator and pythonQt wrapper at initialization time
  87. virtual void preInitialization();
  88. /// Overload this function to execute script at initialization time
  89. virtual void executeInitializationScripts();
  90. protected:
  91. QScopedPointer<ctkAbstractPythonManagerPrivate> d_ptr;
  92. private:
  93. Q_DECLARE_PRIVATE(ctkAbstractPythonManager);
  94. Q_DISABLE_COPY(ctkAbstractPythonManager);
  95. };
  96. #endif