删除冗余的构建工作流文件 build-exe.yml 和 build-exe-Miu.yml

This commit is contained in:
2026-03-15 23:51:22 +08:00
Unverified
parent 8022a69d61
commit 3646908a00
2 changed files with 0 additions and 379 deletions

View File

@@ -1,245 +0,0 @@
name: Build Windows EXE
on:
push:
workflow_dispatch:
env:
APP_NAME: Shortcut_Sync_PotPlayer
PACKAGE_NAME: shortcut-sync-potplayer
PYTHON_VERSION: "3.9.1"
PYTHON_DIR: 'C:\Python391'
PYTHON_EXE: 'C:\Python391\python.exe'
jobs:
build:
runs-on: ubuntu-22.04
steps:
- name: Checkout repository
shell: bash
env:
ACTIONS_TOKEN: ${{ github.token }}
GIT_TERMINAL_PROMPT: 0
run: |
pwd
ls -la
if [ -f main.py ]; then
echo "Repository already available in workspace."
exit 0
fi
if ! command -v git >/dev/null 2>&1; then
sudo apt-get update
sudo apt-get install -y --no-install-recommends git ca-certificates
fi
repo_url="${GITHUB_SERVER_URL}/${GITHUB_REPOSITORY}.git"
if [ ! -d .git ]; then
git init .
fi
git config --global --add safe.directory "$PWD"
if git remote get-url origin >/dev/null 2>&1; then
git remote set-url origin "$repo_url"
else
git remote add origin "$repo_url"
fi
fetch_target() {
local target="$1"
git fetch --depth=1 origin "$target"
}
fetch_with_basic_auth() {
local target="$1"
local username="$2"
local auth_header
auth_header="$(printf '%s:%s' "$username" "${ACTIONS_TOKEN}" | base64 -w0)"
git \
-c http.extraHeader="Authorization: Basic ${auth_header}" \
fetch --depth=1 origin "$target"
}
if fetch_target "${GITHUB_SHA}" || fetch_target "${GITHUB_REF}"; then
echo "Fetched repository without authentication."
elif [ -n "${ACTIONS_TOKEN:-}" ] && (fetch_with_basic_auth "${GITHUB_SHA}" "${GITHUB_ACTOR:-git}" || fetch_with_basic_auth "${GITHUB_REF}" "${GITHUB_ACTOR:-git}"); then
echo "Fetched repository with actor token authentication."
elif [ -n "${ACTIONS_TOKEN:-}" ] && (fetch_with_basic_auth "${GITHUB_SHA}" "oauth2" || fetch_with_basic_auth "${GITHUB_REF}" "oauth2"); then
echo "Fetched repository with oauth2 token authentication."
elif [ -n "${ACTIONS_TOKEN:-}" ] && (fetch_with_basic_auth "${GITHUB_SHA}" "git" || fetch_with_basic_auth "${GITHUB_REF}" "git"); then
echo "Fetched repository with git token authentication."
else
echo "Failed to fetch repository contents from ${repo_url}."
exit 1
fi
git checkout --force FETCH_HEAD
git log -1 --oneline
test -f main.py
- name: Setup Wine
shell: bash
run: |
WINEPREFIX="$RUNNER_TEMP/wine"
echo "WINEPREFIX=$WINEPREFIX" >> "$GITHUB_ENV"
echo "WINEDEBUG=-all" >> "$GITHUB_ENV"
export WINEPREFIX
export WINEDEBUG=-all
sudo dpkg --add-architecture i386
sudo apt-get update
sudo apt-get install -y --no-install-recommends \
wine64 \
wine32 \
curl \
ca-certificates \
jq \
xvfb \
zip
xvfb-run -a wine64 wineboot --init
wineserver -w
wine64 --version
- name: Install Windows Python
shell: bash
run: |
curl -fsSL \
"https://www.python.org/ftp/python/${PYTHON_VERSION}/python-${PYTHON_VERSION}-amd64.exe" \
-o /tmp/python-installer.exe
xvfb-run -a wine64 /tmp/python-installer.exe \
/quiet \
InstallAllUsers=1 \
PrependPath=1 \
Include_pip=1 \
Include_test=0 \
SimpleInstall=1 \
"TargetDir=${PYTHON_DIR}"
wineserver -w
rm -f /tmp/python-installer.exe
xvfb-run -a wine64 "${PYTHON_EXE}" --version
- name: Install dependencies
shell: bash
run: |
xvfb-run -a wine64 "${PYTHON_EXE}" -m pip install --upgrade pip setuptools wheel
if [ -f requirements.txt ]; then
xvfb-run -a wine64 "${PYTHON_EXE}" -m pip install --no-cache-dir -r requirements.txt
fi
xvfb-run -a wine64 "${PYTHON_EXE}" -m pip install --no-cache-dir \
pyinstaller \
keyboard \
pywin32
xvfb-run -a wine64 "${PYTHON_EXE}" -c "import keyboard, win32api, win32gui; print('dependencies ok')"
- name: Build EXE
shell: bash
run: |
xvfb-run -a wine64 "${PYTHON_EXE}" -m PyInstaller \
--noconfirm \
--clean \
--onefile \
--windowed \
--name "${APP_NAME}" \
main.py
test -f "dist/${APP_NAME}.exe"
- name: Package build
id: package
shell: bash
run: |
if [[ "$GITHUB_REF" == refs/tags/* ]]; then
version="$GITHUB_REF_NAME"
else
version="run-${GITHUB_RUN_NUMBER}-${GITHUB_SHA::7}"
fi
archive_name="${APP_NAME}-${version}-windows-x64.zip"
archive_path="dist/${archive_name}"
zip -j "$archive_path" "dist/${APP_NAME}.exe"
echo "version=${version}" >> "$GITHUB_OUTPUT"
echo "archive_name=${archive_name}" >> "$GITHUB_OUTPUT"
echo "archive_path=${archive_path}" >> "$GITHUB_OUTPUT"
- name: Upload package to Gitea Packages
id: publish_package
shell: bash
env:
ACTIONS_TOKEN: ${{ github.token }}
run: |
owner="${GITHUB_REPOSITORY%%/*}"
package_url="${GITHUB_SERVER_URL}/api/packages/${owner}/generic/${PACKAGE_NAME}/${{ steps.package.outputs.version }}/${{ steps.package.outputs.archive_name }}"
curl --fail-with-body --silent --show-error \
-X PUT \
-H "Authorization: token ${ACTIONS_TOKEN}" \
-H "Content-Type: application/zip" \
--upload-file "${{ steps.package.outputs.archive_path }}" \
"$package_url"
echo "package_url=${package_url}" >> "$GITHUB_OUTPUT"
if [ -n "${GITHUB_STEP_SUMMARY:-}" ]; then
echo "Built package: ${package_url}" >> "$GITHUB_STEP_SUMMARY"
fi
- name: Create release on tag
if: startsWith(github.ref, 'refs/tags/')
shell: bash
env:
ACTIONS_TOKEN: ${{ github.token }}
run: |
api_url="${GITHUB_API_URL:-${GITHUB_SERVER_URL}/api/v1}"
releases_url="${api_url}/repos/${GITHUB_REPOSITORY}/releases"
tag_name="${GITHUB_REF_NAME}"
release_name="${tag_name}"
body="Windows build package: ${{ steps.publish_package.outputs.package_url }}"
existing_release_id="$(
curl --silent \
-H "Authorization: token ${ACTIONS_TOKEN}" \
"${releases_url}" | jq -r --arg tag "$tag_name" '.[] | select(.tag_name == $tag) | .id' | head -n 1
)"
if [ -n "$existing_release_id" ] && [ "$existing_release_id" != "null" ]; then
echo "Release already exists for ${tag_name}, skipping creation."
exit 0
fi
payload="$(
jq -n \
--arg tag_name "$tag_name" \
--arg target_commitish "$GITHUB_SHA" \
--arg name "$release_name" \
--arg body "$body" \
'{
tag_name: $tag_name,
target_commitish: $target_commitish,
name: $name,
body: $body,
draft: false,
prerelease: false
}'
)"
curl --fail-with-body --silent --show-error \
-X POST \
-H "Authorization: token ${ACTIONS_TOKEN}" \
-H "Content-Type: application/json" \
-d "$payload" \
"$releases_url" > /dev/null
if [ -n "${GITHUB_STEP_SUMMARY:-}" ]; then
echo "Release created for ${tag_name}" >> "$GITHUB_STEP_SUMMARY"
fi