diff --git a/.github/workflows/publish.yaml b/.github/workflows/publish.yaml index 7cec4c0..c62358d 100644 --- a/.github/workflows/publish.yaml +++ b/.github/workflows/publish.yaml @@ -14,6 +14,8 @@ jobs: steps: - name: Checkout code uses: actions/checkout@692973e3d937129bcbf40652eb9f2f61becf3332 + with: + fetch-depth: 0 - name: Set up Python uses: actions/setup-python@v4 @@ -23,7 +25,6 @@ jobs: - name: Install dependencies run: | python -m pip install uv - python -m uv pip install . python -m uv pip install build - name: Build the CLI diff --git a/pyproject.toml b/pyproject.toml index 492fad9..07ddf9c 100644 --- a/pyproject.toml +++ b/pyproject.toml @@ -61,5 +61,4 @@ armonik = "armonik_cli.cli:cli" [tool.setuptools_scm] version_scheme = "post-release" -local_scheme = "no-local-version" version_file = "src/armonik_cli/_version.py" diff --git a/setup.py b/setup.py new file mode 100644 index 0000000..f6d0c77 --- /dev/null +++ b/setup.py @@ -0,0 +1,32 @@ +# WARNING: This setup.py script is only for customizing the local version scheme with setuptools-scm. +# All other project configuration must be provided in pyproject.toml. Use this script cautiously and +# refer to the documentation for more details: https://setuptools-scm.readthedocs.io/en/latest/customizing/. + +from os import environ +from setuptools import setup +from setuptools_scm import ScmVersion + + +def get_local_schema(version: ScmVersion) -> str: + """ + Generate a custom local version scheme for setuptools-scm. + + Generates a local version string based on environment variables. If RELEASE is unset, + appends .dev for development builds; otherwise, returns an empty string. The + value of is retrieved from the GITHUB_RUN_ID environment variable if it exists, + otherwise the default value used is 0. + + Args: + version: The ScmVersion object passed by setuptools-scm. + + Returns: + The custom local version string. + """ + run_id = environ.get("GITHUB_RUN_ID", "0") + release = environ.get("RELEASE", "") + if not release: + return f".dev{run_id}" + return "" + + +setup(use_scm_version={"local_scheme": get_local_schema})