From 691d8f23bad4e6ff850fd0504bc7a8ed1cd656e9 Mon Sep 17 00:00:00 2001 From: David Calavera Date: Thu, 24 Jul 2014 17:41:10 -0700 Subject: [PATCH] Add Repository#RevParseSingle. --- revparse.go | 17 +++++++++++++++++ revparse_test.go | 14 +++++++++++++- 2 files changed, 30 insertions(+), 1 deletion(-) diff --git a/revparse.go b/revparse.go index bc9a4e2..9cd494f 100644 --- a/revparse.go +++ b/revparse.go @@ -58,3 +58,20 @@ func (r *Repository) RevParse(spec string) (*RevSpec, error) { return newRevSpecFrom(ptr, r), nil } + +func (r *Repository) RevParseSingle(spec string) (Object, error) { + cspec := C.CString(spec) + defer C.free(unsafe.Pointer(cspec)) + + var obj *C.git_object + + runtime.LockOSThread() + defer runtime.UnlockOSThread() + + ecode := C.git_revparse_single(&obj, r.ptr, cspec) + if ecode != 0 { + return nil, MakeGitError(ecode) + } + + return allocObject(obj, r), nil +} diff --git a/revparse_test.go b/revparse_test.go index 45dc7dc..df553a0 100644 --- a/revparse_test.go +++ b/revparse_test.go @@ -5,7 +5,7 @@ import ( "testing" ) -func TestRevParseSingle(t *testing.T) { +func TestRevParse(t *testing.T) { repo := createTestRepo(t) defer os.RemoveAll(repo.Workdir()) @@ -17,6 +17,18 @@ func TestRevParseSingle(t *testing.T) { checkObject(t, revSpec.From(), commitId) } +func TestRevParseSingle(t *testing.T) { + repo := createTestRepo(t) + defer os.RemoveAll(repo.Workdir()) + + commitId, _ := seedTestRepo(t, repo) + + obj, err := repo.RevParseSingle("HEAD") + checkFatal(t, err) + + checkObject(t, obj, commitId) +} + func checkObject(t *testing.T, obj Object, id *Oid) { if obj == nil { t.Fatalf("bad object")