Git上一些修改错误操作的命令使用技巧


修改错误的提交信息commit message
提交信息很长时间内会一直保留在你的代码库code base中,所以你肯定希望通过这个信息正确地了解代码修改情况。 下面这个命令可以让你编辑最近一次的提交信息,但是你必须确保没有对当前的代码库working copy做修改,否则这些修改也会随之一起提交。
[/code]
$ git commit --amend -m ”YOUR-NEW-COMMIT-MESSAGE”
[/code]
假如你已经将代码提交(git commit)推送(git push)到了远程分支,那么你需要通过下面的命令强制推送这次的代码提交。

复制代码
代码如下:

$ git push <remote> <branch> --force

从当前Git分支移除未追踪的本地文件
假设你凑巧有一些未被追踪的文件(因为不再需要它们),不想每次使用git status命令时让它们显示出来。下面是解决这个问题的一些方法:

复制代码
代码如下:

$ git clean -f -n # 1
$ git clean -f # 2
$ git clean -fd # 3
$ git clean -fX # 4
$ git clean -fx # 5

(1): 选项-n将显示执行(2)时将会移除哪些文件。
(2): 该命令会移除所有命令(1)中显示的文件。
(3): 如果你还想移除文件件,请使用选项-d。
(4): 如果你只想移除已被忽略的文件,请使用选项-X。
(5): 如果你想移除已被忽略和未被忽略的文件,请使用选项-x。
请注意最后两个命令中X的区别。

修复更早期的 commit

场景: 你在一个更早期的 commit 里忘记了加入一个文件,如果更早的 commit 能包含这个忘记的文件就太棒了。你还没有 push,但这个 commit 不是最近的,所以你没法用 commit --amend.

方法:

复制代码
代码如下:
git commit --squash <SHA of the earlier commit>

复制代码
代码如下:
git rebase --autosquash -i <even earlier SHA>

原理:

复制代码
代码如下:
git commit --squash
会创建一个新的 commit ,它带有一个 commit 消息,类似于 squash! Earlier commit。 (你也可以手工创建一个带有类似 commit 消息的 commit,但是 commit --squash 可以帮你省下输入的工作。)

如果你不想被提示为新合并的 commit 输入一条新的 commit 消息,你也可以利用 git commit --fixup 。在这个情况下,你很可能会用commit --fixup ,因为你只是希望在 rebase 的时候使用早期 commit 的 commit 消息。


复制代码
代码如下:
rebase --autosquash -i
  会激活一个交互式的 rebase 编辑器,但是编辑器打开的时候,在 commit 清单里任何 squash! 和 fixup! 的 commit 都已经配对到目标 commit 上了,如下所示:

在使用 --squash 和 --fixup 的时候,你可能不记得想要修正的 commit 的 SHA 了— 只记得它是前面第 1 个或第 5 个 commit。你会发现 Git 的 ^ 和 ~ 操作符特别好用。HEAD^ 是 HEAD 的前一个 commit。 HEAD~4 是 HEAD 往前第 4 个 – 或者一起算,倒数第 5 个 commit。

 

停止追踪一个文件

场景: 你偶然把 application.log 加到代码库里了,现在每次你运行应用,Git 都会报告在 application.log 里有未提交的修改。你把 *.login 放到了 .gitignore 文件里,可文件还是在代码库里 — 你怎么才能告诉 Git “撤销” 对这个文件的追踪呢?

方法:

复制代码
代码如下:
git rm --cached application.log

原理: 虽然 .gitignore 会阻止 Git 追踪文件的修改,甚至不关注文件是否存在,但这只是针对那些以前从来没有追踪过的文件。一旦有个文件被加入并提交了,Git 就会持续关注该文件的改变。类似地,如果你利用 git add -f 来强制或覆盖了 .gitignore, Git 还会持续追踪改变的情况。之后你就不必用-f  来添加这个文件了。

如果你希望从 Git 的追踪对象中删除那个本应忽略的文件, git rm --cached 会从追踪对象中删除它,但让文件在磁盘上保持原封不动。因为现在它已经被忽略了,你在  git status 里就不会再看见这个文件,也不会再偶然提交该文件的修改了。


删除本地和远程Git分支
删除本地分支:

复制代码
代码如下:

$ git branch --delete --force <branchName>

或者使用选项-D作为简写:

复制代码
代码如下:

$ git branch -D

删除远程分支:

复制代码
代码如下:

$ git push origin --delete <branchName>



相关阅读:
JS控制日期显示的小例子
各浏览器对document.getElementById等方法的实现差异解析
Win10系统自由设置时间对电脑进行重启的方法
MSSQL产生死锁的根本原因及解决方法
android图像绘制(七)ClipRect局部绘图/切割原图绘制总结
Bootstrap carousel轮转图的使用实例详解
部分Win10用户遭遇闪屏问题致电脑不能正常使用 微软提供解决方法
win10如何关闭完成字符串?Win10输入提示完成字符串的三种解决方法
iOS应用开发中使用Auto Layout来适配不同屏幕尺寸
jQuery多项选项卡的实现思路附样式及代码
DBA应该知道的一些关于SQL Server跟踪标记的使用
js获取本机操作系统类型的两种方法
HTML5 Canvas实现文本对齐的方法总结
Jersey框架的统一异常处理机制分析
快速导航
PHP MySQL HTML CSS JavaScript MSSQL AJAX .NET JSP Linux Mac ASP 服务器 SQL jQuery C# C++ java Android IOS oracle MongoDB SQLite wamp 交通频道 作文范文 遗孤 会计毕业实习报告范文 曾经、失去作文700字 再这样下去不行了,必须要改变 2014物业实习报告范文精编 建军节短信祝福语 老虎拜师傅 2012班主任培训心得体会 享一份安暖,笺底生香 成长在幸福的路上作文700字 爱我母亲河——汉江 没有最完美作文600字 留下 小学五年级作文500字:倒霉的一周 中小学教师培训结业典礼学员代表发言稿 2009年三年级语文教研组工作总结 2016年乡镇书记任期经济责任审计述职报告 《乡愁》支点设计 我想做小孩 伴随我成长的一篇童话 三、科学技术的发展与成就(专题五) 劳动节促销活动总结报告 党员2016年度个人工作总结 镇领导班子述职报告 落落空虚 你要走,我放手 长不大的我们 2015年酒店员工合同范本 储存诚信 2015学校学习十八届三中全会总结 励志美文:我只能靠自己,因为我没得选择 现在 吐水现象作文300字 邮政储蓄银行柜员实习报告 爆破施工合同范本 我的摔跤日 顶岗实习交流会总结 谢僧寄拄杖 如果时间倒流 2016年暑假社会实践心得体会 迎春花作文150字 高中高三作文1000字:走向辉煌 中国的美丽蜕变 公路运输调研分析报告 五年级军训日记400字 为你举行的葬礼 三十年后的相聚——李金鑫 小学六年级作文400字:难过哭泣 凌晨的幻想 世界不能因为你的虚荣,而把人生的天平倾斜 “海洋生物”聚集会_关于参观海洋馆的小学生作文800字

Copyright © 2016 phpStudy |