summaryrefslogtreecommitdiff
path: root/submodule.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 /submodule.go
parent193deb7ae3cbc5d5a1f7f186aae6edb20bff950a (diff)
parente8531dd5c31fc87044e9061b18f37df9b05bd0ac (diff)
Merge pull request #196 from pks-t/pointer-indirection
[WIP/RFC] Pointer indirection
Diffstat (limited to 'submodule.go')
-rw-r--r--submodule.go15
1 files changed, 11 insertions, 4 deletions
diff --git a/submodule.go b/submodule.go
index 7c6c922..3882462 100644
--- a/submodule.go
+++ b/submodule.go
@@ -97,17 +97,24 @@ func (repo *Repository) LookupSubmodule(name string) (*Submodule, error) {
type SubmoduleCbk func(sub *Submodule, name string) int
//export SubmoduleVisitor
-func SubmoduleVisitor(csub unsafe.Pointer, name *C.char, cfct unsafe.Pointer) C.int {
+func SubmoduleVisitor(csub unsafe.Pointer, name *C.char, handle unsafe.Pointer) C.int {
sub := &Submodule{(*C.git_submodule)(csub)}
- fct := *(*SubmoduleCbk)(cfct)
- return (C.int)(fct(sub, C.GoString(name)))
+
+ if callback, ok := pointerHandles.Get(handle).(SubmoduleCbk); ok {
+ return (C.int)(callback(sub, C.GoString(name)))
+ } else {
+ panic("invalid submodule visitor callback")
+ }
}
func (repo *Repository) ForeachSubmodule(cbk SubmoduleCbk) error {
runtime.LockOSThread()
defer runtime.UnlockOSThread()
- ret := C._go_git_visit_submodule(repo.ptr, unsafe.Pointer(&cbk))
+ handle := pointerHandles.Track(cbk)
+ defer pointerHandles.Untrack(handle)
+
+ ret := C._go_git_visit_submodule(repo.ptr, handle)
if ret < 0 {
return MakeGitError(ret)
}