diff --git a/conanfile.py b/conanfile.py index 68bd9d2c17..d9e5cdb4fc 100644 --- a/conanfile.py +++ b/conanfile.py @@ -1,7 +1,10 @@ import os +from pathlib import Path from platform import python_version +from jinja2 import Template + from conan import ConanFile from conans import tools from conan.errors import ConanInvalidConfiguration @@ -26,14 +29,18 @@ class CuraConan(ConanFile): "enterprise": [True, False], "staging": [True, False], "external_engine": [True, False], - "devtools": [True, False] + "devtools": [True, False], + "cloud_api_version": "ANY", + "display_name": "ANY" } default_options = { "python_version": "system", "enterprise": False, "staging": False, "external_engine": False, - "devtools": False + "devtools": False, + "cloud_api_version": "1", + "display_name": "Ultimaker Cura" } scm = { "type": "git", @@ -42,6 +49,26 @@ class CuraConan(ConanFile): "revision": "auto" } + def set_version(self): + if not self.version and "CURA_VERSION" in os.environ: + self.version = os.environ["CURA_VERSION"] + + @property + def _cloud_api_root(self): + return "https://api-staging.ultimaker.com" if self.options.staging else "https://api.ultimaker.com" + + @property + def _cloud_account_api_root(self): + return "https://account-staging.ultimaker.com" if self.options.staging else "https://account.ultimaker.com" + + @property + def _marketplace_root(self): + return "https://marketplace-staging.ultimaker.com" if self.options.staging else "https://marketplace.ultimaker.com" + + @property + def _digital_factory_url(self): + return "https://digitalfactory-staging.ultimaker.com" if self.options.staging else "https://digitalfactory.ultimaker.com" + @property def requirements_txts(self): if self.options.devtools: @@ -67,7 +94,21 @@ class CuraConan(ConanFile): self.requires("pynest2d/latest@ultimaker/cura-9365") # FIXME: change to ultimaker/stable once the pynest2d PR for CURA-9365 has been merged def generate(self): - pass + with open(Path(self.source_folder, "cura", "CuraVersion.py.jinja"), "r") as f: + cura_version_py = Template(f.read()) + + with open(Path(self.source_folder, "cura", "CuraVersion.py"), "w") as f: + f.write(cura_version_py.render( + cura_app_name = self.name, + cura_app_display_name = self.options.display_name, + cura_version = self.version if self.version else "master", + cura_build_type = "Enterprise" if self.options.enterprise else "", + cura_debug_mode = self.settings.build_type != "Release", + cura_cloud_api_root = self._cloud_api_root, + cura_cloud_api_version = self.options.cloud_api_version, + cura_cloud_account_api_root = self._cloud_account_api_root, + cura_marketplace_root = self._marketplace_root, + cura_digital_factory_url = self._digital_factory_url)) def layout(self): self.folders.source = "." diff --git a/cura/CuraVersion.py.jinja b/cura/CuraVersion.py.jinja new file mode 100644 index 0000000000..1c30a0b5af --- /dev/null +++ b/cura/CuraVersion.py.jinja @@ -0,0 +1,13 @@ +# Copyright (c) 2022 Ultimaker B.V. +# Cura is released under the terms of the LGPLv3 or higher. + +CuraAppName = "{{ cura_app_name }}" +CuraAppDisplayName = "{{ cura_app_display_name }}" +CuraVersion = "{{ cura_version }}" +CuraBuildType = "{{ cura_build_type }}" +CuraDebugMode = {{ cura_debug_mode }} +CuraCloudAPIRoot = "{{ cura_cloud_api_root }}" +CuraCloudAPIVersion = "{{ cura_cloud_api_version }}" +CuraCloudAccountAPIRoot = "{{ cura_cloud_account_api_root }}" +CuraMarketplaceRoot = "{{ cura_marketplace_root }}" +CuraDigitalFactoryURL = "{{ cura_digital_factory_url }}"