Sfoglia il codice sorgente

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 13 anni fa
parent
commit
78a9af2da8
1 ha cambiato i file con 3 aggiunte e 0 eliminazioni
  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));
     }
 }