脚本更新
This commit is contained in:
@@ -1,19 +1,19 @@
|
||||
#!/bin/bash
|
||||
# SDK Tag 發布腳本 (僅限 main 分支使用)
|
||||
# SDK Tag 發布腳本 (僅限 dev 分支使用)
|
||||
# 用法: ./scripts/publish_sdk.sh <sdk-name> <version>
|
||||
|
||||
# 此腳本執行後的行為說明:
|
||||
# 1.強制分支檢查:如果當前不是 main 分支,腳本會立即報錯終止。
|
||||
# 1.強制分支檢查:如果當前不是 dev 分支,腳本會立即報錯終止。
|
||||
# 2.版本一致性檢查:它會讀取 packages/xxx/pubspec.yaml 裡面的 version 欄位。如果你輸入的參數是 1.1.0 但檔案裡寫的是 1.0.9,腳本會拒絕執行。這強制要求你必須在 PR 階段就正確更新版本號。
|
||||
# 3.同步檢查:它會檢查本地的 main 是否與遠端的 origin/main 一致。這防止你在忘記 git pull 的情況下把 Tag 打在舊的 Commit 上。
|
||||
# 3.同步檢查:它會檢查本地的 dev 是否與遠端的 origin/dev 一致。這防止你在忘記 git pull 的情況下把 Tag 打在舊的 Commit 上。
|
||||
# 4.防重複檢查:如果該 Tag 名稱(例如 networks_sdk/1.1.0)已經存在,腳本會報錯,防止覆蓋發布。
|
||||
# 5.不修改檔案:此腳本不會修改任何代碼,它只負責「蓋章(打 Tag)」和「公告(Push Tag)」。
|
||||
|
||||
#操作流程:
|
||||
# 1.開發:在功能分支開發,手動更新 pubspec.yaml 的版本號。
|
||||
# 2.審核:提交 PR,通過測試與 Code Review,合併進入 main 分支。
|
||||
# 2.審核:提交 PR,通過測試與 Code Review,合併進入 dev 分支。
|
||||
# 3.發布:
|
||||
# •git checkout main
|
||||
# •git checkout dev
|
||||
# •git pull
|
||||
# •執行 melos run publish:sdk:only -- <sdk-name> <version>
|
||||
# 範例:
|
||||
@@ -41,12 +41,12 @@ VERSION=$2
|
||||
PACKAGE_DIR="packages/$SDK_NAME"
|
||||
TAG_NAME="${SDK_NAME}/${VERSION}"
|
||||
|
||||
# 1. 檢查是否在 main 分支
|
||||
# 1. 檢查是否在 dev 分支
|
||||
CURRENT_BRANCH=$(git rev-parse --abbrev-ref HEAD)
|
||||
if [ "$CURRENT_BRANCH" != "main" ]; then
|
||||
echo -e "${RED}錯誤: 此腳本只能在 'main' 分支執行。${NC}"
|
||||
if [ "$CURRENT_BRANCH" != "dev" ]; then
|
||||
echo -e "${RED}錯誤: 此腳本只能在 'dev' 分支執行。${NC}"
|
||||
echo "當前分支為: $CURRENT_BRANCH"
|
||||
echo "請先合併 PR 並切換至 main 分支後再執行。"
|
||||
echo "請先合併 PR 並切換至 dev 分支後再執行。"
|
||||
exit 1
|
||||
fi
|
||||
|
||||
@@ -67,13 +67,13 @@ if [ "$FILE_VERSION" != "$VERSION" ]; then
|
||||
exit 1
|
||||
fi
|
||||
|
||||
# 4. 檢查遠端是否有更新 (確保本地 main 是最新的)
|
||||
# 4. 檢查遠端是否有更新 (確保本地 dev 是最新的)
|
||||
echo -e "${CYAN}正在檢查遠端狀態...${NC}"
|
||||
git fetch origin
|
||||
LOCAL=$(git rev-parse HEAD)
|
||||
REMOTE=$(git rev-parse origin/main)
|
||||
REMOTE=$(git rev-parse origin/dev)
|
||||
if [ "$LOCAL" != "$REMOTE" ]; then
|
||||
echo -e "${RED}錯誤: 本地 main 分支落後於遠端,請先執行 git pull。${NC}"
|
||||
echo -e "${RED}錯誤: 本地 dev 分支落後於遠端,請先執行 git pull。${NC}"
|
||||
exit 1
|
||||
fi
|
||||
|
||||
@@ -89,7 +89,7 @@ echo -e "${GREEN}========================================${NC}"
|
||||
echo "SDK Name: $SDK_NAME"
|
||||
echo "Version: $VERSION"
|
||||
echo "Tag: $TAG_NAME"
|
||||
echo "Branch: main"
|
||||
echo "Branch: dev"
|
||||
echo -e "${GREEN}========================================${NC}"
|
||||
|
||||
# 確認訊息
|
||||
|
||||
Reference in New Issue
Block a user