6.3 Git 工具 - 交互式暂存

交互式暂存

Git提供了很多脚本来辅助某些命令行任务。这里,你将看到一些交互式命令,它们帮助你方便地构建只包含特定组合和部分文件的提交。在你修改了一大批文件然后决定将这些变更分布在几个各有侧重的提交而不是单个又大又乱的提交时,这些工具非常有用。用这种方法,你可以确保你的提交在逻辑上划分为相应的变更集,以便于供和你一起工作的开发者审阅。如果你运行git add时加上-i或者--interactive选项,Git就进入了一个交互式的shell模式,显示一些类似于下面的信息:

$ git add -i
           staged     unstaged path
  1:    unchanged        +0/-1 TODO
  2:    unchanged        +1/-1 index.html
  3:    unchanged        +5/-1 lib/simplegit.rb

*** Commands ***
  1: status     2: update      3: revert     4: add untracked
  5: patch      6: diff        7: quit       8: help
What now>

你会看到这个命令以一个完全不同的视图显示了你的暂存区——主要是你通过git status得到的那些信息但是稍微简洁但信息更加丰富一些。它在左侧列出了你暂存的变更,在右侧列出了未被暂存的变更。

在这之后是一个命令区。这里你可以做很多事情,包括暂存文件,撤回文件,暂存部分文件,加入未被追踪的文件,查看暂存文件的差别。

暂存和撤回文件

如果你在What now>的提示后输入2或者u,这个脚本会提示你那些文件你想要暂存:

What now> 2
           staged     unstaged path
  1:    unchanged        +0/-1 TODO
  2:    unchanged        +1/-1 index.html
  3:    unchanged        +5/-1 lib/simplegit.rb
Update>>

如果想暂存TODO和index.html,你可以输入相应的编号:

Update>> 1,2
           staged     unstaged path
* 1:    unchanged        +0/-1 TODO
* 2:    unchanged        +1/-1 index.html
  3:    unchanged        +5/-1 lib/simplegit.rb
Update>>

每个文件旁边的*表示选中的文件将被暂存。如果你在update>>提示后直接敲入回车,Git会替你把所有选中的内容暂存:

Update>>
updated 2 paths

*** Commands ***
  1: status     2: update      3: revert     4: add untracked
  5: patch      6: diff        7: quit       8: help
What now> 1
           staged     unstaged path
  1:        +0/-1      nothing TODO
  2:        +1/-1      nothing index.html
  3:    unchanged        +5/-1 lib/simplegit.rb

现在你可以看到TODO和index.html文件被暂存了同时simplegit.rb文件仍然未被暂存。如果这时你想要撤回TODO文件,就使用3或者r(代表revert,恢复)选项:

*** Commands ***
  1: status     2: update      3: revert     4: add untracked
  5: patch      6: diff        7: quit       8: help
What now> 3
           staged     unstaged path
  1:        +0/-1      nothing TODO
  2:        +1/-1      nothing index.html
  3:    unchanged        +5/-1 lib/simplegit.rb
Revert>> 1
           staged     unstaged path
* 1:        +0/-1      nothing TODO
  2:        +1/-1      nothing index.html
  3:    unchanged        +5/-1 lib/simplegit.rb
Revert>> [enter]
reverted one path

再次查看Git的状态,你会看到你已经撤回了TODO文件

*** Commands ***
  1: status     2: update      3: revert     4: add untracked
  5: patch      6: diff        7: quit       8: help
What now> 1
           staged     unstaged path
  1:    unchanged        +0/-1 TODO
  2:        +1/-1      nothing index.html
  3:    unchanged        +5/-1 lib/simplegit.rb

要查看你暂存内容的差异,你可以使用6或者d(表示diff)命令。它会显示你暂存文件的列表,你可以选择其中的几个,显示其被暂存的差异。这跟你在命令行下指定git diff --cached非常相似:

*** Commands ***
  1: status     2: update      3: revert     4: add untracked
  5: patch      6: diff        7: quit       8: help
What now> 6
           staged     unstaged path
  1:        +1/-1      nothing index.html
Review diff>> 1
diff --git a/index.html b/index.html
index 4d07108..4335f49 100644
--- a/index.html
+++ b/index.html
@@ -16,7 +16,7 @@ Date Finder

 <p id="out">...</p>

-<div id="footer">contact : support@github.com</div>
+<div id="footer">contact : email.support@github.com</div>

 <script type="text/javascript">

通过这些基本命令,你可以使用交互式增加模式更加方便地处理暂存区。

暂存补丁

只让Git暂存文件的某些部分而忽略其他也是有可能的。例如,你对simplegit.rb文件作了两处修改但是只想暂存其中一个而忽略另一个,在Git中实现这一点非常容易。在交互式的提示符下,输入5或者p(表示patch,补丁)。Git会询问哪些文件你希望部分暂存;然后对于被选中文件的每一节,他会逐个显示文件的差异区块并询问你是否希望暂存他们:

diff --git a/lib/simplegit.rb b/lib/simplegit.rb
index dd5ecc4..57399e0 100644
--- a/lib/simplegit.rb
+++ b/lib/simplegit.rb
@@ -22,7 +22,7 @@ class SimpleGit
   end

   def log(treeish = 'master')
