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 /checkout.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 'checkout.go')
| -rw-r--r-- | checkout.go | 7 |
1 files changed, 7 insertions, 0 deletions
diff --git a/checkout.go b/checkout.go index 63637e2..f4c1d4e 100644 --- a/checkout.go +++ b/checkout.go @@ -9,6 +9,7 @@ git_checkout_opts git_checkout_opts_init() { */ import "C" import ( + "runtime" "os" ) @@ -59,6 +60,9 @@ func (v *Repository) Checkout(opts *CheckoutOpts) error { var copts C.git_checkout_opts populateCheckoutOpts(&copts, opts) + runtime.LockOSThread() + defer runtime.UnlockOSThread() + ret := C.git_checkout_head(v.ptr, &copts) if ret < 0 { return LastError() @@ -72,6 +76,9 @@ func (v *Repository) CheckoutIndex(index *Index, opts *CheckoutOpts) error { var copts C.git_checkout_opts populateCheckoutOpts(&copts, opts) + runtime.LockOSThread() + defer runtime.UnlockOSThread() + ret := C.git_checkout_index(v.ptr, index.ptr, &copts) if ret < 0 { return LastError() |
