Explorar o código

Merge branch 'ensure-python-script-local-import'

* ensure-python-script-local-import:
  Ensure module located where python script is executed can be imported
Jean-Christophe Fillion-Robin %!s(int64=13) %!d(string=hai) anos
pai
achega
78a9af2da8
Modificáronse 1 ficheiros con 3 adicións e 0 borrados
  1. 3 0
      Libs/Scripting/Python/Core/ctkAbstractPythonManager.cpp

+ 3 - 0
Libs/Scripting/Python/Core/ctkAbstractPythonManager.cpp

@@ -222,7 +222,10 @@ void ctkAbstractPythonManager::executeFile(const QString& filename)
   PythonQtObjectPtr main = ctkAbstractPythonManager::mainContext();
   if (main)
     {
+    QString path = QFileInfo(filename).absolutePath();
+    this->executeString(QString("import sys\nsys.path.insert(0, '%1')").arg(path));
     main.evalFile(filename);
+    this->executeString(QString("import sys\nif sys.path[0] == '%1': sys.path.pop(0)").arg(path));
     }
 }