mirror of https://gitee.com/cxasm/notepad--.git
56 lines
2.7 KiB
Markdown
56 lines
2.7 KiB
Markdown
# 补丁操作说明
|
||
|
||
> 用于 patchs/coconil-cmake-spark-deb-appimage.patch 补丁化构建方式
|
||
|
||
- 如何使用此补丁(测试本补丁)
|
||
|
||
> 注:此补丁仅可基于 master 分支进行构建
|
||
|
||
1. 在项目中使用此补丁?
|
||
```shell
|
||
git am --whitespace=fix < patchs/coconil-cmake-spark-deb-appimage.patch
|
||
```
|
||
2. 使用在线的方式直接使用补丁文件,并对纯净的 ndd 项目进行打补丁
|
||
```
|
||
# 克隆 notepad-- 项目
|
||
git clone https://gitee.com/cxasm/notepad--
|
||
cd notepad--
|
||
|
||
# 打在线补丁
|
||
curl -s https://gitee.com/zinface/coconil-notepad--/raw/cmake-patchs/patchs/coconil-cmake-spark-deb-appimage.patch | git am --whitespace=fix
|
||
|
||
make package # 构建 release 模式的 deb 包
|
||
make linuxdeploy # 构建出相关文件与自动组织 appimage 的结构目录
|
||
make genrate-appimage # 基于已 linuxdeploy 的结构目录进行打包为 Appimage
|
||
```
|
||
|
||
|
||
- 在应用补丁时,并对补丁进行的更新操作
|
||
|
||
```shell
|
||
# 切换到一个新的分支,即可开始进行补丁内的更新提交
|
||
git checkout -b coconil-cmake-spark-deb-appimage
|
||
|
||
# origin/dev 表示本仓库的 dev 开发分支
|
||
# 在应用过补丁,并产生了新的提交,即可在当前所在补丁更新分支内
|
||
# 相对基于 origin/master 为参考,目前所包含的所有最新提交内容将生成为一个补丁文件(其中尾部为增量更新)
|
||
git format-patch --stdout origin/master > patchs/coconil-cmake-spark-deb-appimage.patch
|
||
|
||
# 最后,回到你的原 master 分支,将被改变的补丁文件进行提交
|
||
# 在推送完成后,即可放弃你在 coconil-cmake-spark-deb-appimage 分支中所有产生的内容(因为都已经进入补丁)
|
||
```
|
||
|
||
- 一些注意事项
|
||
|
||
```shell
|
||
# 在不了解补丁时,你需要认识一下补丁,但补丁与补丁之间有着不同的用法
|
||
# 本 patchs/coconil-cmake-spark-deb-appimage.patch 补丁为支持 Appimage 构建
|
||
|
||
# 关于补丁的一些方面
|
||
# 1. 首先你需要了解 git 是什么,以及简单的使用
|
||
# 2. 你需要了解补丁是什么,以及简单的使用(应用补丁)
|
||
# 3. 你需要了解如何创建一个补丁,最基本的就是相对于旧目标分支,将本分区新增的提交进行导出为补丁
|
||
# 4. 你可能只会将单个提交、或多个提交导出为补丁,但这还不够,你需要具有绝对的对于补丁的理解
|
||
# 5. 对于不同的目的补丁,应该是多个 patch 文件存在的形式
|
||
# 6. 最后,不管在什么时候,你在应用补丁前,你应该考虑是否应用到当前分支?为什么不切换到一个新的分支呢?
|
||
``` |