mirror of
https://github.com/Ultimaker/Cura.git
synced 2025-07-24 23:23:57 -06:00
Set the runenv for deploy
Contributes to CURA-9365
This commit is contained in:
parent
aa43287c26
commit
32ed0619b0
1 changed files with 43 additions and 8 deletions
51
conanfile.py
51
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"))
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue