summaryrefslogtreecommitdiff
path: root/repository.go
diff options
context:
space:
mode:
authorCarlos Martín Nieto <[email protected]>2014-05-03 19:20:34 +0200
committerCarlos Martín Nieto <[email protected]>2014-05-03 19:20:34 +0200
commit645a35dfb12041a329619d47083f7032bb57ed65 (patch)
treee6fd831dd7d6dd0548f2f650fc8cdd1e2e6d06e6 /repository.go
parent9b4c865f18d0c6241b228621f557840159119ef6 (diff)
parent2cf19370bcc2082cbc0378f210073629122f88e7 (diff)
Merge pull request #89 from tchap/set-head
Implement git_repository_set_head(_detached)
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))