开发前须知
开发前须知
Github Pull Request 流程简述
我不懂编程,只是想改一点点 JSON 文件/文档等,要怎么操作?
欢迎收看 牛牛也能看懂的 GitHub Pull Request 使用指南 (纯网页端操作 Github.com)
我会编程,但没接触过 GitHub/C++/……,要怎么操作?
如果很久以前 fork 过,先在自己仓库的
Settings
里,翻到最下面,删除打开 MAA 主仓库,点击
Fork
,继续点击Create fork
克隆你自己仓库下的 dev 分支到本地,并拉取子模块
git clone --recurse-submodules <你的仓库的 git 链接> -b dev
注意
如果正在使用 Visual Studio 等不附带
--recurse-submodules
参数的 Git GUI,则需在克隆后再执行git submodule update --init
以拉取子模块。下载预构建的第三方库
需要有 Python 环境,请自行搜索 Python 安装教程
(maadeps-download.py 文件在项目根目录)python maadeps-download.py
配置编程环境
- 下载并安装
Visual Studio 2022 community
, 安装的时候需要选中基于c++的桌面开发
和.NET桌面开发
。
- 下载并安装
双击打开
MAA.sln
文件,Visual Studio 会自动加载整个项目。设置 VS
- VS 上方配置选择
RelWithDebInfo
x64
(如果编译 Release 包 或 ARM 平台,请忽略这步) - 右键
MaaWpfGui
- 属性 - 调试 - 启用本地调试(这样就能把断点挂到 C++ Core 那边了)
- VS 上方配置选择
到这里,你就可以愉快地
瞎 JB 改发电了开发过程中,每一定数量,记得提交一个 commit, 别忘了写上 message
假如你不熟悉 git 的使用,你可能想要新建一个分支进行更改,而不是直接提交在dev
上git branch your_own_branch git checkout your_own_branch
这样你的提交就能在新的分支上生长,不会受到
dev
更新的打扰完成开发后,推送你修改过的本地分支(以
dev
为例)到远程(fork 的仓库)git push origin dev
打开 MAA 主仓库。提交一个 pull request,等待管理员通过。别忘了你是在 dev 分支上修改,别提交到 master 分支去了
当 MAA 原仓库出现更改(别人做的),你可能需要把这些更改同步到你的分支
关联 MAA 原仓库
git remote add upstream https://github.com/MaaAssistantArknights/MaaAssistantArknights.git
从 MAA 原仓库拉取更新
git fetch upstream
变基(推荐)或者合并修改
git rebase upstream/dev # 变基
或者
git merge # 合并
重复上述 7, 8, 9, 10 中的操作
提示
在打开 VS2022 之后,和 git 有关的操作可以不用命令行工具,直接使用 vs 自带的“Git 更改”即可
MAA 的文件格式化要求
MAA 使用一系列的格式化工具来保证仓库中的代码和资源文件美观统一,以便于维护和阅读
请确保在提交之前已经格式化,或是启用 Pre-commit Hooks 来进行自动格式化
目前启用的格式化工具如下:
文件类型 | 格式化工具 |
---|---|
C++ | clang-format |
Json/Yaml | Prettier |
Markdown | markdownlint |
利用 Pre-commit Hooks 自动进行代码格式化
确保你的电脑上有 Python 与 Node 环境
在项目根目录下执行以下命令
pip install pre-commit pre-commit install
如果pip安装后依然无法运行pre-commit,请确认pip安装地址已被添加到PATH
接下来,每次提交时都将会自动运行格式化工具,来确保你的代码格式符合规范
在 Visual Studio 中启用 clang-format
安装 clang-format 17 或更高版本
python -m pip install clang-format
使用 Everything 等工具 找到 clang-format.exe 的安装位置。作为参考,若您使用了 Anaconda,clang-format.exe 将安装在 YourAnacondaPath/Scripts/clang-format.exe
在 Visual Studio
工具-选项
中搜索clang-format
点击
启用 ClangFormat 支持
,然后选择下面的使用自定义 clang-format.exe 文件
,选择第 2 步找到的clang-format.exe
然后你的 Visual Studio 就能愉快的使用支持 c++20 语法的 clang-format 啦!
你也可以使用 tools\ClangFormatter\clang-formatter.py
来直接调用你的 clang-format 来进行格式化,只需要在项目根目录下执行:
python tools\ClangFormatter\clang-formatter.py --clang-format=PATH\TO\YOUR\clang-format.exe --input=src\MaaCore
使用 GitHub codespace 进行在线开发
创建 GitHub codespace 自动配置 C++ 开发环境
随后根据 vscode 的提示或 Linux 教程 配置 GCC 12 和 CMake 工程