diff options
author | Michael Haggerty <mhagger@alum.mit.edu> | 2017-03-20 17:33:07 +0100 |
---|---|---|
committer | Junio C Hamano <gitster@pobox.com> | 2017-04-14 12:54:31 +0200 |
commit | 470be518623b0ca7a30bdb1fcef483f63a8e72ec (patch) | |
tree | 48eea01b7ed599b8e4c5aeb8a962367db721b510 /refs.c | |
parent | get_ref_dir(): don't call read_loose_refs() for "refs/bisect" (diff) | |
download | git-470be518623b0ca7a30bdb1fcef483f63a8e72ec.tar.xz git-470be518623b0ca7a30bdb1fcef483f63a8e72ec.zip |
refs_read_raw_ref(): new function
Extract a new function from `refs_resolve_ref_unsafe()`. It will be
useful elsewhere.
Signed-off-by: Michael Haggerty <mhagger@alum.mit.edu>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
Diffstat (limited to 'refs.c')
-rw-r--r-- | refs.c | 11 |
1 files changed, 9 insertions, 2 deletions
@@ -1326,6 +1326,13 @@ int for_each_rawref(each_ref_fn fn, void *cb_data) return refs_for_each_rawref(get_main_ref_store(), fn, cb_data); } +int refs_read_raw_ref(struct ref_store *ref_store, + const char *refname, unsigned char *sha1, + struct strbuf *referent, unsigned int *type) +{ + return ref_store->be->read_raw_ref(ref_store, refname, sha1, referent, type); +} + /* This function needs to return a meaningful errno on failure */ const char *refs_resolve_ref_unsafe(struct ref_store *refs, const char *refname, @@ -1362,8 +1369,8 @@ const char *refs_resolve_ref_unsafe(struct ref_store *refs, for (symref_count = 0; symref_count < SYMREF_MAXDEPTH; symref_count++) { unsigned int read_flags = 0; - if (refs->be->read_raw_ref(refs, refname, - sha1, &sb_refname, &read_flags)) { + if (refs_read_raw_ref(refs, refname, + sha1, &sb_refname, &read_flags)) { *flags |= read_flags; if (errno != ENOENT || (resolve_flags & RESOLVE_REF_READING)) return NULL; |