Browse Source

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>
maint
Michael Haggerty 8 years ago committed by Junio C Hamano
parent
commit
470be51862
  1. 9
      refs.c
  2. 4
      refs/refs-internal.h

9
refs.c

@ -1326,6 +1326,13 @@ int for_each_rawref(each_ref_fn fn, void *cb_data) @@ -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,7 +1369,7 @@ const char *refs_resolve_ref_unsafe(struct ref_store *refs, @@ -1362,7 +1369,7 @@ 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,
if (refs_read_raw_ref(refs, refname,
sha1, &sb_refname, &read_flags)) {
*flags |= read_flags;
if (errno != ENOENT || (resolve_flags & RESOLVE_REF_READING))

4
refs/refs-internal.h

@ -165,6 +165,10 @@ struct ref_update { @@ -165,6 +165,10 @@ struct ref_update {
const char refname[FLEX_ARRAY];
};

int refs_read_raw_ref(struct ref_store *ref_store,
const char *refname, unsigned char *sha1,
struct strbuf *referent, unsigned int *type);

/*
* Add a ref_update with the specified properties to transaction, and
* return a pointer to the new object. This function does not verify

Loading…
Cancel
Save