我将一些源代码签入GIT,并提交消息“Build 0051”。

然而,我似乎再也找不到那个源代码了——如何使用命令行从GIT存储库中提取这个源代码呢?

更新

使用SmartGIT在0043、0044、0045和0046版本中检出。 签出了0043,并在不同的分支签入了0051之前的版本。 又查了一次0043。 现在,0051已经消失了。

更新

源代码肯定在那里,现在是检查它的问题:

C:\Source>git log -g --grep="0052"
commit 77b1f718d19e5cf46e2fab8405a9a0859c9c2889
Reflog: HEAD@{10} (unknown <Mike@.(none)>)
Reflog message: commit: 20110819 - 1724 - GL: Intermediate version. File version:  v0.5.0 build 0052.
Author: unknown <Mike@.(none)>
Date:   Fri Aug 19 17:24:51 2011 +0100

    20110819 - 1724 - GL: Intermediate version. File version: v0.5.0 build 0052.

C:\Source>

当前回答

我把它放在~/.gitconfig中:

[alias]
    find = log --pretty=\"format:%Cgreen%H %Cblue%s\" --name-status --grep

然后我可以输入“git find string”,我得到一个包含该字符串的所有提交的列表。例如,要查找所有引用票号33的提交:

029a641667d6d92e16deccae7ebdeef792d8336b Added isAttachmentEditable() and isAttachmentViewable() methods. (references #33)
M       library/Dbs/Db/Row/Login.php

a1bccdcd29ed29573d2fb799e2a564b5419af2e2 Add permissions checks for attachments of custom strategies. (references #33).
M       application/controllers/AttachmentController.php

38c8db557e5ec0963a7292aef0220ad1088f518d Fix permissions. (references #33)
M       application/views/scripts/attachment/_row.phtml

041db110859e7259caeffd3fed7a3d7b18a3d564 Fix permissions. (references #33)
M       application/views/scripts/attachment/index.phtml

388df3b4faae50f8a8d8beb85750dd0aa67736ed Added getStrategy() method. (references #33)
M       library/Dbs/Db/Row/Attachment.php

其他回答

只是git log——all——grep命令的一个小补充: 在我的情况下,我必须转义括号内的消息:

git log --all --grep="\[C\] Ticket-1001: Fix nasty things"

我把它放在~/.gitconfig中:

[alias]
    find = log --pretty=\"format:%Cgreen%H %Cblue%s\" --name-status --grep

然后我可以输入“git find string”,我得到一个包含该字符串的所有提交的列表。例如,要查找所有引用票号33的提交:

029a641667d6d92e16deccae7ebdeef792d8336b Added isAttachmentEditable() and isAttachmentViewable() methods. (references #33)
M       library/Dbs/Db/Row/Login.php

a1bccdcd29ed29573d2fb799e2a564b5419af2e2 Add permissions checks for attachments of custom strategies. (references #33).
M       application/controllers/AttachmentController.php

38c8db557e5ec0963a7292aef0220ad1088f518d Fix permissions. (references #33)
M       application/views/scripts/attachment/_row.phtml

041db110859e7259caeffd3fed7a3d7b18a3d564 Fix permissions. (references #33)
M       application/views/scripts/attachment/index.phtml

388df3b4faae50f8a8d8beb85750dd0aa67736ed Added getStrategy() method. (references #33)
M       library/Dbs/Db/Row/Attachment.php

虽然有点晚,但有:/,这是一个专用的符号,用于指定基于提交消息的提交(或修订),只需在搜索字符串前加上:/,例如:

git show :/keyword(s)

这里<keywords>可以是单个单词,也可以是由空格组成的复杂正则表达式模式,所以请确保在必要时引用/转义,例如:

git log -1 -p ":/a few words"

或者,可以指定一个起始点,以找到从特定点可到达的最近提交,例如:

git show 'HEAD^{/fix nasty bug}'

参见:git修订手册。

这样的:

git log --oneline --grep='Searched phrase'

或:

git log --oneline --name-status --grep='Searched phrase'

命令最适合我。

如果变化不是太老,你可以这样做,

git 引用日志

然后签出提交id