summaryrefslogtreecommitdiff
path: root/index.go
diff options
context:
space:
mode:
authorCarlos Martín Nieto <[email protected]>2015-05-30 22:23:23 +0200
committerCarlos Martín Nieto <[email protected]>2015-05-30 22:23:23 +0200
commit35ff0de8559ed987ff82b025cc2bb5983f29e559 (patch)
tree62b2ffe5ef7c32f89a49bb722c1cce85b2a9656b /index.go
parent193deb7ae3cbc5d5a1f7f186aae6edb20bff950a (diff)
parente8531dd5c31fc87044e9061b18f37df9b05bd0ac (diff)
Merge pull request #196 from pks-t/pointer-indirection
[WIP/RFC] Pointer indirection
Diffstat (limited to 'index.go')
-rw-r--r--index.go28
1 files changed, 17 insertions, 11 deletions
diff --git a/index.go b/index.go
index 1a899f1..c1bfb74 100644
--- a/index.go
+++ b/index.go
@@ -162,16 +162,17 @@ func (v *Index) AddAll(pathspecs []string, flags IndexAddOpts, callback IndexMat
runtime.LockOSThread()
defer runtime.UnlockOSThread()
- var cb *IndexMatchedPathCallback
+ var handle unsafe.Pointer
if callback != nil {
- cb = &callback
+ handle = pointerHandles.Track(callback)
+ defer pointerHandles.Untrack(handle)
}
ret := C._go_git_index_add_all(
v.ptr,
&cpathspecs,
C.uint(flags),
- unsafe.Pointer(cb),
+ handle,
)
if ret < 0 {
return MakeGitError(ret)
@@ -188,15 +189,16 @@ func (v *Index) UpdateAll(pathspecs []string, callback IndexMatchedPathCallback)
runtime.LockOSThread()
defer runtime.UnlockOSThread()
- var cb *IndexMatchedPathCallback
+ var handle unsafe.Pointer
if callback != nil {
- cb = &callback
+ handle = pointerHandles.Track(callback)
+ defer pointerHandles.Untrack(handle)
}
ret := C._go_git_index_update_all(
v.ptr,
&cpathspecs,
- unsafe.Pointer(cb),
+ handle,
)
if ret < 0 {
return MakeGitError(ret)
@@ -213,15 +215,16 @@ func (v *Index) RemoveAll(pathspecs []string, callback IndexMatchedPathCallback)
runtime.LockOSThread()
defer runtime.UnlockOSThread()
- var cb *IndexMatchedPathCallback
+ var handle unsafe.Pointer
if callback != nil {
- cb = &callback
+ handle = pointerHandles.Track(callback)
+ defer pointerHandles.Untrack(handle)
}
ret := C._go_git_index_remove_all(
v.ptr,
&cpathspecs,
- unsafe.Pointer(cb),
+ handle,
)
if ret < 0 {
return MakeGitError(ret)
@@ -231,8 +234,11 @@ func (v *Index) RemoveAll(pathspecs []string, callback IndexMatchedPathCallback)
//export indexMatchedPathCallback
func indexMatchedPathCallback(cPath, cMatchedPathspec *C.char, payload unsafe.Pointer) int {
- callback := (*IndexMatchedPathCallback)(payload)
- return (*callback)(C.GoString(cPath), C.GoString(cMatchedPathspec))
+ if callback, ok := pointerHandles.Get(payload).(IndexMatchedPathCallback); ok {
+ return callback(C.GoString(cPath), C.GoString(cMatchedPathspec))
+ } else {
+ panic("invalid matched path callback")
+ }
}
func (v *Index) RemoveByPath(path string) error {