From b1b2474b2d698ccc1cad0aacebe9c88c9b55e8a5 Mon Sep 17 00:00:00 2001 From: Jelle Spijker Date: Mon, 12 Feb 2024 11:42:36 +0100 Subject: [PATCH] Use Conan v2 Contributes to CURA-11622 --- .github/workflows/conan-package.yml | 224 ++++++------------ .../workflows/requirements-conan-package.txt | 2 - .github/workflows/requirements-runner.txt | 0 conandata.yml | 3 + conanfile.py | 79 +++--- test_package/conanfile.py | 13 +- 6 files changed, 119 insertions(+), 202 deletions(-) delete mode 100644 .github/workflows/requirements-conan-package.txt create mode 100644 .github/workflows/requirements-runner.txt create mode 100644 conandata.yml diff --git a/.github/workflows/conan-package.yml b/.github/workflows/conan-package.yml index e6c38a7..d03c284 100644 --- a/.github/workflows/conan-package.yml +++ b/.github/workflows/conan-package.yml @@ -1,157 +1,77 @@ ---- name: conan-package -# Exports the recipe, sources and binaries for Mac, Windows and Linux and upload these to the server such that these can -# be used downstream. -# -# It should run on pushes against main or CURA-* branches, but it will only create the binaries for main and release branches - on: - workflow_dispatch: - inputs: - # FIXME: Not yet implemented - conan_id: - required: false - type: string - description: 'The full conan package ID, e.g. "libnest2d/1.2.3@ultimaker/stable"' - create_latest_alias: - required: true - default: false - type: boolean - description: 'Create latest alias' - create_binaries_windows: - required: true - default: false - type: boolean - description: 'create binaries Windows' - create_binaries_linux: - required: true - default: false - type: boolean - description: 'create binaries Linux' - create_binaries_macos: - required: true - default: false - type: boolean - description: 'create binaries Macos' - - push: - paths: - - 'python/**' - - 'test_package/**' - - 'cmake/**' - - 'conanfile.py' - - 'conandata.yml' - - 'CMakeLists.txt' - - '.github/workflows/conan-package.yml' - - '.github/workflows/requirements*' - branches: - - main - - 'CURA-*' - - '[0-9]+.[0-9]+' - tags: - - '[0-9]+.[0-9]+.[0-9]*' + push: + paths: + - 'python/**' + - 'test_package/**' + - 'conanfile.py' + - 'conandata.yml' + - 'CMakeLists.txt' + - '.github/workflows/conan-package.yml' + - '.github/workflows/requirements*' + branches: + - main + - 'CURA-*' + - 'PP-*' + - 'NP-*' + - '[0-9].[0-9]*' + - '[0-9].[0-9][0-9]*' jobs: - conan-recipe-version: - uses: ultimaker/cura/.github/workflows/conan-recipe-version.yml@main - with: - project_name: pynest2d - - conan-package-export: - needs: [ conan-recipe-version ] - uses: ultimaker/cura/.github/workflows/conan-recipe-export.yml@main - with: - recipe_id_full: ${{ needs.conan-recipe-version.outputs.recipe_id_full }} - recipe_id_latest: ${{ needs.conan-recipe-version.outputs.recipe_id_latest }} - runs_on: 'ubuntu-20.04' - python_version: '3.11.x' - conan_logging_level: 'info' - secrets: inherit - - conan-package-create-windows: - if: ${{ (github.event_name == 'push' && (github.ref_name == 'main' || github.ref_name == 'master' || needs.conan-recipe-version.outputs.is_release_branch)) || (github.event_name == 'workflow_dispatch' && inputs.create_binaries_windows) }} - needs: [ conan-recipe-version, conan-package-export ] - - uses: ultimaker/cura/.github/workflows/conan-package-create.yml@main - with: - project_name: ${{ needs.conan-recipe-version.outputs.project_name }} - recipe_id_full: ${{ needs.conan-recipe-version.outputs.recipe_id_full }} - build_id: 4 - build_info: false - runs_on: 'windows-2022' - python_version: '3.11.x' - conan_config_branch: '' - conan_logging_level: 'info' - secrets: inherit - - conan-package-create-macos: - if: ${{ (github.event_name == 'push' && (github.ref_name == 'main' || github.ref_name == 'master' || needs.conan-recipe-version.outputs.is_release_branch)) || (github.event_name == 'workflow_dispatch' && inputs.create_binaries_macos) }} - needs: [ conan-recipe-version, conan-package-export ] - - uses: ultimaker/cura/.github/workflows/conan-package-create.yml@main - with: - project_name: ${{ needs.conan-recipe-version.outputs.project_name }} - recipe_id_full: ${{ needs.conan-recipe-version.outputs.recipe_id_full }} - build_id: 3 - build_info: false - runs_on: 'macos-11' - python_version: '3.11.x' - conan_logging_level: 'info' - secrets: inherit - - conan-package-create-linux-modern: - if: ${{ (github.event_name == 'push' && (github.ref_name == 'main' || github.ref_name == 'master' || needs.conan-recipe-version.outputs.is_release_branch)) || (github.event_name == 'workflow_dispatch' && inputs.create_binaries_linux) }} - needs: [ conan-recipe-version, conan-package-export ] - - uses: ultimaker/cura/.github/workflows/conan-package-create.yml@main - with: - project_name: ${{ needs.conan-recipe-version.outputs.project_name }} - recipe_id_full: ${{ needs.conan-recipe-version.outputs.recipe_id_full }} - build_id: 2 - build_info: false - runs_on: 'ubuntu-22.04' - python_version: '3.11.x' - conan_logging_level: 'info' - secrets: inherit - - conan-package-create-linux: - if: ${{ (github.event_name == 'push' && (github.ref_name == 'main' || github.ref_name == 'master' || needs.conan-recipe-version.outputs.is_release_branch)) || (github.event_name == 'workflow_dispatch' && inputs.create_binaries_linux) }} - needs: [ conan-recipe-version, conan-package-export ] - - uses: ultimaker/cura/.github/workflows/conan-package-create.yml@main - with: - project_name: ${{ needs.conan-recipe-version.outputs.project_name }} - recipe_id_full: ${{ needs.conan-recipe-version.outputs.recipe_id_full }} - build_id: 1 - build_info: false - runs_on: 'ubuntu-20.04' - python_version: '3.11.x' - conan_logging_level: 'info' - secrets: inherit - - notify-export: - if: ${{ always() }} - needs: [ conan-recipe-version, conan-package-export ] - - uses: ultimaker/cura/.github/workflows/notify.yml@main - with: - success: ${{ contains(join(needs.*.result, ','), 'success') }} - success_title: "New Conan recipe exported in ${{ github.repository }}" - success_body: "Exported ${{ needs.conan-recipe-version.outputs.recipe_id_full }}" - failure_title: "Failed to export Conan Export in ${{ github.repository }}" - failure_body: "Failed to exported ${{ needs.conan-recipe-version.outputs.recipe_id_full }}" - secrets: inherit - - notify-create: - if: ${{ always() && ((github.event_name == 'push' && (github.ref_name == 'main' || github.ref_name == 'master' || needs.conan-recipe-version.outputs.is_release_branch)) || (github.event_name == 'workflow_dispatch' && inputs.create_binaries_linux)) }} - needs: [ conan-recipe-version, conan-package-create-macos, conan-package-create-windows, conan-package-create-linux, conan-package-create-linux-modern ] - - uses: ultimaker/cura/.github/workflows/notify.yml@main - with: - success: ${{ contains(join(needs.*.result, ','), 'success') }} - success_title: "New binaries created in ${{ github.repository }}" - success_body: "Created binaries for ${{ needs.conan-recipe-version.outputs.recipe_id_full }}" - failure_title: "Failed to create binaries in ${{ github.repository }}" - failure_body: "Failed to created binaries for ${{ needs.conan-recipe-version.outputs.recipe_id_full }}" - secrets: inherit +# FIXME: Use main once merged + conan-recipe-version: + uses: ultimaker/cura-workflows/.github/workflows/conan-recipe-version.yml@CURA-11622_conan_v2 + with: + project_name: pynest2d + +# FIXME: Use main once merged + conan-package-export: + needs: [ conan-recipe-version ] + uses: ultimaker/cura-workflows/.github/workflows/conan-recipe-export.yml@CURA-11622_conan_v2 + with: + recipe_id_name: ${{ needs.conan-recipe-version.outputs.project_name }} + recipe_id_version: ${{ needs.conan-recipe-version.outputs.recipe_semver_full }} + recipe_id_user: ${{ needs.conan-recipe-version.outputs.user }} + recipe_id_channel: ${{ needs.conan-recipe-version.outputs.channel }} + recipe_id_full: ${{ needs.conan-recipe-version.outputs.recipe_id_full }} + secrets: inherit + +# FIXME: Use main once merged + conan-package-create-macos: + needs: [ conan-recipe-version, conan-package-export ] + if: ${{ (github.event_name == 'push' && (github.ref_name == 'main' || github.ref_name == 'master' || needs.conan-recipe-version.outputs.is_release_branch == 'true')) }} + uses: ultimaker/cura-workflows/.github/workflows/conan-package-create-macos.yml@CURA-11622_conan_v2 + with: + recipe_id_name: ${{ needs.conan-recipe-version.outputs.project_name }} + recipe_id_version: ${{ needs.conan-recipe-version.outputs.recipe_semver_full }} + recipe_id_user: ${{ needs.conan-recipe-version.outputs.user }} + recipe_id_channel: ${{ needs.conan-recipe-version.outputs.channel }} + recipe_id_full: ${{ needs.conan-recipe-version.outputs.recipe_id_full }} + secrets: inherit + +# FIXME: Use main once merged + conan-package-create-windows: + needs: [ conan-recipe-version, conan-package-export ] + if: ${{ (github.event_name == 'push' && (github.ref_name == 'main' || github.ref_name == 'master' || needs.conan-recipe-version.outputs.is_release_branch == 'true')) }} + uses: ultimaker/cura-workflows/.github/workflows/conan-package-create-windows.yml@CURA-11622_conan_v2 + with: + recipe_id_name: ${{ needs.conan-recipe-version.outputs.project_name }} + recipe_id_version: ${{ needs.conan-recipe-version.outputs.recipe_semver_full }} + recipe_id_user: ${{ needs.conan-recipe-version.outputs.user }} + recipe_id_channel: ${{ needs.conan-recipe-version.outputs.channel }} + recipe_id_full: ${{ needs.conan-recipe-version.outputs.recipe_id_full }} + secrets: inherit + +# FIXME: Use main once merged + conan-package-create-linux: + needs: [ conan-recipe-version, conan-package-export ] + if: ${{ (github.event_name == 'push' && (github.ref_name == 'main' || github.ref_name == 'master' || needs.conan-recipe-version.outputs.is_release_branch == 'true')) }} + uses: ultimaker/cura-workflows/.github/workflows/conan-package-create-linux.yml@CURA-11622_conan_v2 + with: + recipe_id_name: ${{ needs.conan-recipe-version.outputs.project_name }} + recipe_id_version: ${{ needs.conan-recipe-version.outputs.recipe_semver_full }} + recipe_id_user: ${{ needs.conan-recipe-version.outputs.user }} + recipe_id_channel: ${{ needs.conan-recipe-version.outputs.channel }} + recipe_id_full: ${{ needs.conan-recipe-version.outputs.recipe_id_full }} + secrets: inherit \ No newline at end of file diff --git a/.github/workflows/requirements-conan-package.txt b/.github/workflows/requirements-conan-package.txt deleted file mode 100644 index 790edfb..0000000 --- a/.github/workflows/requirements-conan-package.txt +++ /dev/null @@ -1,2 +0,0 @@ -conan -sip diff --git a/.github/workflows/requirements-runner.txt b/.github/workflows/requirements-runner.txt new file mode 100644 index 0000000..e69de29 diff --git a/conandata.yml b/conandata.yml new file mode 100644 index 0000000..f8e8c3e --- /dev/null +++ b/conandata.yml @@ -0,0 +1,3 @@ +version: "5.4.0-alpha.0" +requirements: + - "nest2d/[>=5.4.0]@ultimaker/cura_11622" diff --git a/conanfile.py b/conanfile.py index c276b42..cea4724 100644 --- a/conanfile.py +++ b/conanfile.py @@ -6,14 +6,12 @@ from conan import ConanFile from conan.errors import ConanInvalidConfiguration from conan.tools.build import check_min_cppstd -from conan.tools.cmake import CMake, CMakeToolchain, cmake_layout -from conan.tools.env import VirtualBuildEnv -from conan.tools.files import copy, mkdir +from conan.tools.cmake import CMake, CMakeToolchain, cmake_layout, CMakeDeps +from conan.tools.files import copy, mkdir, update_conandata from conan.tools.microsoft import check_min_vs, is_msvc, is_msvc_static_runtime -from conan.tools.scm import Version +from conan.tools.scm import Version, Git - -required_conan_version = ">=1.56.0" +required_conan_version = ">=1.58.0" class PyNest2DConan(ConanFile): @@ -24,11 +22,10 @@ class PyNest2DConan(ConanFile): description = "Python bindings for libnest2d" topics = ("conan", "cura", "prusaslicer", "nesting", "c++", "bin packaging", "python", "sip") settings = "os", "compiler", "build_type", "arch" - revision_mode = "scm" exports = "LICENSE*" - generators = "CMakeDeps", "VirtualBuildEnv", "VirtualRunEnv" + package_type = "library" - python_requires = "pyprojecttoolchain/[>=0.1.7]@ultimaker/stable", "sipbuildtool/[>=0.2.4]@ultimaker/stable" + python_requires = "pyprojecttoolchain/[>=0.2.0]@ultimaker/cura_11622", "sipbuildtool/[>=0.3.0]@ultimaker/cura_11622" # FIXME: use stable after merge options = { "shared": [True, False], @@ -45,7 +42,11 @@ class PyNest2DConan(ConanFile): def set_version(self): if not self.version: - self.version = "5.4.0-alpha" + self.version = self.conan_data["version"] + + def export(self): + git = Git(self) + update_conandata(self, {"version": self.version, "commit": git.get_commit()}) @property def _min_cppstd(self): @@ -66,8 +67,8 @@ def export_sources(self): copy(self, "*", path.join(self.recipe_folder, "python"), path.join(self.export_sources_folder, "python")) def requirements(self): - self.requires("nest2d/5.3.0") - self.requires("cpython/3.10.4") + for req in self.conan_data["requirements"]: + self.requires(req) def validate(self): if self.settings.compiler.cppstd: @@ -81,8 +82,9 @@ def validate(self): ) def build_requirements(self): - self.test_requires("standardprojectsettings/[>=0.1.0]@ultimaker/stable") - self.test_requires("sipbuildtool/[>=0.2.4]@ultimaker/stable") + self.test_requires("standardprojectsettings/[>=0.2.0]@ultimaker/cura_11622") # FIXME: use stable after merge + self.test_requires("sipbuildtool/[>=0.3.0]@ultimaker/cura_11622") # FIXME: use stable after merge + self.test_requires("cpython/3.12.2@ultimaker/cura_11622") # FIXME: use stable after merge def config_options(self): if self.settings.os == "Windows": @@ -94,18 +96,23 @@ def configure(self): self.options["cpython"].shared = True def generate(self): - pp = self.python_requires["pyprojecttoolchain"].module.PyProjectToolchain(self) - pp.blocks["tool_sip_project"].values["sip_files_dir"] = str(Path("python").as_posix()) - pp.blocks.remove("extra_sources") - pp.generate() + tc = self.python_requires["pyprojecttoolchain"].module.PyProjectToolchain(self) + tc.blocks["tool_sip_project"].values["sip_files_dir"] = str(Path("python").as_posix()) + tc.blocks.remove("extra_sources") + tc.generate() + + tc = CMakeDeps(self) + tc.generate() tc = CMakeToolchain(self) if is_msvc(self): tc.variables["USE_MSVC_RUNTIME_LIBRARY_DLL"] = not is_msvc_static_runtime(self) - tc.cache_variables["CMAKE_POLICY_DEFAULT_CMP0077"] = "NEW" - tc.variables["Python_EXECUTABLE"] = self.deps_user_info["cpython"].python.replace("\\", "/") - tc.variables["Python_USE_STATIC_LIBS"] = not self.options["cpython"].shared - tc.variables["Python_ROOT_DIR"] = self.deps_cpp_info["cpython"].rootpath.replace("\\", "/") + tc.cache_variables["CMAKE_POLICY_DEFAULT_CMP0148"] = "OLD" + cpython_conf = self.dependencies["cpython"].conf_info + tc.variables["Python_EXECUTABLE"] = cpython_conf.get("user.cpython:python").replace("\\", "/") + tc.variables["Python_ROOT_DIR"] = cpython_conf.get("user.cpython:python_root").replace("\\", "/") + cpython_options = self.dependencies["cpython"].options + tc.variables["Python_USE_STATIC_LIBS"] = not cpython_options.shared tc.variables["Python_FIND_FRAMEWORK"] = "NEVER" tc.variables["Python_FIND_REGISTRY"] = "NEVER" tc.variables["Python_FIND_IMPLEMENTATIONS"] = "CPython" @@ -113,13 +120,10 @@ def generate(self): tc.variables["Python_SITEARCH"] = "site-packages" tc.generate() - vb = VirtualBuildEnv(self) - vb.generate(scope="build") - # Generate the Source code from SIP - sip = self.python_requires["sipbuildtool"].module.SipBuildTool(self) - sip.configure() - sip.build() + tc = self.python_requires["sipbuildtool"].module.SipBuildTool(self) + tc.configure() + tc.build() def layout(self): cmake_layout(self) @@ -127,6 +131,12 @@ def layout(self): if self.settings.os in ["Linux", "FreeBSD", "Macos"]: self.cpp.package.system_libs = ["pthread"] + self.cpp.package.lib = ["pySavitar"] + self.cpp.package.libdirs = ["lib"] + + self.layouts.build.runenv_info.prepend_path("PYTHONPATH", ".") + self.layouts.package.runenv_info.prepend_path("PYTHONPATH", "lib") + def build(self): cmake = CMake(self) cmake.configure() @@ -134,15 +144,8 @@ def build(self): def package(self): copy(self, pattern="LICENSE*", dst="licenses", src=self.source_folder) - for ext in ("*.pyi", "*.so", "*.lib", "*.a", "*.pyd"): - copy(self, ext, src = self.build_folder, dst = path.join(self.package_folder, "lib"), keep_path = False) - - for ext in ("*.dll", "*.so", "*.dylib"): - copy(self, ext, src = self.build_folder, dst = path.join(self.package_folder, "bin"), keep_path = False) + for ext in ("*.pyi", "*.so", "*.lib", "*.a", "*.pyd", "*.dll", "*.dylib"): + copy(self, ext, src=self.build_folder, dst=path.join(self.package_folder, "lib"), keep_path=False) def package_info(self): - self.cpp_info.libdirs = [ os.path.join(self.package_folder, "lib")] - if self.in_local_cache: - self.runenv_info.append_path("PYTHONPATH", os.path.join(self.package_folder, "lib")) - else: - self.runenv_info.append_path("PYTHONPATH", self.build_folder) + self.conf_info.define("user.pysavitar:pythonpath", os.path.join(self.package_folder, "lib")) diff --git a/test_package/conanfile.py b/test_package/conanfile.py index 23992bd..5ec34b4 100644 --- a/test_package/conanfile.py +++ b/test_package/conanfile.py @@ -1,6 +1,4 @@ -import shutil from io import StringIO -from pathlib import Path from conan import ConanFile from conan.tools.env import VirtualRunEnv @@ -11,7 +9,6 @@ class PyNest2DTestConan(ConanFile): settings = "os", "compiler", "build_type", "arch" - generators = "VirtualRunEnv" test_type = "explicit" def requirements(self): @@ -22,19 +19,15 @@ def generate(self): venv.generate() cpp_info = self.dependencies[self.tested_reference_str].cpp_info - copy(self, "*.pyd", src = cpp_info.libdirs[0], dst =self.build_folder) + copy(self, "*.pyd", src=cpp_info.libdirs[0], dst=self.build_folder) for dep in self.dependencies.values(): for bin_dir in dep.cpp_info.bindirs: - copy(self, "*.dll", src = bin_dir, dst = self.build_folder) - - def build(self): - if can_run(self): - shutil.copy(Path(self.source_folder).joinpath("test.py"), Path(self.build_folder).joinpath("test.py")) + copy(self, "*.dll", src=bin_dir, dst=self.build_folder) def test(self): if can_run(self): test_buf = StringIO() - self.run(f"python test.py", env = "conanrun", output = test_buf) + self.run(f"python test.py", env="conanrun", stdout=test_buf, scope="run") if "True" not in test_buf.getvalue(): raise ConanException("pynest2d wasn't build correctly!")