Revert "修改自动编译版本号生成逻辑"

This reverts commit 94b9516a4e.
This commit is contained in:
orz12
2024-05-25 12:06:43 +08:00
parent 94b9516a4e
commit d2c47d6a94
2 changed files with 21 additions and 57 deletions

View File

@@ -4,7 +4,7 @@ on:
workflow_dispatch:
push:
branches:
- 'main'
- '*'
paths-ignore:
- '**.md'
- '**.txt'
@@ -23,46 +23,19 @@ jobs:
steps:
- name: Checkout code
uses: actions/checkout@v4
with:
fetch-depth: 0
#- name: 获取first parent commit次数
# id: get-first-parent-commit-count
# run: |
# version=$(yq e .version pubspec.yaml | cut -d "+" -f 1)
# recent_release_tag=$(git tag -l | grep $version | egrep -v "[-|+]" || true)
# if [[ "x$recent_release_tag" == "x" ]]; then
# echo "当前版本tag不存在请手动生成tag."
# exit 1
# fi
# git log --oneline HEAD
# first_parent_commit_count=$(git rev-list --first-parent --count $recent_release_tag..HEAD)
# echo "count=$first_parent_commit_count" >> $GITHUB_OUTPUT
- name: 从tag获取之前的version_code与beta版本号
id: get-previous-codes
run: |
version=$(yq e .version pubspec.yaml | cut -d "+" -f 1)
last_tag=$(git describe --tags | awk -F"-" '{for(i=1;i<=NF-2;i++) printf "%s", $i}')
echo $last_tag | grep "+" || echo "Tag格式不正确" && exit 1
echo $last_tag | grep $version || echo "当前版本tag不存在请手动添加tag." && exit 1
version_code=$(echo $last_tag | cut -d "+" -f 2)
beta_code=0$(echo $last_tag | cut -d "+" -f 1 | cut -d "." -f 4)
echo "beta-code=$beta_code" >> $GITHUB_OUTPUT
echo "version-code=$version_code" >> $GITHUB_OUTPUT
uses: actions/checkout@v2
- name: 更新版本号
id: version
run: |
# 读取版本号
version_name=$(yq e .version pubspec.yaml | cut -d "+" -f 1)
let beta_code=${{ steps.get-previous-codes.outputs.beta-code }}+1
let version_code=${{ steps.get-previous-codes.outputs.version-code }}+1
VERSION=$(yq e .version pubspec.yaml)
# 获取GitHub Actions的run_number
RUN_NUMBER=${{ github.run_number }}
# 构建新版本号
NEW_VERSION=${version_name}-beta.${beta_code}+${version_code}
NEW_VERSION=$(echo $VERSION | awk -F+ -v run_number="$RUN_NUMBER" '{print $1"+"run_number}')
# 输出新版本号
echo "New version: $NEW_VERSION"
@@ -132,10 +105,9 @@ jobs:
- name: 重命名应用
run: |
version_name=$(yq e .version pubspec.yaml | cut -d "+" -f 1)
for file in build/app/outputs/flutter-apk/app-*.apk; do
if [[ $file =~ app-(.?*)release.apk ]]; then
new_file_name="build/app/outputs/flutter-apk/Pili-${BASH_REMATCH[1]}${version_name}.apk"
new_file_name="build/app/outputs/flutter-apk/Pili-${BASH_REMATCH[1]}${{ needs.update_version.outputs.new_version }}.apk"
mv "$file" "$new_file_name"
fi
done
@@ -177,9 +149,9 @@ jobs:
- name: 重命名应用
run: |
version_name=$(yq e .version pubspec.yaml | cut -d "+" -f 1)
DATE=${{ steps.date.outputs.date }}
for file in app.ipa; do
new_file_name="build/Pili-${version_name}.ipa"
new_file_name="build/Pili-${{ needs.update_version.outputs.new_version }}.ipa"
mv "$file" "$new_file_name"
done