summaryrefslogtreecommitdiff
path: root/repository.go
diff options
context:
space:
mode:
authorOndrej Kupka <[email protected]>2014-05-02 10:44:42 +0200
committerOndrej Kupka <[email protected]>2014-05-03 13:55:25 +0200
commit2cf19370bcc2082cbc0378f210073629122f88e7 (patch)
tree5dce65d4b34cd620d8a91d4ddfde9eec21cf6c8c /repository.go
parent5809f031087e5665549de3355034b193f7c13853 (diff)
Implement git_repository_set_head(_detached)
This closes #88 Signed-off-by: Ondrej Kupka <[email protected]>
Diffstat (limited to 'repository.go')
-rw-r--r--repository.go43
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))