diff options
| author | Carlos Martín Nieto <[email protected]> | 2013-09-18 09:23:47 +0200 |
|---|---|---|
| committer | Carlos Martín Nieto <[email protected]> | 2013-12-18 16:18:32 +0100 |
| commit | a40bdfd4202db244bfc5da348a0f0c528ef122cd (patch) | |
| tree | 115fcae49287c82eb55bb275cbbd4556fbed72b7 /odb.go | |
| parent | 625ffd022e2c39f3820543cc1239deeb21837266 (diff) | |
Lock the OS thread when acessing errors
The library stores error information in thread-local storage, which
means we need to make sure that the Go runtime doesn't switch OS
threads between the time we call a function and th time we attempt to
retrieve the error information.
Diffstat (limited to 'odb.go')
| -rw-r--r-- | odb.go | 8 |
1 files changed, 8 insertions, 0 deletions
@@ -25,6 +25,10 @@ func (v *Odb) Exists(oid *Oid) bool { func (v *Odb) Write(data []byte, otype ObjectType) (oid *Oid, err error) { oid = new(Oid) hdr := (*reflect.SliceHeader)(unsafe.Pointer(&data)) + + runtime.LockOSThread() + defer runtime.UnlockOSThread() + ret := C.git_odb_write(oid.toC(), v.ptr, unsafe.Pointer(hdr.Data), C.size_t(hdr.Len), C.git_otype(otype)) if ret < 0 { @@ -36,6 +40,10 @@ func (v *Odb) Write(data []byte, otype ObjectType) (oid *Oid, err error) { func (v *Odb) Read(oid *Oid) (obj *OdbObject, err error) { obj = new(OdbObject) + + runtime.LockOSThread() + defer runtime.UnlockOSThread() + ret := C.git_odb_read(&obj.ptr, v.ptr, oid.toC()) if ret < 0 { return nil, LastError() |
