summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorCarlos Martín Nieto <[email protected]>2015-02-13 08:45:14 +0100
committerCarlos Martín Nieto <[email protected]>2015-02-13 08:45:14 +0100
commit94b1f7d07dd3786de15f44e3faf2a3e4d680a0b8 (patch)
tree52621afd24aa27659e531ce535e44955c0f5aeaf
parentce8bcbf9663c8b36f309f98ccedbd64b57b8125d (diff)
parentdddcbb71c45932feef3c2d0fe6fbdf375b0de644 (diff)
Merge pull request #173 from AaronO/add/graph-methods
Add bindings for git_graph_* methods
-rw-r--r--graph.go36
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
+}