diff options
| author | Carlos Martín Nieto <[email protected]> | 2015-02-13 08:45:14 +0100 |
|---|---|---|
| committer | Carlos Martín Nieto <[email protected]> | 2015-02-13 08:45:14 +0100 |
| commit | 94b1f7d07dd3786de15f44e3faf2a3e4d680a0b8 (patch) | |
| tree | 52621afd24aa27659e531ce535e44955c0f5aeaf /graph.go | |
| parent | ce8bcbf9663c8b36f309f98ccedbd64b57b8125d (diff) | |
| parent | dddcbb71c45932feef3c2d0fe6fbdf375b0de644 (diff) | |
Merge pull request #173 from AaronO/add/graph-methods
Add bindings for git_graph_* methods
Diffstat (limited to 'graph.go')
| -rw-r--r-- | graph.go | 36 |
1 files changed, 36 insertions, 0 deletions
diff --git a/graph.go b/graph.go new file mode 100644 index 0000000..e5d7732 --- /dev/null +++ b/graph.go @@ -0,0 +1,36 @@ +package git + +/* +#include <git2.h> +*/ +import "C" +import ( + "runtime" +) + +func (repo *Repository) DescendantOf(commit, ancestor *Oid) (bool, error) { + runtime.LockOSThread() + defer runtime.UnlockOSThread() + + ret := C.git_graph_descendant_of(repo.ptr, commit.toC(), ancestor.toC()) + if ret < 0 { + return false, MakeGitError(ret) + } + + return (ret > 0), nil +} + +func (repo *Repository) AheadBehind(local, upstream *Oid) (ahead, behind int, err error) { + runtime.LockOSThread() + defer runtime.UnlockOSThread() + + var aheadT C.size_t + var behindT C.size_t + + ret := C.git_graph_ahead_behind(&aheadT, &behindT, repo.ptr, local.toC(), upstream.toC()) + if ret < 0 { + return 0, 0, MakeGitError(ret) + } + + return int(aheadT), int(behindT), nil +} |
