diff options
| author | Carlos Martín Nieto <[email protected]> | 2015-12-29 13:21:41 +0000 |
|---|---|---|
| committer | Carlos Martín Nieto <[email protected]> | 2015-12-29 13:21:41 +0000 |
| commit | 105573ac7a37a3a270f17d59f0e9916edc98f7ab (patch) | |
| tree | ab0b1fbd70d429c25db5ceb01a430edba97efdd4 | |
| parent | 9022ab9c195e646f9e9928b4ab3f2e83c8f04268 (diff) | |
| parent | 20ab28bfeacbfd0c0b1a83e471de8de5610f9de8 (diff) | |
Merge pull request #275 from clearr/index-find
Add Index.Find() and Index.FindPrefix()
| -rw-r--r-- | index.go | 30 |
1 files changed, 30 insertions, 0 deletions
@@ -363,6 +363,36 @@ func (v *Index) EntryByPath(path string, stage int) (*IndexEntry, error) { return newIndexEntryFromC(centry), nil } +func (v *Index) Find(path string) (uint, error) { + cpath := C.CString(path) + defer C.free(unsafe.Pointer(cpath)) + + runtime.LockOSThread() + defer runtime.UnlockOSThread() + + var pos C.size_t + ret := C.git_index_find(&pos, v.ptr, cpath) + if ret < 0 { + return uint(0), MakeGitError(ret) + } + return uint(pos), nil +} + +func (v *Index) FindPrefix(prefix string) (uint, error) { + cprefix := C.CString(prefix) + defer C.free(unsafe.Pointer(cprefix)) + + runtime.LockOSThread() + defer runtime.UnlockOSThread() + + var pos C.size_t + ret := C.git_index_find_prefix(&pos, v.ptr, cprefix) + if ret < 0 { + return uint(0), MakeGitError(ret) + } + return uint(pos), nil +} + func (v *Index) HasConflicts() bool { return C.git_index_has_conflicts(v.ptr) != 0 } |
