summaryrefslogtreecommitdiff
path: root/repository.go
diff options
context:
space:
mode:
authorAidan Nulman <[email protected]>2014-01-29 18:10:38 -0500
committerAidan Nulman <[email protected]>2014-01-29 18:10:38 -0500
commitd59f6d6d9029e7ee75602a850b57292bbd1db761 (patch)
treee9341ad7caecc1048e355a2c7adfcb92f8b739ed /repository.go
parentf610cf25d71d44881b31157832b49e793efc2d56 (diff)
parentf66502aaf44862a8671285e80327d808afee155f (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.go27
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()
}