action! 我不认输9

This commit is contained in:
2026-01-03 16:25:56 +08:00
parent c521ba24a4
commit 87b698c4c6

View File

@@ -5,63 +5,65 @@ on:
workflow_dispatch: workflow_dispatch:
inputs: inputs:
version: version:
description: '版本号 (例如: v1.0.0, 1.0.0, v2.0.0-beta.1)' description: '版本号 (例如: v1.0.0)'
required: true required: true
default: 'dev-build' default: 'dev-build'
jobs: jobs:
build-linux-x64: build-linux-x64:
runs-on: ubuntu runs-on: ubuntu
# 关键修复1使用 host 网络模式,容器与宿主机共享网络栈
container: container:
image: ubuntu:22.04 image: ubuntu:22.04
options: --dns 223.5.5.5 --dns 223.6.6.6 # DNS配置保留用于后续可能的需求 options: --network=host
steps: steps:
# 1. 安装系统必要工具 # 1. 安装基础工具
- name: 安装基础工具 - name: 安装基础工具
run: | run: |
apt-get update apt-get update
apt-get install -y wget xz-utils tar git # 添加了 xz-utils 用于解压 apt-get install -y wget xz-utils tar git
echo 基础工具安装完成。 echo "基础工具安装完成。"
# 2. 【关键修复】离线安装xmake # 2. 【关键修复】离线安装xmake (修正版)
- name: 安装xmake - name: 安装xmake
run: | run: |
echo === 开始离线安装 xmake ===" echo "=== 开始安装 xmake ==="
# 方案1优先尝试从Ubuntu官方仓库安装最稳定无需外网 # 尝试从系统仓库安装现在网络通了应该能访问Ubuntu官方源
if apt-get install -y xmake 2>/dev/null; then if apt-get install -y xmake 2>/dev/null; then
echo [成功] 通过系统包管理器安装 xmake。 echo "[成功] 通过系统包管理器安装 xmake。"
else else
echo 系统仓库未提供 xmake尝试方案2... echo "系统仓库安装失败或版本太旧,尝试下载预编译包..."
# 方案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"
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} echo "尝试从固定地址下载: ${PACKAGE_URL}"
if wget -q --timeout=30 --tries=3 -O xmake.tar.gz “${PACKAGE_URL}”; then # 设置超时和重试
echo “[成功] 下载预编译包完成。” if wget -q --timeout=30 --tries=3 -O xmake.tar.gz "${PACKAGE_URL}"; then
echo "[成功] 下载预编译包完成。"
tar -xzf xmake.tar.gz tar -xzf xmake.tar.gz
cd xmake-* || cd xmake.* cd xmake-* 2>/dev/null || cd xmake.* 2>/dev/null
./install ./install
cd .. cd ..
else else
# 方案3最终保底方案需要你预先准备 echo "[错误] 预编译包下载失败。这通常意味着容器网络即使是host模式仍无法访问GitHub。"
echo “[严重] 所有远程安装方式均失败。” echo "最后的保底方案:请将 'xmake-v2.9.8.linux-x86_64.tar.gz' 预先放置在仓库根目录,并取消下方注释。"
echo “请将 xmake 的预编译包 (xmake-v*.linux-x86_64.tar.gz) 放置在仓库根目录,并取消下方注释。” # 取消以下4行注释以启用完全离线的最终方案
# 如果以上都失败,最后的保底方案是使用你预置在仓库里的包
# tar -xzf xmake-v2.9.8.linux-x86_64.tar.gz # tar -xzf xmake-v2.9.8.linux-x86_64.tar.gz
# cd xmake-v2.9.8.linux-x86_64 # cd xmake-v2.9.8.linux-x86_64
# ./install # ./install
# cd .. # cd ..
# 如果启用了上方离线方案,请将下一行的 exit 1 注释掉
exit 1 exit 1
fi fi
fi fi
echo “=== xmake 安装完成 ===" # 验证安装
xmake --version echo "=== 验证 xmake 安装 ==="
/usr/local/bin/xmake --version || $HOME/.local/bin/xmake --version || xmake --version
echo "=== xmake 安装阶段完成 ==="
# 3. 检出代码 # 3. 检出代码
- name: 检出代码 - name: 检出代码
@@ -72,69 +74,59 @@ 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. 构建项目
- name: 构建项目 - name: 构建项目
run: | run: |
export PATH=“$HOME/.local/bin:/usr/local/bin:$PATH” # 确保在PATH中找到xmake
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. 打包
- name: 打包发布文件 - name: 打包发布文件
run: | run: |
export PATH=$HOME/.local/bin:/usr/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
if [ -d “src/Module/Library” ]; then cp -r src/Module/Library "${PACKAGE_NAME}/"
cp -r src/Module/Library “${PACKAGE_NAME}/” echo "已包含Library目录。"
echo “已包含Library目录。”
else
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
# 7. 发布到Gitea Releases # 7. 发布到Gitea
- name: 发布到Gitea - name: 发布到Gitea
env: env:
GITEA_TOKEN: ${{ secrets.CI_TOKEN }} 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 }} API="https://git.fig-lang.cn/api/v1/repos/${{ github.repository }}"
echo “正在为版本 $VERSION 创建或更新Release...” curl -sS -X POST -H "Authorization: token $GITEA_TOKEN" \
curl -sSf -X POST \ -H "Content-Type: application/json" \
-H “Authorization: token $GITEA_TOKEN” \ -d "{\"tag_name\":\"$VERSION\",\"name\":\"Fig $VERSION\"}" \
-H “Content-Type: application/json” \ "$API/releases" 2>/dev/null || true
-d “{\“tag_name\”:\”$VERSION\“, \“name\”:\”Fig $VERSION\“, \“draft\”: false, \“prerelease\”: false}” \
“${REPO_API}/releases” 2>/dev/null || echo “Release可能已存在继续上传。”
echo “正在上传构建产物...” curl -sS -X POST -H "Authorization: token $GITEA_TOKEN" \
curl -sSf -X POST \ -H "Content-Type: application/octet-stream" \
-H “Authorization: token $GITEA_TOKEN” \ --data-binary @Fig-$VERSION-linux-x86_64.tar.gz \
-H “Content-Type: application/octet-stream” \ "$API/releases/$VERSION/assets?name=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”
curl -sSf -X POST \ curl -sS -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 \ "$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 "✅ 发布完成!"