summaryrefslogtreecommitdiff
path: root/refdb.go
diff options
context:
space:
mode:
authorCarlos Martín Nieto <[email protected]>2017-07-08 16:51:22 +0200
committerGitHub <[email protected]>2017-07-08 16:51:22 +0200
commit08db2e2c167404c5ed9be0fc1c995e41bad479bb (patch)
tree4a9c1357f3682d4134318e73ef85aa172cbfbd48 /refdb.go
parent29c0b730076fe402c22ea3e3a11a7ed541663637 (diff)
parent55a1096141519a1f380d0702671cfe9bf90ec435 (diff)
Merge pull request #393 from libgit2/cmn/keepalive-all-the-things
KeepAlive all the things
Diffstat (limited to 'refdb.go')
-rw-r--r--refdb.go9
1 files changed, 7 insertions, 2 deletions
diff --git a/refdb.go b/refdb.go
index 4e3ebf9..578f43c 100644
--- a/refdb.go
+++ b/refdb.go
@@ -14,6 +14,7 @@ import (
type Refdb struct {
ptr *C.git_refdb
+ r *Repository
}
type RefdbBackend struct {
@@ -21,16 +22,17 @@ type RefdbBackend struct {
}
func (v *Repository) NewRefdb() (refdb *Refdb, err error) {
- refdb = new(Refdb)
+ var ptr *C.git_refdb
runtime.LockOSThread()
defer runtime.UnlockOSThread()
- ret := C.git_refdb_new(&refdb.ptr, v.ptr)
+ ret := C.git_refdb_new(&ptr, v.ptr)
if ret < 0 {
return nil, MakeGitError(ret)
}
+ refdb = &Refdb{ptr: ptr, r: v}
runtime.SetFinalizer(refdb, (*Refdb).Free)
return refdb, nil
}
@@ -45,6 +47,8 @@ func (v *Refdb) SetBackend(backend *RefdbBackend) (err error) {
defer runtime.UnlockOSThread()
ret := C.git_refdb_set_backend(v.ptr, backend.ptr)
+ runtime.KeepAlive(v)
+ runtime.KeepAlive(backend)
if ret < 0 {
backend.Free()
return MakeGitError(ret)
@@ -53,5 +57,6 @@ func (v *Refdb) SetBackend(backend *RefdbBackend) (err error) {
}
func (v *RefdbBackend) Free() {
+ runtime.SetFinalizer(v, nil)
C._go_git_refdb_backend_free(v.ptr)
}