Wordma CLI 是一个用于管理 wordma 静态博客项目的脚手架工具。
访问 Releases 页面 下载适合你操作系统的预编译二进制文件。
git clone https://github.com/your-username/wordma-cli.git
cd wordma-cli
go build -o wordma.exe
本地开发构建:
# Windows
.\build.bat
# Linux/macOS
chmod +x scripts/build.sh
./scripts/build.sh
发布构建(多平台):
# Windows
.\scripts\build.bat [version]
# Linux/macOS
./scripts/build.sh [version]
💡 版本管理: 构建脚本会自动从 Git Tag 获取版本号。如果当前 commit 有对应的 tag,则使用该 tag;否则使用最新 tag +
-dev
后缀。详见 VERSION.md。
检查当前系统是否安装了必要的依赖工具(nodejs、pnpm、git)。
wordma doctor
在当前目录初始化一个新的 wordma 静态博客项目。
wordma init
这个命令会:
- 从
https://github.com/zwying0814/wordma.git
克隆 main 分支到当前目录 - 保留
.git
目录,方便后续更新模板
注意:此命令不再自动创建 .deploy
目录,请使用 wordma deploy init
来初始化部署目录。
安装项目的所有依赖。
wordma install
# 或
wordma i
启动指定主题的开发服务器。
wordma dev my-theme
等价于在 themes/my-theme
目录下执行 pnpm run dev
。
构建指定主题用于生产环境。
wordma build my-theme
这个命令会:
- 在
themes/my-theme
目录下执行pnpm run build
- 自动重命名构建输出:将
.deploy/.temp
文件夹重命名为主题名称(如.deploy/my-theme
) - 如果目标目录已存在,会先删除旧版本再重命名
- 提供清晰的构建状态反馈
从指定的 git 仓库添加主题到 themes 目录。
wordma add theme https://github.com/user/awesome-theme.git
更新指定主题到最新版本。
wordma update theme my-theme
这个命令会:
- 检查主题是否存在且为 git 仓库
- 自动备份配置文件(config 目录)
- 智能处理本地更改:
- 配置文件更改:保留在工作区,不会被 stash
- 非配置文件更改:自动 stash 以避免冲突
- 混合更改:只 stash 非配置文件,保护配置文件
- 从远程仓库拉取最新代码
- 智能处理配置文件冲突:
- 如果配置文件无变化,自动恢复原配置
- 如果有变化,提供三个选项:
- 保留当前配置(推荐)
- 使用新的默认配置
- 保留备份供手动合并
- 提供恢复非配置更改的指导
配置保护机制确保你的自定义配置永远不会在更新时丢失。
初始化或重新创建 .deploy
目录,通过克隆指定的 Git 仓库。
# 从指定仓库克隆到 .deploy 目录
wordma deploy init https://github.com/zwying0814/my-blog.git
这个命令用于解决意外删除 .deploy
文件夹的问题,会:
- 检查项目根目录(必须包含
package.json
) - 如果
.deploy
目录已存在,提示用户确认是否删除并重新初始化 - 使用
git clone
直接从指定的 Git 仓库克隆到.deploy
目录 - 提供后续部署操作的指引
参数说明:
[git-url]
(可选):远程 Git 仓库的 URL,用于部署推送
使用场景:
- 意外删除了
.deploy
文件夹 - 需要重新初始化部署环境
- 部署目录配置损坏需要重置
- 快速设置部署仓库关联
查看当前 CLI 工具的版本信息。
wordma version
这个命令会显示:
- 当前版本号(从构建时注入)
- 最新可用版本(从 GitHub API 获取)
- 平台信息(操作系统/架构)
- 构建时间和 Git Commit 信息
- 更新提示和下载链接
自动更新 CLI 工具到最新版本。
wordma update
这个命令会:
- 检查当前版本和最新版本
- 自动下载适合当前平台的最新版本
- 替换当前可执行文件
- 验证更新是否成功
注意:
- 开发版本(
dev
或包含-dev
后缀)不支持自动更新 - 需要手动下载正式发布版本
# 更新指定主题
wordma update theme <theme-name>
# 更新所有主题
wordma update theme all
-
检查系统依赖:
wordma doctor
-
初始化项目:
wordma init my-blog cd my-blog
-
安装依赖:
wordma install
-
初始化部署目录:
# 基本初始化 wordma deploy init # 同时设置远程仓库(推荐) wordma deploy init https://github.com/your-username/your-blog.git
-
添加主题(可选):
wordma add theme https://github.com/user/theme.git
-
更新主题(可选):
wordma update theme theme-name
-
启动开发服务器:
wordma dev theme-name
-
构建生产版本:
wordma build theme-name
-
如果意外删除了
.deploy
文件夹,可以重新初始化:# 从指定仓库重新初始化 wordma deploy init https://github.com/your-username/your-blog.git
# 克隆仓库
git clone https://github.com/your-username/wordma-cli.git
cd wordma-cli
# 安装依赖
go mod download
# 运行测试
go test ./...
# 构建
go build -o wordma .
项目使用 GitHub Actions 进行持续集成和部署:
- 开发分支 (dev): 每次推送时运行测试和代码质量检查
- 主分支 (main): 每次推送时构建多平台二进制文件
- 标签 (v)*: 自动创建 GitHub Release 并上传构建产物
- 确保所有更改都已合并到
main
分支 - 创建并推送新的版本标签:
git tag v1.0.0 git push origin v1.0.0
- GitHub Actions 将自动构建并发布新版本
- Linux (amd64, arm64)
- macOS (amd64, arm64)
- Windows (amd64)
- Node.js
- pnpm
- Git
使用 wordma doctor
命令检查这些依赖是否已正确安装。
MIT License - 详见 LICENSE 文件。
欢迎提交 Issue 和 Pull Request!