1
0
mirror of synced 2024-11-30 18:24:32 +01:00

Revert "workflow - iterate for each pushed commit; fix deprecation; prevent extra empty lines (#741)"

This reverts commit db426c9647.
This commit is contained in:
0auBSQ 2024-11-04 20:33:23 +09:00
parent 44b2636895
commit 91adef7922

View File

@ -16,13 +16,9 @@ jobs:
# added or changed files to the repository. # added or changed files to the repository.
contents: write contents: write
env:
messagePathPrefix: COMMIT_MSG_
versionsPath: COMMIT_VERSIONS
steps: steps:
- name: Checkout Repository - name: Checkout Repository
uses: actions/checkout@v4 uses: actions/checkout@v2
- name: Setup .NET - name: Setup .NET
uses: actions/setup-dotnet@v4 uses: actions/setup-dotnet@v4
@ -34,151 +30,91 @@ jobs:
run: | run: |
dir dir
- name: Get each commit message for version checking - name: Get commit subject for version checking
id: get-latest-commits id: get-latest-commit
run: | run: |
$messages = ConvertFrom-Json $env:messagesJson $latestCommitMessage = git log -1 --pretty=format:%s
$nMessages = $messages.Count echo "::set-output name=latest_commit_message::$latestCommitMessage"
echo "nMessages=$nMessages" >> $env:GITHUB_ENV
for ($c = 0; $c -lt $nMessages; ++$c) {
New-Item -Path ($env:messagePathPrefix + $c) -Type file
$message = $messages | Select-Object -Index $c
echo $message > ($env:messagePathPrefix + $c)
}
env:
messagesJson: ${{ toJSON(github.event.commits.*.message) }}
- name: Get project version - name: Extract version from commit message
id: extract-version
run: |
if ('${{ steps.get-latest-commit.outputs.latest_commit_message }}' -match '^(?<version>[0-9]+\.[0-9]+\.[0-9]+\.[0-9]+)\s-\s') {
$version = $matches['version']
Write-Host "Extracted version is: $version"
echo "::set-output name=version::$version"
} else {
Write-Host "No valid version found in the latest commit message. Skipping bump."
echo "::set-output name=version::"
}
- name: Bump OpenTaiko version if necessary
if: steps.extract-version.outputs.version != ''
run: |
$newVersion = "${{ steps.extract-version.outputs.version }}"
Write-Host "Updating version in OpenTaiko.csproj to $newVersion"
(Get-Content OpenTaiko/OpenTaiko.csproj) -replace '<Version>.*<\/Version>', "<Version>$newVersion</Version>" | Set-Content OpenTaiko/OpenTaiko.csproj
- name: Get version
uses: kzrnm/get-net-sdk-project-versions-action@v2 uses: kzrnm/get-net-sdk-project-versions-action@v2
id: get-version id: get-version
with: with:
proj-path: OpenTaiko/OpenTaiko.csproj proj-path: OpenTaiko/OpenTaiko.csproj
- name: Store projectVersion in environment
run: |
echo "projectVersion=${{ steps.get-version.outputs.version }}" >> $env:GITHUB_ENV
- name: Extract latest version info from each commit message
id: extract-versions
run: |
$hasVersion = $false
$version = $env:projectVersion
New-Item -Path $env:versionsPath -Type file
for ($c = 0; $c -lt $env:nMessages; ++$c) {
$commitSubject = Get-Content -Path ($env:messagePathPrefix + $c) | Select-Object -First 1
if ($commitSubject -match '^(?<version>[0-9]+\.[0-9]+\.[0-9]+\.[0-9]+)\s-\s') {
$hasVersion = $true
$version = $matches['version']
}
if ($c -eq 0) {
echo "versionFirst=$version" >> $env:GITHUB_ENV
}
echo $version >> $env:versionsPath
}
# check the latest version
if ($hasVersion) {
Write-Host "Extracted latest version is: $version"
echo "version=$version" >> $env:GITHUB_ENV
} else {
Write-Host "No valid version found in the latest commit messages. Skipping bump."
echo "version=" >> $env:GITHUB_ENV
}
echo "versionLast=$version" >> $env:GITHUB_ENV
- name: Bump OpenTaiko version if necessary
if: env.version != ''
run: |
$newVersion = $env:version
Write-Host "Updating version in OpenTaiko.csproj to $newVersion"
(Get-Content OpenTaiko/OpenTaiko.csproj) -replace '<Version>.*<\/Version>', "<Version>$newVersion</Version>" | Set-Content OpenTaiko/OpenTaiko.csproj
- name: Get current date - name: Get current date
id: get-date id: get-date
run: | run: |
$date = Get-Date -Format "yyyy-MM-dd" $date = Get-Date -Format "yyyy-MM-dd"
echo "date=$date" >> $env:GITHUB_ENV echo "::set-output name=date::$date"
- name: Get changelogs from commit description
id: get-commit-message
run: |
$message = git log -1 --pretty=%b
$messagePath = 'COMMIT_MSG'
echo $message >> $messagePath
echo "messagePath=$messagePath" >> $env:GITHUB_ENV
- name: Update CHANGELOG.md - name: Update CHANGELOG.md
run: | run: |
$versions = Get-Content -Path $env:versionsPath $version = '${{steps.get-version.outputs.version}}'
$date = $env:date $date = '${{steps.get-date.outputs.date}}'
$messagePath = $env:messagePath
$changelogPath = "CHANGELOG.md" $changelogPath = "CHANGELOG.md"
:commit for ($c = 0; $c -lt $env:nMessages; ++$c) { # Read commit description content
# (Re-)read CHANGELOG.md content as (re-)split lines $messageLines = Get-Content -Path $messagePath
$changelog = Get-Content -Path $changelogPath
# Ensure list type for []-indexing
if ($changelog.Count -eq 1) {
$changelog = , $changelog
}
# Read the message as individual items # Read CHANGELOG.md content
$commitBody = Get-Content -Path ($env:messagePathPrefix + $c) | Select-Object -Skip 1 $changelog = Get-Content -Path $changelogPath
# Remove empty lines from the message # Remove empty lines from the message
$message = ($commitBody | Where-Object { $_ -ne "" }) -join "`n" $message = ($messageLines | Where-Object { $_ -ne "" }) -join "`n"
# Check if the version already exists # Check if the version already exists
$version = $versions | Select-Object -Index $c if ($changelog -match "## \[$version\]") {
for ($i = 0; $i -lt $changelog.Count; ++$i) { if ($message) {
if (-not ($changelog[$i] -match "## \[$version\]")) {
continue
}
# Capture the existing content under the version heading # Capture the existing content under the version heading
if ($message) { $changelog = $changelog -replace "(## \[($version)\] .* \(Beta\))", "`$1`n`n$message"
# Append after the empty line (if exist) or the heading
$di = ($changelog[$i + 1] -eq "")
$changelog[$i + $di] += "`n$message"
}
# Write updated content back to CHANGELOG.md
Set-Content -Path $changelogPath -Value $changelog
continue commit
} }
} else {
# Insert new version under '# Changelog' # Insert new version under '# Changelog'
for ($i = 0; $i -lt $changelog.Count; ++$i) { $changelog = $changelog -replace "(# Changelog)", "`$1`n`n## [$version] - $date (Beta)`n`n$message"
if (-not ($changelog[$i] -match "# Changelog")) {
continue
}
# Append after the title, create empty line space
$changelog[$i] += "`n`n## [$version] - $date (Beta)`n`n"
if ($message) {
$changelog[$i] += "$message`n"
}
# Remove original empty line space
while (++$i -lt $changelog.Count) {
if ($changelog[$i] -ne "") {
break
}
$changelog[$i] = $null
}
# Write updated content back to CHANGELOG.md
Set-Content -Path $changelogPath -Value $changelog
continue commit
}
# No '# Changelog', do nothing
break commit
} }
# Write updated content back to CHANGELOG.md
Set-Content -Path $changelogPath -Value $changelog
- name: Commit CHANGELOG.md and OpenTaiko.csproj changes - name: Commit CHANGELOG.md and OpenTaiko.csproj changes
run: | run: |
git config --global user.name "github-actions" git config --global user.name "github-actions"
git config --global user.email "actions@github.com" git config --global user.email "actions@github.com"
git add OpenTaiko/OpenTaiko.csproj git add OpenTaiko/OpenTaiko.csproj
git add CHANGELOG.md git add CHANGELOG.md
if ($env:versionLast -eq $env:versionFirst) { git commit -m "Update changelog for version ${{steps.get-version.outputs.version}}"
git commit -m "Update changelog for version $env:versionLast"
} else {
git commit -m "Update changelog for versions $env:versionFirst to $env:versionLast"
}
git push https://x-access-token:${{ secrets.GITHUB_TOKEN }}@github.com/${{ github.repository }} HEAD:${{ github.ref }} git push https://x-access-token:${{ secrets.GITHUB_TOKEN }}@github.com/${{ github.repository }} HEAD:${{ github.ref }}
- name: Build for Windows x64 - name: Build for Windows x64
shell: cmd shell: cmd
run: | run: |
@ -209,16 +145,16 @@ jobs:
uses: mukunku/tag-exists-action@v1.6.0 uses: mukunku/tag-exists-action@v1.6.0
id: check-tag id: check-tag
with: with:
tag: ${{ env.projectVersion }} tag: "${{steps.get-version.outputs.version}}"
- name: Create Release - name: Create Release
if: steps.check-tag.outputs.exists == 'false' && env.version != '' if: steps.check-tag.outputs.exists == 'false'
uses: actions/create-release@v1 uses: actions/create-release@v1
env: env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
with: with:
tag_name: ${{ env.projectVersion }} tag_name: "${{steps.get-version.outputs.version}}"
release_name: OpenTaiko v${{ env.projectVersion }} release_name: OpenTaiko v${{steps.get-version.outputs.version}}
body: | body: |
Note: The releases do not contain skins nor songs. Note: The releases do not contain skins nor songs.
Please download/update through the OpenTaiko Hub: https://github.com/OpenTaiko/OpenTaiko-Hub/releases Please download/update through the OpenTaiko Hub: https://github.com/OpenTaiko/OpenTaiko-Hub/releases
@ -226,10 +162,10 @@ jobs:
prerelease: false prerelease: false
- name: Upload All Builds - name: Upload All Builds
uses: xresloader/upload-to-github-release@v1.6.0 uses: xresloader/upload-to-github-release@v1.4.2
with: with:
file: "OpenTaiko.Win.x64.zip;OpenTaiko.Linux.x64.zip" file: "OpenTaiko.Win.x64.zip;OpenTaiko.Linux.x64.zip"
overwrite: true overwrite: true
tag_name: ${{ env.projectVersion }} tag_name: "${{steps.get-version.outputs.version}}"
draft: false draft: false
token: ${{ secrets.GITHUB_TOKEN }} token: ${{ secrets.GITHUB_TOKEN }}