123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100 |
- name: Get Conan Recipe Version
- on:
- workflow_call:
- inputs:
- project_name:
- required: true
- type: string
- outputs:
- recipe_id_full:
- description: "The full Conan recipe id: <name>/<version>@<user>/<channel>"
- value: ${{ jobs.get-semver.outputs.recipe_id_full }}
- recipe_id_latest:
- description: "The full Conan recipe aliased (latest) id: <name>/(latest)@<user>/<channel>"
- value: ${{ jobs.get-semver.outputs.recipe_id_latest }}
- recipe_semver_full:
- description: "The full semver <Major>.<Minor>.<Patch>-<PreReleaseTag>+<BuildMetaData>"
- value: ${{ jobs.get-semver.outputs.semver_full }}
- jobs:
- get-semver:
- runs-on: ubuntu-latest
- outputs:
- recipe_id_full: ${{ inputs.project_name }}/${{ steps.get-conan-broadcast-data.outputs.version }}@${{ steps.get-conan-broadcast-data.outputs.user }}/${{ steps.get-conan-broadcast-data.outputs.channel }}
- recipe_id_latest: ${{ steps.latest-alias.outputs.recipe_id_latest }}
- recipe_id_pr: ${{ steps.pr-alias.outputs.recipe_id_pr }}
- semver_full: ${{ steps.get-conan-broadcast-data.outputs.version }}
- user: ${{ steps.get-conan-broadcast-data.outputs.user }}
- channel: ${{ steps.get-conan-broadcast-data.outputs.channel }}
- steps:
- - name: Checkout repo
- uses: actions/checkout@v3
- with:
- ref: ${{ github.head_ref }}
- fetch-depth: 0
- - name: Install GitVersion
- uses: gittools/actions/gitversion/setup@v0.9.13
- with:
- versionSpec: '5.x'
- - name: GitTools
- id: git-tool
- uses: gittools/actions/gitversion/execute@v0.9.13
- - id: get-conan-broadcast-data
- name: Get Conan broadcast data
- run: |
- if [ "${{ github.ref_type == 'tag' && github.ref_name == '${{ steps.git-tool.outputs.Major }}.${{ steps.git-tool.outputs.Minor }}.${{ steps.git-tool.outputs.Patch }}' }}" = "true" ]; then
- # tagged commits on a release branch matching the major.minor.patch are actual released version and should have no user and channel
- # name/major.minor.patch@_/_
- echo '::set-output name=user::_'
- echo '::set-output name=channel::_'
- echo '::set-output name=version::${{ steps.git-tool.outputs.Major }}.${{ steps.git-tool.outputs.Minor }}.${{ steps.git-tool.outputs.Patch }}'
- elif [ "${{ github.ref_type == 'tag' && github.ref_name == '${{ steps.git-tool.outputs.Major }}.${{ steps.git-tool.outputs.Minor }}.${{ steps.git-tool.outputs.Patch }}-BETA' }}" = "true" ]; then
- # tagged commits with major.minor.patch-BETA on a release branch are actual released version and should have no user and channel
- # name/major.minor.patch-beta@_/_
- echo '::set-output name=user::_'
- echo '::set-output name=channel::_'
- echo '::set-output name=version::${{ steps.git-tool.outputs.Major }}.${{ steps.git-tool.outputs.Minor }}.${{ steps.git-tool.outputs.Patch }}-${{ steps.git-tool.outputs.PreReleaseLabel }}'
- elif [ "${{ github.ref_name == 'main' || github.ref_name == 'master' }}" = "true" ]; then
- # commits on main/master are alpha's (nightlies) and are considered testing
- # name/major.minor.patch-alpha+build@ultimaker/testing
- echo ${{ github.repository_owner }} | awk '{print "::set-output name=user::"tolower($0)}'
- echo '::set-output name=channel::testing'
- echo '::set-output name=version::${{ steps.git-tool.outputs.Major }}.${{ steps.git-tool.outputs.Minor }}.${{ steps.git-tool.outputs.Patch }}-${{ steps.git-tool.outputs.PreReleaseLabel }}+${{ steps.git-tool.outputs.BuildMetaData }}'
- elif [ "${{ github.ref_name == '${{ steps.git-tool.outputs.Major }}.${{ steps.git-tool.outputs.Minor }}' }}" = "true" ]; then
- # commits on release branches are beta's and are considered stable
- # name/major.minor.patch-beta+build@ultimaker/stable
- # FIXME: For release branches: maybe rename the branch to release/**
- echo ${{ github.repository_owner }} | awk '{print "::set-output name=user::"tolower($0)}'
- echo '::set-output name=channel::stable'
- echo '::set-output name=version::${{ steps.git-tool.outputs.Major }}.${{ steps.git-tool.outputs.Minor }}.${{ steps.git-tool.outputs.Patch }}-${{ steps.git-tool.outputs.PreReleaseLabel }}+${{ steps.git-tool.outputs.BuildMetaData }}'
- elif [ "${{ github.event_name == 'pull_request' }}" = "true" ]; then
- # Event triggered by a pull_request
- echo ${{ github.repository_owner }} | awk '{print "::set-output name=user::"tolower($0)}'
- sanitized_branch=$(echo "${{ github.ref_name }}" | egrep -o "^[^/|_]+")
- echo '::set-output channel=$sanitized_branch'
- echo '::set-output version=${{ steps.git-tool.outputs.Major }}.${{ steps.git-tool.outputs.Minor }}.${{ steps.git-tool.outputs.Patch }}-${{ steps.git-tool.outputs.PreReleaseLabel }}+${{ steps.git-tool.outputs.BuildMetaData }}'
- else
- # commits on other branches are considered unstable and for development purposes only
- # Use the Cura branch naming scheme CURA-1234_foo_bar
- # we use the first 9 characters of the branch name
- # name/major.minor.patch-beta+build@ultimaker/cura_<jira_number>
- echo ${{ github.repository_owner }} | awk '{print "::set-output name=user::"tolower($0)}'
- sanitized_branch=$(echo "${{ github.ref_name }}" | egrep -o "^[^/|_]+")
- echo '::set-output channel=$sanitized_branch'
- echo '::set-output version=${{ steps.git-tool.outputs.Major }}.${{ steps.git-tool.outputs.Minor }}.${{ steps.git-tool.outputs.Patch }}-${{ steps.git-tool.outputs.PreReleaseLabel }}+${{ steps.git-tool.outputs.BuildMetaData }}'
- fi
- - name: Get latest alias
- id: latest-alias
- run: |
- echo "::set-output name=recipe_id_latest::${{ inputs.project_name }}/latest@${{ steps.get-conan-broadcast-data.outputs.user }}/${{ steps.get-conan-broadcast-data.outputs.channel }}"
|