action! 我不认输8

This commit is contained in:
2026-01-03 16:19:03 +08:00
parent 52b9896288
commit c521ba24a4

View File

@@ -1,7 +1,7 @@
name: Release Build name: Release Build
on: on:
push: push:
tags: ['*'] # 自动任何Tag推送触发 tags: ['*']
workflow_dispatch: workflow_dispatch:
inputs: inputs:
version: version:
@@ -14,29 +14,53 @@ jobs:
runs-on: ubuntu runs-on: ubuntu
container: container:
image: ubuntu:22.04 image: ubuntu:22.04
# 关键修复配置容器使用国内可靠DNS解决无法解析github.com的问题 options: --dns 223.5.5.5 --dns 223.6.6.6 # DNS配置保留用于后续可能的需求
options: --dns 223.5.5.5 --dns 223.6.6.6
steps: steps:
# 1. 安装系统必要工具 # 1. 安装系统必要工具
- name: 安装基础工具 - name: 安装基础工具
run: | run: |
apt-get update apt-get update
apt-get install -y curl git tar apt-get install -y wget xz-utils tar git # 添加了 xz-utils 用于解压
echo "基础工具安装完成。" echo 基础工具安装完成。
# 2. 极速安装xmake (网络修复后优先官方脚本) # 2. 【关键修复】离线安装xmake
- name: 安装xmake - name: 安装xmake
run: | run: |
echo "正在安装xmake..." echo “=== 开始离线安装 xmake ==="
if curl -fsSL https://xmake.io/shget.text -o /tmp/install.sh; then
echo "使用官方脚本安装..." # 方案1优先尝试从Ubuntu官方仓库安装最稳定无需外网
bash /tmp/install.sh if apt-get install -y xmake 2>/dev/null; then
echo “[成功] 通过系统包管理器安装 xmake。”
else else
echo "官方源备用方案失败,使用包管理器安装..." echo “系统仓库未提供 xmake尝试方案2...
apt-get update && apt-get install -y xmake # 方案2手动下载并安装一个已知版本的预编译二进制包
# 这里使用一个版本号固定的、无需联网查询的下载地址
# 如果这个地址也失败,说明容器完全无外网,只能使用预置包。
INSTALL_VERSION=“v2.9.8”
PACKAGE_URL=“https://github.com/xmake-io/xmake/releases/download/${INSTALL_VERSION}/xmake-${INSTALL_VERSION}.linux-x86_64.tar.gz”
echo “尝试从固定地址下载: ${PACKAGE_URL}”
if wget -q --timeout=30 --tries=3 -O xmake.tar.gz “${PACKAGE_URL}”; then
echo “[成功] 下载预编译包完成。”
tar -xzf xmake.tar.gz
cd xmake-* || cd xmake.*
./install
cd ..
else
# 方案3最终保底方案需要你预先准备
echo “[严重] 所有远程安装方式均失败。”
echo “请将 xmake 的预编译包 (xmake-v*.linux-x86_64.tar.gz) 放置在仓库根目录,并取消下方注释。”
# 如果以上都失败,最后的保底方案是使用你预置在仓库里的包
# tar -xzf xmake-v2.9.8.linux-x86_64.tar.gz
# cd xmake-v2.9.8.linux-x86_64
# ./install
# cd ..
exit 1
fi
fi fi
echo "$HOME/.local/bin" >> $GITHUB_PATH
echo “=== xmake 安装完成 ==="
xmake --version xmake --version
# 3. 检出代码 # 3. 检出代码
@@ -48,77 +72,69 @@ jobs:
# 4. 确定版本号 # 4. 确定版本号
- name: 设置版本 - name: 设置版本
run: | run: |
if [ "${{ github.event_name }}" = "workflow_dispatch" ]; then if [ ${{ github.event_name }} = workflow_dispatch ]; then
VERSION="${{ inputs.version }}" VERSION=${{ inputs.version }}
else else
VERSION="${GITHUB_REF#refs/tags/}" VERSION=${GITHUB_REF#refs/tags/}
fi fi
echo "构建版本: $VERSION" echo 构建版本: $VERSION
echo "VERSION=$VERSION" >> $GITHUB_ENV echo VERSION=$VERSION >> $GITHUB_ENV
# 5. 构建项目 (Linux x86_64) # 5. 构建项目 (Linux x86_64)
- name: 构建项目 - name: 构建项目
run: | run: |
export PATH="$HOME/.local/bin:$PATH" export PATH=$HOME/.local/bin:/usr/local/bin:$PATH
xmake f -p linux -a x86_64 -m release -y xmake f -p linux -a x86_64 -m release -y
xmake build -j$(nproc) xmake build -j$(nproc)
echo "构建成功。" echo 构建成功。
# 6. 打包 (包含Library目录) # 6. 打包 (包含Library目录)
- name: 打包发布文件 - name: 打包发布文件
run: | run: |
export PATH="$HOME/.local/bin:$PATH" export PATH=$HOME/.local/bin:/usr/local/bin:$PATH
PACKAGE_NAME="Fig-${{ env.VERSION }}-linux-x86_64" PACKAGE_NAME=Fig-${{ env.VERSION }}-linux-x86_64
mkdir -p "${PACKAGE_NAME}" mkdir -p ${PACKAGE_NAME}
# 复制可执行文件 cp build/linux/x86_64/release/Fig “${PACKAGE_NAME}/”
cp build/linux/x86_64/release/Fig "${PACKAGE_NAME}/" if [ -d “src/Module/Library” ]; then
# 复制Library目录如果存在 cp -r src/Module/Library “${PACKAGE_NAME}/”
if [ -d "src/Module/Library" ]; then echo “已包含Library目录。”
cp -r src/Module/Library "${PACKAGE_NAME}/"
echo "已包含Library目录。"
else else
echo "未找到Library目录跳过。" echo 未找到Library目录跳过。
fi fi
# 创建压缩包和校验和 tar -czf “${PACKAGE_NAME}.tar.gz” “${PACKAGE_NAME}”
tar -czf "${PACKAGE_NAME}.tar.gz" "${PACKAGE_NAME}" sha256sum “${PACKAGE_NAME}.tar.gz” > “${PACKAGE_NAME}.sha256”
sha256sum "${PACKAGE_NAME}.tar.gz" > "${PACKAGE_NAME}.sha256"
echo "打包完成:" echo 打包完成:
ls -lh Fig-*.tar.gz Fig-*.sha256 ls -lh Fig-*.tar.gz Fig-*.sha256
# 7. 发布到Gitea Releases # 7. 发布到Gitea Releases
- name: 发布到Gitea - name: 发布到Gitea
env: env:
GITEA_TOKEN: ${{ secrets.CI_TOKEN }} # 需在仓库Secrets中配置 GITEA_TOKEN: ${{ secrets.CI_TOKEN }}
run: | run: |
VERSION="${{ env.VERSION }}" VERSION=${{ env.VERSION }}
REPO_API="https://git.fig-lang.cn/api/v1/repos/${{ github.repository }}" REPO_API=https://git.fig-lang.cn/api/v1/repos/${{ github.repository }}
echo "正在为版本 $VERSION 创建或更新Release..." echo 正在为版本 $VERSION 创建或更新Release...
# 创建Release如果已存在则忽略错误
curl -sSf -X POST \ curl -sSf -X POST \
-H "Authorization: token $GITEA_TOKEN" \ -H Authorization: token $GITEA_TOKEN \
-H "Content-Type: application/json" \ -H Content-Type: application/json \
-d "{\"tag_name\":\"$VERSION\", \"name\":\"Fig $VERSION\", \"draft\": false, \"prerelease\": false}" \ -d {\tag_name\:\$VERSION\, \name\:\Fig $VERSION\, \draft\: false, \prerelease\: false} \
"${REPO_API}/releases" 2>/dev/null || echo "Release可能已存在继续上传。" ${REPO_API}/releases 2>/dev/null || echo Release可能已存在继续上传。
echo "正在上传构建产物..." echo 正在上传构建产物...
# 上传主程序包
curl -sSf -X POST \ curl -sSf -X POST \
-H "Authorization: token $GITEA_TOKEN" \ -H Authorization: token $GITEA_TOKEN \
-H "Content-Type: application/octet-stream" \ -H Content-Type: application/octet-stream \
--data-binary @Fig-${VERSION}-linux-x86_64.tar.gz \ --data-binary @Fig-${VERSION}-linux-x86_64.tar.gz \
"${REPO_API}/releases/${VERSION}/assets?name=Fig-${VERSION}-linux-x86_64.tar.gz" ${REPO_API}/releases/${VERSION}/assets?name=Fig-${VERSION}-linux-x86_64.tar.gz
# 上传校验文件
curl -sSf -X POST \ curl -sSf -X POST \
-H "Authorization: token $GITEA_TOKEN" \ -H Authorization: token $GITEA_TOKEN \
-H "Content-Type: text/plain" \ -H Content-Type: text/plain \
--data-binary @Fig-${VERSION}-linux-x86_64.sha256 \ --data-binary @Fig-${VERSION}-linux-x86_64.sha256 \
"${REPO_API}/releases/${VERSION}/assets?name=Fig-${VERSION}-linux-x86_64.sha256" ${REPO_API}/releases/${VERSION}/assets?name=Fig-${VERSION}-linux-x86_64.sha256
echo "✅ 发布流程完成!" echo ✅ 发布流程完成!
echo "版本: Fig $VERSION"
echo "文件: Fig-${VERSION}-linux-x86_64.tar.gz"