准备一个现场,工作区修改一个文件,新增一个文件(添加到暂存区)
-
[root@S-LAB-52 demo]# git status -s
-
A a/b/c/hello_test.txt
-
M welcome.txt
保存工作现场
点击(此处)折叠或打开
-
[root@S-LAB-52 demo]# git stash
-
Saved working directory and index state WIP on (no branch): 6ca2d9e add new welcome.txt
-
HEAD is now at 6ca2d9e add new welcome.txt
保存现场后,再查看当前的状态
-
[root@S-LAB-52 demo]# git status -s
-
[root@S-LAB-52 demo]# git status
-
# Not currently on any branch.
-
nothing to commit (working directory clean)
下面我们看一下如何恢复?
查看保存的进度
点击(此处)折叠或打开
-
[root@S-LAB-52 demo]# git stash list
-
stash@{0}: WIP on (no branch): 6ca2d9e add new welcome.txt
恢复进度
点击(此处)折叠或打开
-
[root@S-LAB-52 demo]# git stash pop
-
# Not currently on any branch.
-
# Changes to be committed:
-
# (use "git reset HEAD ..." to unstage)
-
#
-
# new file: a/b/c/hello_test.txt
-
#
-
# Changed but not updated:
-
# (use "git add ..." to update what will be committed)
-
# (use "git checkout -- ..." to discard changes in working directory)
-
#
-
# modified: welcome.txt
-
#
-
Dropped refs/stash@{0} (8054d86ce601e186f106a9567162e284cb1eace7)
-
[root@S-LAB-52 demo]# git status -s
-
A a/b/c/hello_test.txt
-
M welcome.txt
可以看到git status -s的显示,进度已经找回来了。
下面对找回的状态进行一些操作,看是否是正常的?
1. 提交暂存区的内容
点击(此处)折叠或打开
-
[root@S-LAB-52 demo]# git status -s
-
A a/b/c/hello_test.txt
-
M welcome.txt
-
[root@S-LAB-52 demo]# git commit -m "commit new file a/b/c/hello_test.txt"
-
[detached HEAD 77b95e6] commit new file a/b/c/hello_test.txt
-
0 files changed, 0 insertions(+), 0 deletions(-)
-
create mode 100644 a/b/c/hello_test.txt
-
[root@S-LAB-52 demo]#
-
[root@S-LAB-52 demo]# git status -s
-
M welcome.txt
早期,hello_test.txt已经加入了暂存区,而welcome.txt的修改还在工作区。直接提交hello_test.txt,然后查看,只剩下工作区的welcome.txt的修改了。
2. 回退提交的内容
-
[root@S-LAB-52 demo]# git reset --soft HEAD^
-
[root@S-LAB-52 demo]# git status -s
-
A a/b/c/hello_test.txt
-
M welcome.txt
--soft只回退引用的指向,不影响工作区和暂存区,所以回退之后查看status,工作区和暂存区分别是M和A
3. 提交welcome.txt增加到暂存区
点击(此处)折叠或打开
-
[root@S-LAB-52 demo]# git add welcome.txt
-
[root@S-LAB-52 demo]# git status -s
-
A a/b/c/hello_test.txt
-
M welcome.txt
可以看到M的位置由第2列跑到了第1列,第1列表示暂存区和版本库之间的差异,第2列表示工作区和暂存区之间的差异
4. 将hello_test.txt从暂存区撤销
点击(此处)折叠或打开
-
[root@S-LAB-52 demo]# git reset HEAD a/b/c/hello_test.txt
-
[root@S-LAB-52 demo]# git status -s
-
M welcome.txt
-
?? a/b/c/hello_test.txt
用到了git reset的第一种用法,即指定paths。用HEAD指向的目录树中文件覆盖暂存区中的hello_test.txt,
此时暂存区中的hello_test.txt与HEAD指向的版本库中相同,而工作区中仍保留了早期的hello_test.txt的状态,因此前面提示???
5. 将welcome.txt从暂存区撤销
点击(此处)折叠或打开
-
[root@S-LAB-52 demo]# git reset
-
Unstaged changes after reset:
-
M welcome.txt
-
[root@S-LAB-52 demo]# git status -s
-
M welcome.txt
-
?? a/b/c/hello_test.txt
git reset与git reset HEAD相同,用HEAD指向的目录树重置暂存区,因此提交到暂存区的welcome.txt被撤销了。welcome.txt前面的M变到了第2列
6. 删除本地工作区的所有修改
点击(此处)折叠或打开
-
[root@S-LAB-52 demo]# git status -s
-
M welcome.txt
-
?? a/b/c/hello_test.txt
-
[root@S-LAB-52 demo]# git checkout -- welcome.txt
-
[root@S-LAB-52 demo]# git status -s
-
?? a/b/c/hello_test.txt
我们一步一步来,先删除welcome.txt,用到checkout -- file_path的方式,表示用暂存区的file_path覆盖工作区的file_path。
再来删除hello_test.txt,由于删除本地多余的目录和文件的clean命令比较危险,先看一下哪些文件和目录会被删除,然后再删除
-
[root@S-LAB-52 demo]# git clean -nd
-
Would remove a/b/c/hello_test.txt
-
[root@S-LAB-52 demo]# git clean -fd
-
Removing a/b/c/hello_test.txt
-
[root@S-LAB-52 demo]# git status -s
-nd 确认哪些将会被删除,-fd 执行删除的动作,然后查看当前状态,工作区已经干净!
下面再来看一下git stash的具体用法:
git stash: 保存当前的工作进度
git stash list:显示进度列表,git stash可以多次保存工作栈,可以在恢复时进行选择
git stash pop [--index] []
当不用任何参数时,会恢复最新保存的工作进度,并将恢复的工作进度从存储的工作进度列表中删除
当提供参数时(git stash list显示的列表),则从该中恢复,恢复后也从进度列表中删除
--index指出除了恢复工作区的文件外,同时尝试恢复暂存区
git stash [save [--patch] [-k | -- [no-] keep-index ] [-q | --quiet] []
--patch会显示工作区和HEAD的差异
-k或--keep-index参数,保存进度后不会将暂存区重置,而默认会将暂存区和工作区强制重置
当保存工作进度时,需要使用指定的说明,需要使用以下格式:git stash save "message......."
git stash apply [--index] []
除了不删除恢复的进度外,其余和git stash pop相同
git stash drop []
删除存储的进度,默认删除最新的进度
git stash clear
删除所有存储的进度
git stash branch []
基于进度创建分支
注意,没有被版本控制系统跟踪的文件不能保存进度
阅读(2050) | 评论(0) | 转发(0) |