diff options
| author | Carlos Martín Nieto <[email protected]> | 2014-05-03 19:20:34 +0200 |
|---|---|---|
| committer | Carlos Martín Nieto <[email protected]> | 2014-05-03 19:20:34 +0200 |
| commit | 645a35dfb12041a329619d47083f7032bb57ed65 (patch) | |
| tree | e6fd831dd7d6dd0548f2f650fc8cdd1e2e6d06e6 | |
| parent | 9b4c865f18d0c6241b228621f557840159119ef6 (diff) | |
| parent | 2cf19370bcc2082cbc0378f210073629122f88e7 (diff) | |
Merge pull request #89 from tchap/set-head
Implement git_repository_set_head(_detached)
| -rw-r--r-- | repository.go | 43 |
1 files changed, 43 insertions, 0 deletions
diff --git a/repository.go b/repository.go index bd6f773..81a46b1 100644 --- a/repository.go +++ b/repository.go @@ -176,6 +176,49 @@ func (v *Repository) Head() (*Reference, error) { return newReferenceFromC(ptr), nil } +func (v *Repository) SetHead(refname string, sig *Signature, msg string) error { + cname := C.CString(refname) + defer C.free(unsafe.Pointer(cname)) + + csig := sig.toC() + defer C.free(unsafe.Pointer(csig)) + + var cmsg *C.char + if msg != "" { + cmsg = C.CString(msg) + defer C.free(unsafe.Pointer(cmsg)) + } + + runtime.LockOSThread() + defer runtime.UnlockOSThread() + + ecode := C.git_repository_set_head(v.ptr, cname, csig, cmsg) + if ecode != 0 { + return MakeGitError(ecode) + } + return nil +} + +func (v *Repository) SetHeadDetached(id *Oid, sig *Signature, msg string) error { + csig := sig.toC() + defer C.free(unsafe.Pointer(csig)) + + var cmsg *C.char + if msg != "" { + cmsg = C.CString(msg) + defer C.free(unsafe.Pointer(cmsg)) + } + + runtime.LockOSThread() + defer runtime.UnlockOSThread() + + ecode := C.git_repository_set_head_detached(v.ptr, id.toC(), csig, cmsg) + if ecode != 0 { + return MakeGitError(ecode) + } + return nil +} + func (v *Repository) CreateReference(name string, id *Oid, force bool, sig *Signature, msg string) (*Reference, error) { cname := C.CString(name) defer C.free(unsafe.Pointer(cname)) |
