当我运行git reset -hard HEAD时,它应该重置为你所拉的原始版本,据我所知。不幸的是,它会让文件到处乱放,因为git状态显示了一大串未跟踪的文件。
你怎么告诉少不再来的人“只是把它拉回到最后拉的地方,不多也不少”?
当我运行git reset -hard HEAD时,它应该重置为你所拉的原始版本,据我所知。不幸的是,它会让文件到处乱放,因为git状态显示了一大串未跟踪的文件。
你怎么告诉少不再来的人“只是把它拉回到最后拉的地方,不多也不少”?
当前回答
你必须使用git clean -f -d来清除工作副本中未被跟踪的文件和目录。 你可以添加-x来删除被忽略的文件,更多信息在这个优秀的SO回答中。
如果你需要将整个存储库的子模块重置到master上的状态,运行这个脚本:
git fetch origin master
git checkout --force -B master origin/master
git reset --hard
git clean -fdx
git submodule update --init --recursive --force
git submodule foreach git fetch
git submodule foreach git checkout --force -B master origin/master
git submodule foreach git reset --hard
git submodule foreach git clean -fdx
其他回答
您正在寻找的命令是git clean
你必须使用git clean -f -d来清除工作副本中未被跟踪的文件和目录。 你可以添加-x来删除被忽略的文件,更多信息在这个优秀的SO回答中。
如果你需要将整个存储库的子模块重置到master上的状态,运行这个脚本:
git fetch origin master
git checkout --force -B master origin/master
git reset --hard
git clean -fdx
git submodule update --init --recursive --force
git submodule foreach git fetch
git submodule foreach git checkout --force -B master origin/master
git submodule foreach git reset --hard
git submodule foreach git clean -fdx
你可以使用git stash。您必须指定-include-untracked,否则您将会遇到最初的问题。
git stash --include-untracked
那就把最后一笔存起来
git stash drop
你可以为它创建一个方便的别名,比如git discard:
git config --global alias.discard "! git stash -q --include-untracked && git stash drop -q"
你可能在某个时候做了软重置,你可以通过这样做来解决这个问题
git add .
git reset --hard HEAD~100
git pull
你可以添加这个有用的别名来硬重置所有文件(跟踪和未跟踪),并返回到之前的提交版本:
git config --global alias.reset-hard '!f() { git reset --hard; git clean -df ; }; f'
然后你可以这样重置:
git reset-hard