git相关操作

1.git如果当前提交生成的链接没有合入但是要进行修改如何处理

要将新的修改同步到当前 Gerrit 上已有的待合入提交中(即生成该提交的新版本 Patch Set),您需要使用 Git 的 --amend(追加/修改)

功能。

请按照以下步骤操作:

第一步:确保本地处于该提交的代码状态

如果您本地的当前分支和提交正是这个修改,可以直接进行第二步。

如果本地代码已经变动,建议先将该 Gerrit 提交的代码拉取到本地:

  1. 在 Gerrit 网页上点击该提交,进入详情页。

  2. 点击右上角(或右上侧面)的 Download 按钮。

  3. 复制 Checkout 或 Cherry Pick 下方的命令,在本地终端执行,使本地代码回退到该提交的状态。

第二步:修改代码并暂存

在本地修改好代码后,将修改的文件添加到暂存区:

git add <修改的文件路径>

或者添加所有修改的文件

git add .

第三步:使用 --amend 修改提交**(PS:这步需要注意,如果在网页中修改了编辑内容,这里会把原先的编辑内容覆盖,所以建议将网页的编辑内容拷贝下来)**

执行以下命令,这会将您刚刚的修改合并到上一次的提交中,而不会生成新的 commit 记录:

git commit --amend

  • 注意:执行此命令后会弹出文本编辑器(如 Vim)让您编辑提交信息。请千万不要删除或修改最底部的 Change-Id: Ixxxxxxxx...

这一行。Gerrit 正是通过这个 Change-Id 来识别并关联到同一个待合入页面的。

  • 保存并退出编辑器。

第四步:推送修改到 Gerrit

将修改后的 commit 推送至对应的目标分支(根据您的截图,分支为 3in1_xgd_0307):

git push origin HEAD:refs/for/3in1_xgd_0307

(注:如果您的远程仓库名称不是 origin,请替换为对应的名称。)

验证结果

推送成功后,刷新 Gerrit 网页。您会发现该提交页面中生成了一个新的 Patch Set(例如从 Patch Set 1 变为 Patch

Set 2),这说明您的修改已成功同步到该待合入状态的提交中。

2.git如何查看git commit之后的diff

git diff HEAD~1 HEAD

3.git如何查看git add之后的diff

git diff --staged

4.git如何清理没有连接进来的内容

git clean -dfx

5.如何在指定目录下面合入patch以及生成patch

首先切换到对应的目录,合入patch比较简单,就是git apply,这没什么好说的

如果我们合入了patch发现不对,然后上述第一步以及将patch合入了,然后我们就可以进行修改

修改完成我们需要生成patch,此时我们还需要保持原先的目录,然后执行如下指令

git diff --relative > 0004_wpa_supplicant_wapi_sprd.patch

这样我们就生成新的patch了

将生成的patch与之前的patch进行对比,目录结构一致即可,行数有所改变甚至之前的行数有所改变都是正常的,说明之前的patch行数不正确,我们生成的patch更稳定,如下

相关推荐
嘻嘻仙人3 天前
Ubuntu中 git上传自己的项目和二次上传一般流程
git·github
Patrick_Wilson3 天前
Squash Merge 的血缘陷阱:为什么删掉的代码又活了过来
前端·git·程序员
沉浸学习的匿名网友3 天前
什么是 .gitignore?为什么每个 Git 项目几乎都离不开它?
前端·git
深海鱼在掘金4 天前
Git 完全指南 —— 第3章:理解工作区、暂存区、版本库三个核心
git
江华森4 天前
Git 基础筑基:从原理到团队协作的全栈实战
git
JakeJiang4 天前
Git 必备命令指南:从日常高频到项目开发实战
git
叫我少年5 天前
Windows 中安装 git
git
深海鱼在掘金10 天前
Git 完全指南 —— 第1章:Git 概览与版本控制演进
git
noravinsc11 天前
关于Git Flow
git
蜜獾云11 天前
在Git中配置用户名和密码
git