-    command("git log -n 25 #{treeish}")
+    command("git log -n 30 #{treeish}")
   end

   def blame(path)
Stage this hunk [y,n,a,d,/,j,J,g,e,?]?

此处你有很多选择。输入?可以显示列表:

Stage this hunk [y,n,a,d,/,j,J,g,e,?]? ?
y - stage this hunk
n - do not stage this hunk
a - stage this and all the remaining hunks in the file
d - do not stage this hunk nor any of the remaining hunks in the file
g - select a hunk to go to
/ - search for a hunk matching the given regex
j - leave this hunk undecided, see next undecided hunk
J - leave this hunk undecided, see next hunk
k - leave this hunk undecided, see previous undecided hunk
K - leave this hunk undecided, see previous hunk
s - split the current hunk into smaller hunks
e - manually edit the current hunk
? - print help

如果你想暂存各个区块,通常你会输入y或者n,但是暂存特定文件里的全部区块或者暂时跳过对一个区块的处理同样也很有用。如果你暂存了文件的一个部分而保留另外一个部分不被暂存,你的状态输出看起来会是这样:

What now> 1
           staged     unstaged path
  1:    unchanged        +0/-1 TODO
  2:        +1/-1      nothing index.html
  3:        +1/-1        +4/-0 lib/simplegit.rb

simplegit.rb的状态非常有意思。它显示有几行被暂存了,有几行没有。你部分地暂存了这个文件。在这时,你可以退出交互式脚本然后运行git commit来提交部分暂存的文件。

最后你也可以不通过交互式增加的模式来实现部分文件暂存——你可以在命令行下通过git add -p或者git add --patch来启动同样的脚本。


本文来自 http://git-scm.com/ 保存下来,方便自己查阅。


### 回答1: `git reset --hard` 命令会将 Git 仓库中的 HEAD 指向指定的提交,同时重置暂存区和工作区,这样会丢失工作区中未提交的修改和所有已暂存但未提交的修改。 如果你只是想撤销暂存区的修改,可以使用以下命令: ``` git reset HEAD ``` 这个命令会将暂存区的修改撤销,但不会影响工作区的修改。如果你想撤销工作区的修改,可以使用以下命令: ``` git checkout . ``` 这个命令会将工作区中所有修改还原到最近的一次提交状态。注意,所有未提交的修改都会被丢弃,因此请谨慎使用。 ### 回答2: git reset --hard 暂存文件是指使用git的reset命令来重置工作区和暂存区,并且放弃对某个文件的更改,恢复到之前的提交状态。 当我们在进行代码开发时,有时可能会修改一些文件,但事后发现自己的修改是错误的或不需要的。此时,我们可以使用git reset --hard命令来撤销对这些文件的修改。 使用git reset --hard命令,会同时重置工作区和暂存区,将它们恢复到上一次提交的状态。这个命令会永久性地丢弃我们对文件的修改,所以在执行这个命令之前,一定要确保我们不需要保存这些修改。 要使用git reset --hard命令,我们需要先确定要重置的提交版本或分支。可以通过git log命令来查看提交记录,找到我们需要回滚到的版本号或提交哈希。然后,在终端中输入git reset --hard <提交哈希>命令,将工作区和暂存区重置到指定的提交。 需要注意的是,git reset --hard命令会永久性地丢弃所有没有提交的修改,所以在执行这个命令之前,一定要确认工作区中没有重要的未保存的更改。在重置之前,也可以使用git stash命令将修改的文件暂存起来,以便稍后可以恢复到当前状态。 综上所述,git reset --hard 暂存文件是一个强制性的重置命令,它可以丢弃对文件的修改,恢复到之前的提交状态。但是由于这个命令会永久地丢弃未提交的更改,使用之前需要谨慎确认。 ### 回答3: git reset --hard 对于暂存文件的作用是把所有已暂存的文件回退到最近一次提交的状态。也就是说,执行这个命令后,暂存区中的文件会被清空,工作目录中的文件会与最近一次提交的版本完全一致。 当我们使用 git add 命令将文件添加到暂存区后,我们有时可能会发现自己添加了一些不必要的或错误的文件。这时,可以使用 git reset --hard 暂存文件来撤销这些暂存的文件,使其回到工作目录并且不出现在暂存区中。 另外,当我们想要回退到之前某个提交的状态时,可以使用 git reset --hard 加上想要回退的提交的SHA值来实现。执行该命令后,Git会将HEAD指针和分支指针移动到指定的提交上,并且重置工作目录和暂存区到该提交的状态。这意味着,我们回退后之前的提交及其之后的提交都会被丢弃,工作目录和暂存区会和指定的提交完全一致。 需要注意的是,git reset --hard 命令是具有破坏性的,它会永久性地清空暂存区和工作目录中的文件,并且丢弃掉之前的提交。因此,在执行该命令之前,需要确保已经备份了重要的更改,以免造成数据的不可挽回的损失。 总之,git reset --hard 暂存文件命令用于撤销暂存的文件,或者回退到之前某个提交的状态,但需要谨慎使用。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值