2

有没有办法列出已获取但未使用 LibGit2Sharp 合并的提交?

例如,我可以运行以下 git 命令:

C:\Users\Tom\SourceLog>git log origin
commit f3beb4960b2f4bf5641d5b512b5b8c3081512a56
Author: Tom Hunter
Date:   Wed Jan 9 22:58:51 2013 +0000

    Rollback change to icon

    Seemed to crash on windows xp for some reason..

commit d95f29a6cbfea9cb6009c3095a67d71f86d9e8bd
Author: Tom Hunter
Date:   Mon Jan 7 21:34:36 2013 +0000

    Updating Icon

commit 8785ed4ff3c46bef46ea6e2398c115b4b0203b2c
Author: Tom Hunter
Date:   Mon Jan 7 21:22:54 2013 +0000

    Fixing tests

    Moved GenerateFlowDocuments method to LogEntry class.
    Have somehow managed to greatly simplify tests..

...

前两个提交尚未合并到我的本地存储库中。即,如果我省略origin,这就是我得到的:

C:\Users\Tom\SourceLog>git log
commit 8785ed4ff3c46bef46ea6e2398c115b4b0203b2c
Author: Tom Hunter
Date:   Mon Jan 7 21:22:54 2013 +0000

    Fixing tests

    Moved GenerateFlowDocuments method to LogEntry class.
    Have somehow managed to greatly simplify tests..

...

下面的代码只给了我 8785ed。如何获取包含尚未合并的提交的列表?

using (var repo = new Repository(@"C:\Users\Tom\SourceLog"))
{
    var c = repo.Commits.First();
}
4

1 回答 1

4

您可以通过以下方式获取远程原始分支的提交:

repo.Branches["origin/HEAD"].Commits

您可以使用First()默认排序获取最新提交。但是,您将获得远程分支的所有提交,而不仅仅是未合并的提交。

如果您想要收集未合并的提交,您应该使用它QueryBy(filter)来获取提交。nulltoken 的 asnwer描述了解决方案,但它包含错误。正确的用法是:

var filter = new Filter
{
    Since = repo.Branches["origin/HEAD"],
    Until = repo.Head
};
var notMergedCommits = repo.Commits.QueryBy(filter);

因为:

  • 自:指向提交对象的指针或作为起点的指针列表。
  • 直到:指向提交对象的指针或将被排除(连同祖先)从枚举中的指针列表。

因此,使用上面的代码,您希望从分支中获得提交"origin/HEAD"并排除包含在您的分支"HEAD"中的提交,这意味着返回所有在获取的分支中但尚未合并到"HEAD".

于 2013-01-13T07:32:24.753 回答