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 交通频道 作文范文 1100字国庆晚会观后感作文范文 淘宝客服年度工作总结范文 激励人的英语名言 〈征服〉作文5篇 区域经理年终个人工作总结 逗号和句号作文300字 泪雨霖铃 2016新年愿望作文600字:长大 打工吟 2016夫妻自愿离婚协议书范本 演讲稿 读好书,净化心灵 家乡的小院子 夜深了,便是思绪的天堂 医院保洁员岗位职责 央视最穷主持人柴静的励志人生 阅读带给我快乐 炼铁厂工人入党自传范例 学校机关党委2008年年终总结 鸡蛋壳的妙用350字 春节作文600字:我的压岁钱计划 高中高二作文1000字:超超超超级倒霉! 我梦想有一天在领奖台上…… 描写森林的好句子 心之所安,即为所恋 植树节是几月几日? 让盛夏焐热你的苍凉 邯郸客舍歌 【精品】角的比较与运算教学反思 这事,真让我激动 2012年12月10日 16时20分18秒 绿茶飘香 “甘D故事”实践团先行组抵达目的地 爱情文章:他缺少了一份爱你的决心和勇气 快乐600字 只顾风雨兼程800字 先发制人成语接龙 空间说说:他们总在背后议论你,是因为你走在他们前面 小学生读书笔记格式怎么写 喜羊羊【六】(番外篇) 励志歌曲推荐:邓紫棋《我要我们在一起》 14年大学生财务会计实习报告范文 大学生入党考察意见 2015元月升旗仪式讲话:2015,为自己加油! 2014年升学宴致辞 再见了我的兄弟们 繁华的反义词 科技小论文:茶水变成墨水的实验 庆祝第二十个全国土地日演讲稿——牢记光荣职责,不辱神圣使命 放手了就不要心痛 小学六年级作文550字:起床三部曲

Copyright © 2016 phpStudy |