当我运行git reset -hard HEAD时,它应该重置为你所拉的原始版本,据我所知。不幸的是,它会让文件到处乱放,因为git状态显示了一大串未跟踪的文件。

你怎么告诉少不再来的人“只是把它拉回到最后拉的地方,不多也不少”?


当前回答

你可能在某个时候做了软重置,你可以通过这样做来解决这个问题

git add .
git reset --hard HEAD~100
git pull

其他回答

git reset --hard && git clean -df

或者,ZSH提供了一个'gpristine'别名:

alias gpristine='git reset --hard && git clean -df'

这真的很方便。

可选:

对于git clean命令,还有一个-x选项。这也将删除'git忽略'文件,所以添加这个选项以及如果它是你想要的。

如果在fork回购上工作,请确保从正确的回购/分支中获取和重置,例如:

git fetch upstream && git reset --hard upstream/master && git clean -df

您正在寻找的命令是git clean

git-clean用于删除工作树中不被跟踪的文件。以下是一些可以与git clean命令一起使用的选项(简要)。

-d use当没有指定路径时。所以git递归到未跟踪的目录中删除它们。

-f/——force删除嵌套的未跟踪文件。

-i/——interactive以交互方式显示将要执行的操作和清理文件。

显示不删除任何东西会发生什么。

-x忽略文件

例如:git clean -f -d ->删除当前目录下所有未跟踪的文件。

你可能在某个时候做了软重置,你可以通过这样做来解决这个问题

git add .
git reset --hard HEAD~100
git pull

如果你还有想保留的文件:

Git clean -di会进行交互式的清理,允许你只删除你不想要的文件/dirs。