summaryrefslogtreecommitdiff
path: root/repository.go
diff options
context:
space:
mode:
Diffstat (limited to 'repository.go')
-rw-r--r--repository.go31
1 files changed, 27 insertions, 4 deletions
diff --git a/repository.go b/repository.go
index 871c49c..bd6f773 100644
--- a/repository.go
+++ b/repository.go
@@ -2,7 +2,7 @@ package git
/*
#include <git2.h>
-#include <git2/errors.h>
+#include <git2/sys/repository.h>
*/
import "C"
import (
@@ -51,6 +51,22 @@ func InitRepository(path string, isbare bool) (*Repository, error) {
return repo, nil
}
+func NewRepositoryWrapOdb(odb *Odb) (repo *Repository, err error) {
+ repo = new(Repository)
+
+ ret := C.git_repository_wrap_odb(&repo.ptr, odb.ptr)
+ if ret < 0 {
+ return nil, MakeGitError(ret)
+ }
+
+ runtime.SetFinalizer(repo, (*Repository).Free)
+ return repo, nil
+}
+
+func (v *Repository) SetRefdb(refdb *Refdb) {
+ C.git_repository_set_refdb(v.ptr, refdb.ptr)
+}
+
func (v *Repository) Free() {
runtime.SetFinalizer(v, nil)
C.git_repository_free(v.ptr)
@@ -284,6 +300,11 @@ func (v *Odb) Free() {
C.git_odb_free(v.ptr)
}
+func (v *Refdb) Free() {
+ runtime.SetFinalizer(v, nil)
+ C.git_refdb_free(v.ptr)
+}
+
func (v *Repository) Odb() (odb *Odb, err error) {
odb = new(Odb)
@@ -295,7 +316,7 @@ func (v *Repository) Odb() (odb *Odb, err error) {
}
runtime.SetFinalizer(odb, (*Odb).Free)
- return
+ return odb, nil
}
func (repo *Repository) Path() string {
@@ -380,7 +401,8 @@ func (v *Repository) EnsureLog(name string) error {
runtime.LockOSThread()
defer runtime.UnlockOSThread()
- if ret := C.git_reference_ensure_log(v.ptr, cname); ret < 0 {
+ ret := C.git_reference_ensure_log(v.ptr, cname)
+ if ret < 0 {
return MakeGitError(ret)
}
@@ -413,7 +435,8 @@ func (v *Repository) DwimReference(name string) (*Reference, error) {
defer runtime.UnlockOSThread()
var ptr *C.git_reference
- if ret := C.git_reference_dwim(&ptr, v.ptr, cname); ret < 0 {
+ ret := C.git_reference_dwim(&ptr, v.ptr, cname)
+ if ret < 0 {
return nil, MakeGitError(ret)
}