diff options
| author | Aidan Nulman <[email protected]> | 2014-01-29 18:10:38 -0500 |
|---|---|---|
| committer | Aidan Nulman <[email protected]> | 2014-01-29 18:10:38 -0500 |
| commit | d59f6d6d9029e7ee75602a850b57292bbd1db761 (patch) | |
| tree | e9341ad7caecc1048e355a2c7adfcb92f8b739ed /repository.go | |
| parent | f610cf25d71d44881b31157832b49e793efc2d56 (diff) | |
| parent | f66502aaf44862a8671285e80327d808afee155f (diff) | |
Merge branch 'catchupTo66af84' into custom_odb
Conflicts:
git.go
reference.go
repository.go
submodule.go
Diffstat (limited to 'repository.go')
| -rw-r--r-- | repository.go | 27 |
1 files changed, 19 insertions, 8 deletions
diff --git a/repository.go b/repository.go index 8c6e8f8..68b9aba 100644 --- a/repository.go +++ b/repository.go @@ -158,15 +158,20 @@ func (v *Repository) LookupReference(name string) (*Reference, error) { return newReferenceFromC(ptr), nil } -func (v *Repository) CreateReference(name string, oid *Oid, force bool) (*Reference, error) { +func (v *Repository) CreateReference(name string, oid *Oid, force bool, sig *Signature, msg string) (*Reference, error) { cname := C.CString(name) defer C.free(unsafe.Pointer(cname)) + + csig := sig.toC() + defer C.free(unsafe.Pointer(csig)) + + cmsg := C.CString(msg) + defer C.free(unsafe.Pointer(cmsg)) + var ptr *C.git_reference - runtime.LockOSThread() - defer runtime.UnlockOSThread() + ecode := C.git_reference_create(&ptr, v.ptr, cname, oid.toC(), cbool(force), csig, cmsg) - ecode := C.git_reference_create(&ptr, v.ptr, cname, oid.toC(), cbool(force)) if ecode < 0 { return nil, LastError() } @@ -174,17 +179,23 @@ func (v *Repository) CreateReference(name string, oid *Oid, force bool) (*Refere return newReferenceFromC(ptr), nil } -func (v *Repository) CreateSymbolicReference(name, target string, force bool) (*Reference, error) { +func (v *Repository) CreateSymbolicReference(name, target string, force bool, sig *Signature, msg string) (*Reference, error) { cname := C.CString(name) defer C.free(unsafe.Pointer(cname)) + ctarget := C.CString(target) defer C.free(unsafe.Pointer(ctarget)) + + csig := sig.toC() + defer C.free(unsafe.Pointer(csig)) + + cmsg := C.CString(msg) + defer C.free(unsafe.Pointer(cmsg)) + var ptr *C.git_reference - runtime.LockOSThread() - defer runtime.UnlockOSThread() + ecode := C.git_reference_symbolic_create(&ptr, v.ptr, cname, ctarget, cbool(force), csig, cmsg) - ecode := C.git_reference_symbolic_create(&ptr, v.ptr, cname, ctarget, cbool(force)) if ecode < 0 { return nil, LastError() } |
