From a4f286f55ad05d1e9cb48f704bd163fbd0ae4870 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=E5=9B=9B=E6=9C=88?= Date: Mon, 16 Mar 2026 03:31:56 +0800 Subject: [PATCH] =?UTF-8?q?=E6=9B=B4=E6=96=B0=20.github/workflows/build-ex?= =?UTF-8?q?e.yml?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .github/workflows/build-exe.yml | 162 ++++++++++---------------------- 1 file changed, 49 insertions(+), 113 deletions(-) diff --git a/.github/workflows/build-exe.yml b/.github/workflows/build-exe.yml index 7b1ded3..a132e0e 100644 --- a/.github/workflows/build-exe.yml +++ b/.github/workflows/build-exe.yml @@ -1,152 +1,88 @@ -name: Build Windows EXE with Full Image +name: Build Windows EXE with Wine on: push: - # 推荐:只在打标签时触发 Release tags: - - 'v*' # 例如推送 v1.0.0, v2.1.3 等标签时触发 - # 如果你想在每次推送时都创建,也可以保留 branches,但通常会打 tag + - 'v*' branches: ["main"] jobs: build: runs-on: ubuntu-latest steps: - - uses: actions/checkout@v4 + - name: Checkout Code + uses: actions/checkout@v4 - # 步骤1:下载 Python 3.9.9 安装包(保持文件名一致) - - name: Download Python 3.9.9 installer - run: | - wget https://mirrors.tuna.tsinghua.edu.cn/python/3.9.9/python-3.9.9-amd64.exe - ls -lh python-3.9.9-amd64.exe - # 验证文件完整性 - file python-3.9.9-amd64.exe - - - name: Install Xvfb and Dependencies - # 仅在需要时安装,节省初始化时间 + # 步骤 1: 安装必要依赖 (Wine 和 Xvfb) + - name: Install System Dependencies run: | sudo apt-get update - sudo apt-get install -y xvfb libxrender1 libxtst6 libxi6 - - name: Run Java with Xvfb - env: - # 设置虚拟显示器编号 - DISPLAY: :99 - run: | - # 1. 启动 Xvfb(后台运行) - Xvfb :99 -screen 0 1024x768x16 & - - # 2. 运行你的 Java 构建或测试任务 - # xvfb-run 是一个包装命令,它能自动处理显示器的开启和关闭,更推荐 - xvfb-run --auto-servernum ./gradlew test + sudo apt-get install -y xvfb wine64 wine binutils + sudo apt-get clean # 及时清理 apt 缓存节省硬盘空间 - - - name: Reset Wine environment (clean slate) + # 步骤 2: 下载 Python Windows 安装包 + - name: Download Python 3.9.9 + run: | + wget https://mirrors.tuna.tsinghua.edu.cn/python/3.9.9/python-3.9.9-amd64.exe -O python-installer.exe + ls -lh python-installer.exe + + # 步骤 3: 初始化 Wine 环境 + - name: Setup Wine Environment run: | - echo "=== 备份并删除旧的 Wine 配置目录 ===" - # 如果 ~/.wine 目录存在,先重命名备份(或直接删除) - if [ -d "$HOME/.wine" ]; then - mv "$HOME/.wine" "$HOME/.wine.bak.$(date +%s)" - echo "Old .wine directory backed up." - fi - - echo "=== 初始化一个新的干净的Wine环境 ===" - # 初始化Wine环境,使用 xvfb-run 避免任何图形界面问题 - # 设置 WINEARCH 为 win64 以支持64位 export WINEARCH=win64 - xvfb-run wineboot -u - - echo "=== 验证新环境 ===" - # 等待几秒让环境初始化完成 + export WINEPREFIX=$HOME/.wine + # 使用 xvfb-run 启动,避免 GUI 错误 + xvfb-run --auto-servernum wineboot -u sleep 5 - wine --version - xvfb-run wine cmd /c "echo Wine environment is ready" - - # 步骤3:安装 Python(使用正确的文件名) + + # 步骤 4: 在 Wine 中安装 Python - name: Install Python in Wine run: | - echo "Current directory: $(pwd)" - ls -lah + # /quiet 表示静默安装,这是在 CI 环境中运行的关键 + xvfb-run --auto-servernum wine python-installer.exe /quiet InstallAllUsers=1 PrependPath=1 Include_test=0 + sleep 15 + # 安装完后立即删除安装包,释放硬盘 + rm python-installer.exe - if [ ! -f python-3.9.9-amd64.exe ]; then - echo "Installer not found!" + # 步骤 5: 验证并定位 Python 路径 + - name: Verify Python Path + run: | + # 动态查找 python.exe 路径并存入环境变量 + PYTHON_PATH=$(find $HOME/.wine/drive_c -name "python.exe" | head -n 1) + if [ -z "$PYTHON_PATH" ]; then + echo "Python installation failed!" exit 1 fi + echo "PYTHON_EXE=$PYTHON_PATH" >> $GITHUB_ENV + echo "Found Python at: $PYTHON_PATH" + wine "$PYTHON_PATH" --version - # 直接用 wine 运行 - xvfb-run -a wine python-3.9.9-amd64.exe /quiet InstallAllUsers=1 PrependPath=1 Include_test=0 - - # 等待安装 - sleep 20 - - # 步骤4:更彻底地查找 Python - - name: Find and verify Python + # 步骤 6: 安装 Python 依赖 + - name: Install Pip Dependencies run: | - echo "=== Searching all possible Python locations ===" - # 查找所有 python.exe - find /root/.wine/drive_c -name "python.exe" 2>/dev/null | while read path; do - echo "Found: $path" - echo "Version info:" - wine "$path" --version 2>/dev/null || echo "Cannot run $path" - done - - # 尝试常见路径 - COMMON_PATHS=( - "/root/.wine/drive_c/Python39/python.exe" - "/root/.wine/drive_c/Python39-32/python.exe" - "/root/.wine/drive_c/Program Files/Python39/python.exe" - "/root/.wine/drive_c/users/runner/AppData/Local/Programs/Python/Python39/python.exe" - ) - - for path in "${COMMON_PATHS[@]}"; do - if [ -f "$path" ]; then - echo "Found Python at standard location: $path" - PYTHON_EXE="$path" - break - fi - done - - if [ -z "$PYTHON_EXE" ]; then - echo "Python not found in standard locations" - exit 1 - fi - - echo "PYTHON_EXE=$PYTHON_EXE" >> $GITHUB_ENV - wine "$PYTHON_EXE" --version + # 使用清华源加速并节省网络开销 + wine "$PYTHON_EXE" -m pip install --upgrade pip -i https://pypi.tuna.tsinghua.edu.cn/simple + wine "$PYTHON_EXE" -m pip install pyinstaller keyboard pywin32 -i https://pypi.tuna.tsinghua.edu.cn/simple - # 步骤5:安装依赖 - - name: Install dependencies - run: | - # 先配置 pip 使用清华源(或其他国内源) - wine "$PYTHON_EXE" -m pip config set global.index-url https://pypi.tuna.tsinghua.edu.cn/simple - wine "$PYTHON_EXE" -m pip config set install.trusted-host pypi.tuna.tsinghua.edu.cn - # 升级 pip - wine "$PYTHON_EXE" -m pip install --upgrade pip - # 安装包 - wine "$PYTHON_EXE" -m pip install pyinstaller keyboard pywin32 - - # 步骤6:构建 EXE + # 步骤 7: 执行 PyInstaller 构建 - name: Build EXE run: | - wine "$PYTHON_EXE" -m PyInstaller --onefile --windowed --name Shortcut_Sync_PotPlayer main.py + # --clean 参数可以在构建前清理临时文件 + wine "$PYTHON_EXE" -m PyInstaller --onefile --windowed --clean --name Shortcut_Sync_PotPlayer main.py - # 步骤7:上传构建产物(修复版本) + # 步骤 8: 上传 Artifact (Gitea 专用版本) - name: Upload Artifact - uses: christopherhx/gitea-upload-artifact@v4 # 关键修复! + uses: christopherhx/gitea-upload-artifact@v4 with: name: Shortcut_Sync_PotPlayer path: dist/Shortcut_Sync_PotPlayer.exe - - name: Create Release and Upload Asset - # 使用专门为 Gitea 开发的 release action - # 这是一个在 Gitea 生态中广泛使用的版本 [citation:2][citation:5] + # 步骤 9: 发布 Release (仅在推送 tag 时执行) + - name: Create Release + if: startsWith(github.ref, 'refs/tags/') uses: https://gitea.com/actions/release-action@main with: - # 文件路径:指向你 PyInstaller 生成的 EXE 文件 files: dist/Shortcut_Sync_PotPlayer.exe - # API 密钥:使用 Gitea 自动提供的 token,用于认证 api_key: '${{ secrets.GITHUB_TOKEN }}' - # 可选:设置 Release 的标题,默认会使用 tag 名称 name: 'Release ${{ github.ref_name }}' - # 可选:是否为草稿 (true/false) draft: false - # 可选:是否为预发布 (true/false) prerelease: false \ No newline at end of file