如何在c ++中使用libgit2检查是否需要pull?

时间:2017-02-20 14:41:49

标签: c++ bitbucket commit git-pull libgit2

我想检查一下我是否有最新版本的程序。我将我的程序共享到bitbucket.org,如果我需要提取最新版本,或者我已经拥有最新版本,我希望我的c ++代码能够写信给我。

1 个答案:

答案 0 :(得分:3)

首先,您必须获取以获取远程跟踪分支的状态。没有任何其他方法可以检查您的分支是否已在遥控器上更新。为此,许多工具会定期(例如每10分钟)自动获取一次。

然后将您的本地分支与其上游进行比较。使用libgit2的一种方法是使用revwalk功能。如果您git_revwalk_push_ref上游和git_revwalk_hide_ref本地分支然后遍历范围,您可以计算本地分支后面的提交数量。做相反的事情以获得提交的数量。

示例:

git_revwalk *walker;
git_revwalk_new(&walker, repo);
git_revwalk_push_ref(walker, "refs/remotes/origin/master");
git_revwalk_hide_ref(walker, "refs/heads/master");

git_oid id;
int count = 0;
while (!git_revwalk_next(&id, walker))
    ++count;

// 'count' is the difference between remote and local