我有一个很少有分支和悬空提交的Git存储库。我想在存储库中搜索一个特定字符串的所有这样的提交。
我知道如何获得历史中所有提交的日志,但这些不包括分支或悬垂的blobs,只包括HEAD的历史。我想把它们都找回来,找到一个被放错地方的特定提交。
我还想知道如何在Mercurial做到这一点,因为我正在考虑切换。
我有一个很少有分支和悬空提交的Git存储库。我想在存储库中搜索一个特定字符串的所有这样的提交。
我知道如何获得历史中所有提交的日志,但这些不包括分支或悬垂的blobs,只包括HEAD的历史。我想把它们都找回来,找到一个被放错地方的特定提交。
我还想知道如何在Mercurial做到这一点,因为我正在考虑切换。
当前回答
git中的一个命令,我认为它更容易找到一个字符串:
git log --pretty=oneline --grep "string to search"
适用于Git 2.0.4
其他回答
在Mercurial中,使用hg log——keyword搜索提交消息中的关键字,使用hg log——user搜索特定用户。有关限制日志的其他方法,请参阅hg help log。
在Mercurial中,你做了一个
$ hg grep "search for this" [file...]
还有其他选项可以缩小搜索的修订范围。
除了使用git log -g——grep=<regexp>或git grep -e <regexp> $(git log -g——pretty=format:%h)的richq答案之外:看看以下由当前git维护者Junio C Hamano撰写的博客文章
有趣的“git日志-grep” 有趣的“git grep”
总结
git grep和git log——grep都是面向行的,因为它们寻找匹配指定模式的行。
你可以使用git log——grep=<foo>——grep=<bar>(或者git log——author=<foo>——grep=<bar>,内部转换为two——grep)来查找匹配任何一种模式(隐式或语义)的提交。
由于是面向行的,有用的AND语义是使用git log——all-match——grep=<foo>——grep=<bar>来查找在某个地方同时有第一个行匹配和第二个行匹配的提交。
使用git grep,您可以将多个模式(所有模式都必须使用-e <regexp>形式)与——or(默认值)、——and、——not、(and)组合在一起。对于grep——all-match意味着文件必须有与每个替代选项匹配的行。
任何以引用作为参数的命令都将接受——all选项,该选项记录在git rev-list手册页中,如下:
--all
Pretend as if all the refs in $GIT_DIR/refs/ are listed on the
command line as <commit>.
例如git log -Sstring——all将显示所有提到字符串的提交,并且可以从分支或标签访问(我假设你的悬垂提交至少有一个标签命名)。
如果您是vim用户,您可以安装tig (apt-get install tig),并使用/,相同的命令在vim上搜索
https://blogs.atlassian.com/2013/05/git-tig/