Welcome to mirror list, hosted at ThFree Co, Russian Federation.

github.com/Ultimaker/Cura.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorj.spijker@ultimaker.com <jelle spijker>2022-06-29 05:53:26 +0300
committerJelle Spijker <j.spijker@ultimaker.com>2022-06-29 05:53:26 +0300
commit32ed0619b02e858aab50f2d01466f0d47b3f4d8b (patch)
treec58903b67a1f629905b9598be9d965ed93e38249 /conanfile.py
parentaa43287c26b9f20ab16928fc14e2add2bb281d40 (diff)
Set the runenv for deploy
Contributes to CURA-9365
Diffstat (limited to 'conanfile.py')
-rw-r--r--conanfile.py51
1 files changed, 43 insertions, 8 deletions
diff --git a/conanfile.py b/conanfile.py
index 388176e8b0..42750368aa 100644
--- a/conanfile.py
+++ b/conanfile.py
@@ -239,9 +239,12 @@ class CuraConan(ConanFile):
dst = os.path.join(self.install_folder, self._python_venv_bin_path), keep_path = False)
# Copy resources of Cura (keep folder structure)
- self.copy("*", src = self.cpp_info.libdirs[0], dst = os.path.join(self._site_packages_path(self._py_venv_interp), "cura"), keep_path = True)
- self.copy("*", src = self.cpp_info.resdirs[0], dst = os.path.join(self.install_folder, "share", "cura", "resources"), keep_path = True)
- self.copy("*", src = self.cpp_info.resdirs[1], dst = os.path.join(self.install_folder, "share", "cura", "plugins"), keep_path = True)
+ self.copy("*", src = self.cpp_info.libdirs[0], dst = os.path.join(self._site_packages_path(self._py_venv_interp), "cura"),
+ keep_path = True)
+ self.copy("*", src = self.cpp_info.resdirs[0], dst = os.path.join(self.install_folder, "share", "cura", "resources"),
+ keep_path = True)
+ self.copy("*", src = self.cpp_info.resdirs[1], dst = os.path.join(self.install_folder, "share", "cura", "plugins"),
+ keep_path = True)
# Copy materials (flat)
self.copy_deps("*.fdm_material", root_package = "fdm_materials", src = "@resdirs",
@@ -250,20 +253,52 @@ class CuraConan(ConanFile):
dst = os.path.join(self.install_folder, "share", "cura", "resources", "materials"), keep_path = False)
# Copy resources of Uranium (keep folder structure)
- self.copy_deps("*", root_package = "uranium", src = self.deps_cpp_info["uranium"].resdirs[0], dst = os.path.join(self.install_folder, "share", "uranium", "resources"), keep_path = True)
- self.copy_deps("*", root_package = "uranium", src = self.deps_cpp_info["uranium"].resdirs[1], dst = os.path.join(self.install_folder, "share", "uranium", "plugins"), keep_path = True)
- self.copy_deps("*", root_package = "uranium", src = self.deps_cpp_info["uranium"].libdirs[0], dst = o.path.join(self._site_packages_path(self._py_venv_interp), "UM"), keep_path = True)
+ self.copy_deps("*", root_package = "uranium", src = self.deps_cpp_info["uranium"].resdirs[0],
+ dst = os.path.join(self.install_folder, "share", "uranium", "resources"), keep_path = True)
+ self.copy_deps("*", root_package = "uranium", src = self.deps_cpp_info["uranium"].resdirs[1],
+ dst = os.path.join(self.install_folder, "share", "uranium", "plugins"), keep_path = True)
+ self.copy_deps("*", root_package = "uranium", src = self.deps_cpp_info["uranium"].libdirs[0],
+ dst = os.path.join(self._site_packages_path(self._py_venv_interp), "UM"), keep_path = True)
+
+ # Copy resources of cura_binary_data
+ self.copy_deps("*", root_package = "cura_binary_data", src = self.deps_cpp_info["cura_binary_data"].resdirs[0],
+ dst = os.path.join(self.install_folder, "share", "cura"), keep_path = True)
+ self.copy_deps("*", root_package = "cura_binary_data", src = self.deps_cpp_info["cura_binary_data"].resdirs[1],
+ dst = os.path.join(self.install_folder, "share", "uranium"), keep_path = True)
+ if self.settings.os == "Windows":
+ self.copy_deps("*", root_package = "cura_binary_data", src = self.deps_cpp_info["cura_binary_data"].resdirs[2],
+ dst = os.path.join(self.install_folder, "share", "windows"), keep_path = True)
# Add plugins to PYTHONPATH
self.runenv_info.append_path("PYTHONPATH", os.path.join(self.install_folder, "share", "cura", "plugins"))
self.runenv_info.append_path("PYTHONPATH", os.path.join(self.install_folder, "share", "uranium", "plugins"))
+ # Add PyQt6/Qt6/bin to PATH
+ # TODO: Check if Pqt6/Qt6/plugins should also be added to the PATH
+ self.runenv_info.append_path("PATH", os.path.join(self._site_packages_path(self._py_venv_interp), "PyQt6", "Qt6", "bin"))
+
# Copy dynamic libs to site-packages
self.copy_deps("*.dll", src = "@bindirs", dst = self._site_packages_path(self._py_venv_interp))
self.copy_deps("*.pyd", src = "@libdirs", dst = self._site_packages_path(self._py_venv_interp))
self.copy_deps("*.pyi", src = "@libdirs", dst = self._site_packages_path(self._py_venv_interp))
self.copy_deps("*.dylib", src = "@libdirs", dst = self._site_packages_path(self._py_venv_interp))
+ # Add the virtualrun_env from the dependencies
+ runenv = self.runenv_info
+ for _, dependency in self.dependencies.host.items():
+ runenv.compose_env(dependency.runenv_info)
+
+ # Add the dynamic lib paths from the environment
+ for bin_path in self.deps_cpp_info.bin_paths:
+ runenv.append_path("PATH", bin_path)
+ runenv.append_path("LD_LIBRARY_PATH", bin_path)
+ runenv.append_path("DYLD_LIBRARY_PATH", bin_path)
+
+ vars = runenv.vars(self, scope = "run")
+ vars.save_sh(os.path.join(self.install_folder, self._python_venv_bin_path, "activate"))
+ vars.save_bat(os.path.join(self.install_folder, self._python_venv_bin_path, "activate.bat"))
+ vars.save_ps1(os.path.join(self.install_folder, self._python_venv_bin_path, "Activate.ps1"))
+
# Make sure the CuraVersion.py is up to date with the correct settings
with open(Path(Path(__file__).parent, "CuraVersion.py.jinja"), "r") as f:
cura_version_py = Template(f.read())
@@ -281,8 +316,8 @@ class CuraConan(ConanFile):
self.user_info.pip_requirements_git = "requirements-ultimaker.txt"
self.user_info.pip_requirements_build = "requirements-dev.txt"
if self.in_local_cache:
- self.runenv_info.append_path("PYTHONPATH", str(Path(self.cpp_info.libdirs[0]).parent))
- self.runenv_info.append_path("PYTHONPATH", self.cpp_info.resdirs[0])
+ self.runenv_info.append_path("PYTHONPATH", str(Path(self.cpp_info.lib_paths[0]).parent))
+ self.runenv_info.append_path("PYTHONPATH", self.cpp_info.res_paths[0])
else:
self.runenv_info.append_path("PYTHONPATH", self.source_folder)
self.runenv_info.append_path("PYTHONPATH", os.path.join(self.source_folder, "plugins"))