diff options
| author | Carlos Martín Nieto <[email protected]> | 2014-02-27 17:03:39 +0100 |
|---|---|---|
| committer | Carlos Martín Nieto <[email protected]> | 2014-02-27 17:03:39 +0100 |
| commit | fc6d0fbfff9988cf51d43d605dc1a909e8ca0aac (patch) | |
| tree | 02c004b97a586cf44d7dfef98b5ed3df477289b0 /repository.go | |
| parent | c431fe3c2c7d82626df6b3f3e1a9301648b4088b (diff) | |
| parent | ca2c3c6db287f469736ff635167cd54f29b8a067 (diff) | |
Merge pull request #59 from libgit2/cmn/refs
Add a few reference utility functions
Diffstat (limited to 'repository.go')
| -rw-r--r-- | repository.go | 49 |
1 files changed, 49 insertions, 0 deletions
diff --git a/repository.go b/repository.go index 933bafc..bf6aee5 100644 --- a/repository.go +++ b/repository.go @@ -342,3 +342,52 @@ func (v *Repository) RevparseSingle(spec string) (Object, error) { return allocObject(ptr), nil } + +// EnsureLog ensures that there is a reflog for the given reference +// name and creates an empty one if necessary. +func (v *Repository) EnsureLog(name string) error { + cname := C.CString(name) + defer C.free(unsafe.Pointer(cname)) + + runtime.LockOSThread() + defer runtime.UnlockOSThread() + + if ret := C.git_reference_ensure_log(v.ptr, cname); ret < 0 { + return LastError() + } + + return nil +} + +// HasLog returns whether there is a reflog for the given reference +// name +func (v *Repository) HasLog(name string) (bool, error) { + cname := C.CString(name) + defer C.free(unsafe.Pointer(cname)) + + runtime.LockOSThread() + defer runtime.UnlockOSThread() + + ret := C.git_reference_has_log(v.ptr, cname) + if ret < 0 { + return false, LastError() + } + + return ret == 1, nil +} + +// DwimReference looks up a reference by DWIMing its short name +func (v *Repository) DwimReference(name string) (*Reference, error) { + cname := C.CString(name) + defer C.free(unsafe.Pointer(cname)) + + runtime.LockOSThread() + defer runtime.UnlockOSThread() + + var ptr *C.git_reference + if ret := C.git_reference_dwim(&ptr, v.ptr, cname); ret < 0 { + return nil, LastError() + } + + return newReferenceFromC(ptr), nil +} |
