2  * The backend-independent part of the reference module.
 
  11 #include "refs/refs-internal.h"
 
  12 #include "run-command.h"
 
  13 #include "object-store.h"
 
  16 #include "submodule.h"
 
  19 #include "repository.h"
 
  23  * List of all available backends
 
  25 static struct ref_storage_be *refs_backends = &refs_be_files;
 
  27 static struct ref_storage_be *find_ref_storage_backend(const char *name)
 
  29         struct ref_storage_be *be;
 
  30         for (be = refs_backends; be; be = be->next)
 
  31                 if (!strcmp(be->name, name))
 
  36 int ref_storage_backend_exists(const char *name)
 
  38         return find_ref_storage_backend(name) != NULL;
 
  42  * How to handle various characters in refnames:
 
  43  * 0: An acceptable character for refs
 
  45  * 2: ., look for a preceding . to reject .. in refs
 
  46  * 3: {, look for a preceding @ to reject @{ in refs
 
  47  * 4: A bad character: ASCII control characters, and
 
  48  *    ":", "?", "[", "\", "^", "~", SP, or TAB
 
  49  * 5: *, reject unless REFNAME_REFSPEC_PATTERN is set
 
  51 static unsigned char refname_disposition[256] = {
 
  52         1, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4,
 
  53         4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4,
 
  54         4, 0, 0, 0, 0, 0, 0, 0, 0, 0, 5, 0, 0, 0, 2, 1,
 
  55         0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 4, 0, 0, 0, 0, 4,
 
  56         0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
 
  57         0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 4, 4, 0, 4, 0,
 
  58         0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
 
  59         0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 3, 0, 0, 4, 4
 
  63  * Try to read one refname component from the front of refname.
 
  64  * Return the length of the component found, or -1 if the component is
 
  65  * not legal.  It is legal if it is something reasonable to have under
 
  66  * ".git/refs/"; We do not like it if:
 
  68  * - it begins with ".", or
 
  69  * - it has double dots "..", or
 
  70  * - it has ASCII control characters, or
 
  71  * - it has ":", "?", "[", "\", "^", "~", SP, or TAB anywhere, or
 
  72  * - it has "*" anywhere unless REFNAME_REFSPEC_PATTERN is set, or
 
  73  * - it ends with a "/", or
 
  74  * - it ends with ".lock", or
 
  75  * - it contains a "@{" portion
 
  77  * When sanitized is not NULL, instead of rejecting the input refname
 
  78  * as an error, try to come up with a usable replacement for the input
 
  81 static int check_refname_component(const char *refname, int *flags,
 
  82                                    struct strbuf *sanitized)
 
  86         size_t component_start = 0; /* garbage - not a reasonable initial value */
 
  89                 component_start = sanitized->len;
 
  91         for (cp = refname; ; cp++) {
 
  93                 unsigned char disp = refname_disposition[ch];
 
  95                 if (sanitized && disp != 1)
 
  96                         strbuf_addch(sanitized, ch);
 
 102                         if (last == '.') { /* Refname contains "..". */
 
 104                                         /* collapse ".." to single "." */
 
 105                                         strbuf_setlen(sanitized, sanitized->len - 1);
 
 111                         if (last == '@') { /* Refname contains "@{". */
 
 113                                         sanitized->buf[sanitized->len-1] = '-';
 
 121                                 sanitized->buf[sanitized->len-1] = '-';
 
 126                         if (!(*flags & REFNAME_REFSPEC_PATTERN)) {
 
 127                                 /* refspec can't be a pattern */
 
 129                                         sanitized->buf[sanitized->len-1] = '-';
 
 135                          * Unset the pattern flag so that we only accept
 
 136                          * a single asterisk for one side of refspec.
 
 138                         *flags &= ~ REFNAME_REFSPEC_PATTERN;
 
 145                 return 0; /* Component has zero length. */
 
 147         if (refname[0] == '.') { /* Component starts with '.'. */
 
 149                         sanitized->buf[component_start] = '-';
 
 153         if (cp - refname >= LOCK_SUFFIX_LEN &&
 
 154             !memcmp(cp - LOCK_SUFFIX_LEN, LOCK_SUFFIX, LOCK_SUFFIX_LEN)) {
 
 157                 /* Refname ends with ".lock". */
 
 158                 while (strbuf_strip_suffix(sanitized, LOCK_SUFFIX)) {
 
 159                         /* try again in case we have .lock.lock */
 
 165 static int check_or_sanitize_refname(const char *refname, int flags,
 
 166                                      struct strbuf *sanitized)
 
 168         int component_len, component_count = 0;
 
 170         if (!strcmp(refname, "@")) {
 
 171                 /* Refname is a single character '@'. */
 
 173                         strbuf_addch(sanitized, '-');
 
 179                 if (sanitized && sanitized->len)
 
 180                         strbuf_complete(sanitized, '/');
 
 182                 /* We are at the start of a path component. */
 
 183                 component_len = check_refname_component(refname, &flags,
 
 185                 if (sanitized && component_len == 0)
 
 186                         ; /* OK, omit empty component */
 
 187                 else if (component_len <= 0)
 
 191                 if (refname[component_len] == '\0')
 
 193                 /* Skip to next component. */
 
 194                 refname += component_len + 1;
 
 197         if (refname[component_len - 1] == '.') {
 
 198                 /* Refname ends with '.'. */
 
 200                         ; /* omit ending dot */
 
 204         if (!(flags & REFNAME_ALLOW_ONELEVEL) && component_count < 2)
 
 205                 return -1; /* Refname has only one component. */
 
 209 int check_refname_format(const char *refname, int flags)
 
 211         return check_or_sanitize_refname(refname, flags, NULL);
 
 214 void sanitize_refname_component(const char *refname, struct strbuf *out)
 
 216         if (check_or_sanitize_refname(refname, REFNAME_ALLOW_ONELEVEL, out))
 
 217                 BUG("sanitizing refname '%s' check returned error", refname);
 
 220 int refname_is_safe(const char *refname)
 
 224         if (skip_prefix(refname, "refs/", &rest)) {
 
 227                 size_t restlen = strlen(rest);
 
 229                 /* rest must not be empty, or start or end with "/" */
 
 230                 if (!restlen || *rest == '/' || rest[restlen - 1] == '/')
 
 234                  * Does the refname try to escape refs/?
 
 235                  * For example: refs/foo/../bar is safe but refs/foo/../../bar
 
 238                 buf = xmallocz(restlen);
 
 239                 result = !normalize_path_copy(buf, rest) && !strcmp(buf, rest);
 
 245                 if (!isupper(*refname) && *refname != '_')
 
 253  * Return true if refname, which has the specified oid and flags, can
 
 254  * be resolved to an object in the database. If the referred-to object
 
 255  * does not exist, emit a warning and return false.
 
 257 int ref_resolves_to_object(const char *refname,
 
 258                            const struct object_id *oid,
 
 261         if (flags & REF_ISBROKEN)
 
 263         if (!has_object_file(oid)) {
 
 264                 error(_("%s does not point to a valid object!"), refname);
 
 270 char *refs_resolve_refdup(struct ref_store *refs,
 
 271                           const char *refname, int resolve_flags,
 
 272                           struct object_id *oid, int *flags)
 
 276         result = refs_resolve_ref_unsafe(refs, refname, resolve_flags,
 
 278         return xstrdup_or_null(result);
 
 281 char *resolve_refdup(const char *refname, int resolve_flags,
 
 282                      struct object_id *oid, int *flags)
 
 284         return refs_resolve_refdup(get_main_ref_store(the_repository),
 
 285                                    refname, resolve_flags,
 
 289 /* The argument to filter_refs */
 
 297 int refs_read_ref_full(struct ref_store *refs, const char *refname,
 
 298                        int resolve_flags, struct object_id *oid, int *flags)
 
 300         if (refs_resolve_ref_unsafe(refs, refname, resolve_flags, oid, flags))
 
 305 int read_ref_full(const char *refname, int resolve_flags, struct object_id *oid, int *flags)
 
 307         return refs_read_ref_full(get_main_ref_store(the_repository), refname,
 
 308                                   resolve_flags, oid, flags);
 
 311 int read_ref(const char *refname, struct object_id *oid)
 
 313         return read_ref_full(refname, RESOLVE_REF_READING, oid, NULL);
 
 316 int refs_ref_exists(struct ref_store *refs, const char *refname)
 
 318         return !!refs_resolve_ref_unsafe(refs, refname, RESOLVE_REF_READING, NULL, NULL);
 
 321 int ref_exists(const char *refname)
 
 323         return refs_ref_exists(get_main_ref_store(the_repository), refname);
 
 326 static int filter_refs(const char *refname, const struct object_id *oid,
 
 327                            int flags, void *data)
 
 329         struct ref_filter *filter = (struct ref_filter *)data;
 
 331         if (wildmatch(filter->pattern, refname, 0))
 
 334                 skip_prefix(refname, filter->prefix, &refname);
 
 335         return filter->fn(refname, oid, flags, filter->cb_data);
 
 338 enum peel_status peel_object(const struct object_id *name, struct object_id *oid)
 
 340         struct object *o = lookup_unknown_object(name);
 
 342         if (o->type == OBJ_NONE) {
 
 343                 int type = oid_object_info(the_repository, name, NULL);
 
 344                 if (type < 0 || !object_as_type(o, type, 0))
 
 348         if (o->type != OBJ_TAG)
 
 351         o = deref_tag_noverify(o);
 
 355         oidcpy(oid, &o->oid);
 
 359 struct warn_if_dangling_data {
 
 362         const struct string_list *refnames;
 
 366 static int warn_if_dangling_symref(const char *refname, const struct object_id *oid,
 
 367                                    int flags, void *cb_data)
 
 369         struct warn_if_dangling_data *d = cb_data;
 
 370         const char *resolves_to;
 
 372         if (!(flags & REF_ISSYMREF))
 
 375         resolves_to = resolve_ref_unsafe(refname, 0, NULL, NULL);
 
 378                 ? strcmp(resolves_to, d->refname)
 
 379                 : !string_list_has_string(d->refnames, resolves_to))) {
 
 383         fprintf(d->fp, d->msg_fmt, refname);
 
 388 void warn_dangling_symref(FILE *fp, const char *msg_fmt, const char *refname)
 
 390         struct warn_if_dangling_data data;
 
 393         data.refname = refname;
 
 394         data.refnames = NULL;
 
 395         data.msg_fmt = msg_fmt;
 
 396         for_each_rawref(warn_if_dangling_symref, &data);
 
 399 void warn_dangling_symrefs(FILE *fp, const char *msg_fmt, const struct string_list *refnames)
 
 401         struct warn_if_dangling_data data;
 
 405         data.refnames = refnames;
 
 406         data.msg_fmt = msg_fmt;
 
 407         for_each_rawref(warn_if_dangling_symref, &data);
 
 410 int refs_for_each_tag_ref(struct ref_store *refs, each_ref_fn fn, void *cb_data)
 
 412         return refs_for_each_ref_in(refs, "refs/tags/", fn, cb_data);
 
 415 int for_each_tag_ref(each_ref_fn fn, void *cb_data)
 
 417         return refs_for_each_tag_ref(get_main_ref_store(the_repository), fn, cb_data);
 
 420 int refs_for_each_branch_ref(struct ref_store *refs, each_ref_fn fn, void *cb_data)
 
 422         return refs_for_each_ref_in(refs, "refs/heads/", fn, cb_data);
 
 425 int for_each_branch_ref(each_ref_fn fn, void *cb_data)
 
 427         return refs_for_each_branch_ref(get_main_ref_store(the_repository), fn, cb_data);
 
 430 int refs_for_each_remote_ref(struct ref_store *refs, each_ref_fn fn, void *cb_data)
 
 432         return refs_for_each_ref_in(refs, "refs/remotes/", fn, cb_data);
 
 435 int for_each_remote_ref(each_ref_fn fn, void *cb_data)
 
 437         return refs_for_each_remote_ref(get_main_ref_store(the_repository), fn, cb_data);
 
 440 int head_ref_namespaced(each_ref_fn fn, void *cb_data)
 
 442         struct strbuf buf = STRBUF_INIT;
 
 444         struct object_id oid;
 
 447         strbuf_addf(&buf, "%sHEAD", get_git_namespace());
 
 448         if (!read_ref_full(buf.buf, RESOLVE_REF_READING, &oid, &flag))
 
 449                 ret = fn(buf.buf, &oid, flag, cb_data);
 
 450         strbuf_release(&buf);
 
 455 void normalize_glob_ref(struct string_list_item *item, const char *prefix,
 
 458         struct strbuf normalized_pattern = STRBUF_INIT;
 
 461                 BUG("pattern must not start with '/'");
 
 464                 strbuf_addstr(&normalized_pattern, prefix);
 
 466         else if (!starts_with(pattern, "refs/"))
 
 467                 strbuf_addstr(&normalized_pattern, "refs/");
 
 468         strbuf_addstr(&normalized_pattern, pattern);
 
 469         strbuf_strip_suffix(&normalized_pattern, "/");
 
 471         item->string = strbuf_detach(&normalized_pattern, NULL);
 
 472         item->util = has_glob_specials(pattern) ? NULL : item->string;
 
 473         strbuf_release(&normalized_pattern);
 
 476 int for_each_glob_ref_in(each_ref_fn fn, const char *pattern,
 
 477         const char *prefix, void *cb_data)
 
 479         struct strbuf real_pattern = STRBUF_INIT;
 
 480         struct ref_filter filter;
 
 483         if (!prefix && !starts_with(pattern, "refs/"))
 
 484                 strbuf_addstr(&real_pattern, "refs/");
 
 486                 strbuf_addstr(&real_pattern, prefix);
 
 487         strbuf_addstr(&real_pattern, pattern);
 
 489         if (!has_glob_specials(pattern)) {
 
 490                 /* Append implied '/' '*' if not present. */
 
 491                 strbuf_complete(&real_pattern, '/');
 
 492                 /* No need to check for '*', there is none. */
 
 493                 strbuf_addch(&real_pattern, '*');
 
 496         filter.pattern = real_pattern.buf;
 
 497         filter.prefix = prefix;
 
 499         filter.cb_data = cb_data;
 
 500         ret = for_each_ref(filter_refs, &filter);
 
 502         strbuf_release(&real_pattern);
 
 506 int for_each_glob_ref(each_ref_fn fn, const char *pattern, void *cb_data)
 
 508         return for_each_glob_ref_in(fn, pattern, NULL, cb_data);
 
 511 const char *prettify_refname(const char *name)
 
 513         if (skip_prefix(name, "refs/heads/", &name) ||
 
 514             skip_prefix(name, "refs/tags/", &name) ||
 
 515             skip_prefix(name, "refs/remotes/", &name))
 
 520 static const char *ref_rev_parse_rules[] = {
 
 526         "refs/remotes/%.*s/HEAD",
 
 530 #define NUM_REV_PARSE_RULES (ARRAY_SIZE(ref_rev_parse_rules) - 1)
 
 533  * Is it possible that the caller meant full_name with abbrev_name?
 
 534  * If so return a non-zero value to signal "yes"; the magnitude of
 
 535  * the returned value gives the precedence used for disambiguation.
 
 537  * If abbrev_name cannot mean full_name, return 0.
 
 539 int refname_match(const char *abbrev_name, const char *full_name)
 
 542         const int abbrev_name_len = strlen(abbrev_name);
 
 543         const int num_rules = NUM_REV_PARSE_RULES;
 
 545         for (p = ref_rev_parse_rules; *p; p++)
 
 546                 if (!strcmp(full_name, mkpath(*p, abbrev_name_len, abbrev_name)))
 
 547                         return &ref_rev_parse_rules[num_rules] - p;
 
 553  * Given a 'prefix' expand it by the rules in 'ref_rev_parse_rules' and add
 
 554  * the results to 'prefixes'
 
 556 void expand_ref_prefix(struct strvec *prefixes, const char *prefix)
 
 559         int len = strlen(prefix);
 
 561         for (p = ref_rev_parse_rules; *p; p++)
 
 562                 strvec_pushf(prefixes, *p, len, prefix);
 
 565 static const char default_branch_name_advice[] = N_(
 
 566 "Using '%s' as the name for the initial branch. This default branch name\n"
 
 567 "is subject to change. To configure the initial branch name to use in all\n"
 
 568 "of your new repositories, which will suppress this warning, call:\n"
 
 570 "\tgit config --global init.defaultBranch <name>\n"
 
 572 "Names commonly chosen instead of 'master' are 'main', 'trunk' and\n"
 
 573 "'development'. The just-created branch can be renamed via this command:\n"
 
 575 "\tgit branch -m <name>\n"
 
 578 char *repo_default_branch_name(struct repository *r, int quiet)
 
 580         const char *config_key = "init.defaultbranch";
 
 581         const char *config_display_key = "init.defaultBranch";
 
 582         char *ret = NULL, *full_ref;
 
 583         const char *env = getenv("GIT_TEST_DEFAULT_INITIAL_BRANCH_NAME");
 
 587         else if (repo_config_get_string(r, config_key, &ret) < 0)
 
 588                 die(_("could not retrieve `%s`"), config_display_key);
 
 591                 ret = xstrdup("master");
 
 593                         advise(_(default_branch_name_advice), ret);
 
 596         full_ref = xstrfmt("refs/heads/%s", ret);
 
 597         if (check_refname_format(full_ref, 0))
 
 598                 die(_("invalid branch name: %s = %s"), config_display_key, ret);
 
 604 const char *git_default_branch_name(int quiet)
 
 609                 ret = repo_default_branch_name(the_repository, quiet);
 
 615  * *string and *len will only be substituted, and *string returned (for
 
 616  * later free()ing) if the string passed in is a magic short-hand form
 
 619 static char *substitute_branch_name(struct repository *r,
 
 620                                     const char **string, int *len,
 
 621                                     int nonfatal_dangling_mark)
 
 623         struct strbuf buf = STRBUF_INIT;
 
 624         struct interpret_branch_name_options options = {
 
 625                 .nonfatal_dangling_mark = nonfatal_dangling_mark
 
 627         int ret = repo_interpret_branch_name(r, *string, *len, &buf, &options);
 
 631                 *string = strbuf_detach(&buf, &size);
 
 633                 return (char *)*string;
 
 639 int repo_dwim_ref(struct repository *r, const char *str, int len,
 
 640                   struct object_id *oid, char **ref, int nonfatal_dangling_mark)
 
 642         char *last_branch = substitute_branch_name(r, &str, &len,
 
 643                                                    nonfatal_dangling_mark);
 
 644         int   refs_found  = expand_ref(r, str, len, oid, ref);
 
 649 int expand_ref(struct repository *repo, const char *str, int len,
 
 650                struct object_id *oid, char **ref)
 
 654         struct strbuf fullref = STRBUF_INIT;
 
 657         for (p = ref_rev_parse_rules; *p; p++) {
 
 658                 struct object_id oid_from_ref;
 
 659                 struct object_id *this_result;
 
 662                 this_result = refs_found ? &oid_from_ref : oid;
 
 663                 strbuf_reset(&fullref);
 
 664                 strbuf_addf(&fullref, *p, len, str);
 
 665                 r = refs_resolve_ref_unsafe(get_main_ref_store(repo),
 
 666                                             fullref.buf, RESOLVE_REF_READING,
 
 671                         if (!warn_ambiguous_refs)
 
 673                 } else if ((flag & REF_ISSYMREF) && strcmp(fullref.buf, "HEAD")) {
 
 674                         warning(_("ignoring dangling symref %s"), fullref.buf);
 
 675                 } else if ((flag & REF_ISBROKEN) && strchr(fullref.buf, '/')) {
 
 676                         warning(_("ignoring broken ref %s"), fullref.buf);
 
 679         strbuf_release(&fullref);
 
 683 int repo_dwim_log(struct repository *r, const char *str, int len,
 
 684                   struct object_id *oid, char **log)
 
 686         struct ref_store *refs = get_main_ref_store(r);
 
 687         char *last_branch = substitute_branch_name(r, &str, &len, 0);
 
 690         struct strbuf path = STRBUF_INIT;
 
 693         for (p = ref_rev_parse_rules; *p; p++) {
 
 694                 struct object_id hash;
 
 695                 const char *ref, *it;
 
 698                 strbuf_addf(&path, *p, len, str);
 
 699                 ref = refs_resolve_ref_unsafe(refs, path.buf,
 
 704                 if (refs_reflog_exists(refs, path.buf))
 
 706                 else if (strcmp(ref, path.buf) &&
 
 707                          refs_reflog_exists(refs, ref))
 
 715                 if (!warn_ambiguous_refs)
 
 718         strbuf_release(&path);
 
 723 int dwim_log(const char *str, int len, struct object_id *oid, char **log)
 
 725         return repo_dwim_log(the_repository, str, len, oid, log);
 
 728 static int is_per_worktree_ref(const char *refname)
 
 730         return starts_with(refname, "refs/worktree/") ||
 
 731                starts_with(refname, "refs/bisect/") ||
 
 732                starts_with(refname, "refs/rewritten/");
 
 735 static int is_pseudoref_syntax(const char *refname)
 
 739         for (c = refname; *c; c++) {
 
 740                 if (!isupper(*c) && *c != '-' && *c != '_')
 
 747 static int is_main_pseudoref_syntax(const char *refname)
 
 749         return skip_prefix(refname, "main-worktree/", &refname) &&
 
 751                 is_pseudoref_syntax(refname);
 
 754 static int is_other_pseudoref_syntax(const char *refname)
 
 756         if (!skip_prefix(refname, "worktrees/", &refname))
 
 758         refname = strchr(refname, '/');
 
 759         if (!refname || !refname[1])
 
 761         return is_pseudoref_syntax(refname + 1);
 
 764 enum ref_type ref_type(const char *refname)
 
 766         if (is_per_worktree_ref(refname))
 
 767                 return REF_TYPE_PER_WORKTREE;
 
 768         if (is_pseudoref_syntax(refname))
 
 769                 return REF_TYPE_PSEUDOREF;
 
 770         if (is_main_pseudoref_syntax(refname))
 
 771                 return REF_TYPE_MAIN_PSEUDOREF;
 
 772         if (is_other_pseudoref_syntax(refname))
 
 773                 return REF_TYPE_OTHER_PSEUDOREF;
 
 774         return REF_TYPE_NORMAL;
 
 777 long get_files_ref_lock_timeout_ms(void)
 
 779         static int configured = 0;
 
 781         /* The default timeout is 100 ms: */
 
 782         static int timeout_ms = 100;
 
 785                 git_config_get_int("core.filesreflocktimeout", &timeout_ms);
 
 792 int refs_delete_ref(struct ref_store *refs, const char *msg,
 
 794                     const struct object_id *old_oid,
 
 797         struct ref_transaction *transaction;
 
 798         struct strbuf err = STRBUF_INIT;
 
 800         transaction = ref_store_transaction_begin(refs, &err);
 
 802             ref_transaction_delete(transaction, refname, old_oid,
 
 804             ref_transaction_commit(transaction, &err)) {
 
 805                 error("%s", err.buf);
 
 806                 ref_transaction_free(transaction);
 
 807                 strbuf_release(&err);
 
 810         ref_transaction_free(transaction);
 
 811         strbuf_release(&err);
 
 815 int delete_ref(const char *msg, const char *refname,
 
 816                const struct object_id *old_oid, unsigned int flags)
 
 818         return refs_delete_ref(get_main_ref_store(the_repository), msg, refname,
 
 822 static void copy_reflog_msg(struct strbuf *sb, const char *msg)
 
 827         while ((c = *msg++)) {
 
 828                 if (wasspace && isspace(c))
 
 830                 wasspace = isspace(c);
 
 838 static char *normalize_reflog_message(const char *msg)
 
 840         struct strbuf sb = STRBUF_INIT;
 
 843                 copy_reflog_msg(&sb, msg);
 
 844         return strbuf_detach(&sb, NULL);
 
 847 int should_autocreate_reflog(const char *refname)
 
 849         switch (log_all_ref_updates) {
 
 850         case LOG_REFS_ALWAYS:
 
 852         case LOG_REFS_NORMAL:
 
 853                 return starts_with(refname, "refs/heads/") ||
 
 854                         starts_with(refname, "refs/remotes/") ||
 
 855                         starts_with(refname, "refs/notes/") ||
 
 856                         !strcmp(refname, "HEAD");
 
 862 int is_branch(const char *refname)
 
 864         return !strcmp(refname, "HEAD") || starts_with(refname, "refs/heads/");
 
 867 struct read_ref_at_cb {
 
 872         struct object_id *oid;
 
 875         struct object_id ooid;
 
 876         struct object_id noid;
 
 880         timestamp_t *cutoff_time;
 
 885 static int read_ref_at_ent(struct object_id *ooid, struct object_id *noid,
 
 886                 const char *email, timestamp_t timestamp, int tz,
 
 887                 const char *message, void *cb_data)
 
 889         struct read_ref_at_cb *cb = cb_data;
 
 893         cb->date = timestamp;
 
 895         if (timestamp <= cb->at_time || cb->cnt == 0) {
 
 897                         *cb->msg = xstrdup(message);
 
 899                         *cb->cutoff_time = timestamp;
 
 903                         *cb->cutoff_cnt = cb->reccnt - 1;
 
 905                  * we have not yet updated cb->[n|o]oid so they still
 
 906                  * hold the values for the previous record.
 
 908                 if (!is_null_oid(&cb->ooid)) {
 
 909                         oidcpy(cb->oid, noid);
 
 910                         if (!oideq(&cb->ooid, noid))
 
 911                                 warning(_("log for ref %s has gap after %s"),
 
 912                                         cb->refname, show_date(cb->date, cb->tz, DATE_MODE(RFC2822)));
 
 914                 else if (cb->date == cb->at_time)
 
 915                         oidcpy(cb->oid, noid);
 
 916                 else if (!oideq(noid, cb->oid))
 
 917                         warning(_("log for ref %s unexpectedly ended on %s"),
 
 918                                 cb->refname, show_date(cb->date, cb->tz,
 
 919                                                        DATE_MODE(RFC2822)));
 
 920                 oidcpy(&cb->ooid, ooid);
 
 921                 oidcpy(&cb->noid, noid);
 
 925         oidcpy(&cb->ooid, ooid);
 
 926         oidcpy(&cb->noid, noid);
 
 932 static int read_ref_at_ent_oldest(struct object_id *ooid, struct object_id *noid,
 
 933                                   const char *email, timestamp_t timestamp,
 
 934                                   int tz, const char *message, void *cb_data)
 
 936         struct read_ref_at_cb *cb = cb_data;
 
 939                 *cb->msg = xstrdup(message);
 
 941                 *cb->cutoff_time = timestamp;
 
 945                 *cb->cutoff_cnt = cb->reccnt;
 
 946         oidcpy(cb->oid, ooid);
 
 947         if (is_null_oid(cb->oid))
 
 948                 oidcpy(cb->oid, noid);
 
 949         /* We just want the first entry */
 
 953 int read_ref_at(struct ref_store *refs, const char *refname,
 
 954                 unsigned int flags, timestamp_t at_time, int cnt,
 
 955                 struct object_id *oid, char **msg,
 
 956                 timestamp_t *cutoff_time, int *cutoff_tz, int *cutoff_cnt)
 
 958         struct read_ref_at_cb cb;
 
 960         memset(&cb, 0, sizeof(cb));
 
 961         cb.refname = refname;
 
 962         cb.at_time = at_time;
 
 965         cb.cutoff_time = cutoff_time;
 
 966         cb.cutoff_tz = cutoff_tz;
 
 967         cb.cutoff_cnt = cutoff_cnt;
 
 970         refs_for_each_reflog_ent_reverse(refs, refname, read_ref_at_ent, &cb);
 
 973                 if (flags & GET_OID_QUIETLY)
 
 976                         die(_("log for %s is empty"), refname);
 
 981         refs_for_each_reflog_ent(refs, refname, read_ref_at_ent_oldest, &cb);
 
 986 struct ref_transaction *ref_store_transaction_begin(struct ref_store *refs,
 
 989         struct ref_transaction *tr;
 
 992         tr = xcalloc(1, sizeof(struct ref_transaction));
 
 993         tr->ref_store = refs;
 
 997 struct ref_transaction *ref_transaction_begin(struct strbuf *err)
 
 999         return ref_store_transaction_begin(get_main_ref_store(the_repository), err);
 
1002 void ref_transaction_free(struct ref_transaction *transaction)
 
1009         switch (transaction->state) {
 
1010         case REF_TRANSACTION_OPEN:
 
1011         case REF_TRANSACTION_CLOSED:
 
1014         case REF_TRANSACTION_PREPARED:
 
1015                 BUG("free called on a prepared reference transaction");
 
1018                 BUG("unexpected reference transaction state");
 
1022         for (i = 0; i < transaction->nr; i++) {
 
1023                 free(transaction->updates[i]->msg);
 
1024                 free(transaction->updates[i]);
 
1026         free(transaction->updates);
 
1030 struct ref_update *ref_transaction_add_update(
 
1031                 struct ref_transaction *transaction,
 
1032                 const char *refname, unsigned int flags,
 
1033                 const struct object_id *new_oid,
 
1034                 const struct object_id *old_oid,
 
1037         struct ref_update *update;
 
1039         if (transaction->state != REF_TRANSACTION_OPEN)
 
1040                 BUG("update called for transaction that is not open");
 
1042         FLEX_ALLOC_STR(update, refname, refname);
 
1043         ALLOC_GROW(transaction->updates, transaction->nr + 1, transaction->alloc);
 
1044         transaction->updates[transaction->nr++] = update;
 
1046         update->flags = flags;
 
1048         if (flags & REF_HAVE_NEW)
 
1049                 oidcpy(&update->new_oid, new_oid);
 
1050         if (flags & REF_HAVE_OLD)
 
1051                 oidcpy(&update->old_oid, old_oid);
 
1052         update->msg = normalize_reflog_message(msg);
 
1056 int ref_transaction_update(struct ref_transaction *transaction,
 
1057                            const char *refname,
 
1058                            const struct object_id *new_oid,
 
1059                            const struct object_id *old_oid,
 
1060                            unsigned int flags, const char *msg,
 
1065         if ((new_oid && !is_null_oid(new_oid)) ?
 
1066             check_refname_format(refname, REFNAME_ALLOW_ONELEVEL) :
 
1067             !refname_is_safe(refname)) {
 
1068                 strbuf_addf(err, _("refusing to update ref with bad name '%s'"),
 
1073         if (flags & ~REF_TRANSACTION_UPDATE_ALLOWED_FLAGS)
 
1074                 BUG("illegal flags 0x%x passed to ref_transaction_update()", flags);
 
1076         flags |= (new_oid ? REF_HAVE_NEW : 0) | (old_oid ? REF_HAVE_OLD : 0);
 
1078         ref_transaction_add_update(transaction, refname, flags,
 
1079                                    new_oid, old_oid, msg);
 
1083 int ref_transaction_create(struct ref_transaction *transaction,
 
1084                            const char *refname,
 
1085                            const struct object_id *new_oid,
 
1086                            unsigned int flags, const char *msg,
 
1089         if (!new_oid || is_null_oid(new_oid))
 
1090                 BUG("create called without valid new_oid");
 
1091         return ref_transaction_update(transaction, refname, new_oid,
 
1092                                       &null_oid, flags, msg, err);
 
1095 int ref_transaction_delete(struct ref_transaction *transaction,
 
1096                            const char *refname,
 
1097                            const struct object_id *old_oid,
 
1098                            unsigned int flags, const char *msg,
 
1101         if (old_oid && is_null_oid(old_oid))
 
1102                 BUG("delete called with old_oid set to zeros");
 
1103         return ref_transaction_update(transaction, refname,
 
1108 int ref_transaction_verify(struct ref_transaction *transaction,
 
1109                            const char *refname,
 
1110                            const struct object_id *old_oid,
 
1115                 BUG("verify called with old_oid set to NULL");
 
1116         return ref_transaction_update(transaction, refname,
 
1121 int refs_update_ref(struct ref_store *refs, const char *msg,
 
1122                     const char *refname, const struct object_id *new_oid,
 
1123                     const struct object_id *old_oid, unsigned int flags,
 
1124                     enum action_on_err onerr)
 
1126         struct ref_transaction *t = NULL;
 
1127         struct strbuf err = STRBUF_INIT;
 
1130         t = ref_store_transaction_begin(refs, &err);
 
1132             ref_transaction_update(t, refname, new_oid, old_oid, flags, msg,
 
1134             ref_transaction_commit(t, &err)) {
 
1136                 ref_transaction_free(t);
 
1139                 const char *str = _("update_ref failed for ref '%s': %s");
 
1142                 case UPDATE_REFS_MSG_ON_ERR:
 
1143                         error(str, refname, err.buf);
 
1145                 case UPDATE_REFS_DIE_ON_ERR:
 
1146                         die(str, refname, err.buf);
 
1148                 case UPDATE_REFS_QUIET_ON_ERR:
 
1151                 strbuf_release(&err);
 
1154         strbuf_release(&err);
 
1156                 ref_transaction_free(t);
 
1160 int update_ref(const char *msg, const char *refname,
 
1161                const struct object_id *new_oid,
 
1162                const struct object_id *old_oid,
 
1163                unsigned int flags, enum action_on_err onerr)
 
1165         return refs_update_ref(get_main_ref_store(the_repository), msg, refname, new_oid,
 
1166                                old_oid, flags, onerr);
 
1169 char *refs_shorten_unambiguous_ref(struct ref_store *refs,
 
1170                                    const char *refname, int strict)
 
1173         static char **scanf_fmts;
 
1174         static int nr_rules;
 
1176         struct strbuf resolved_buf = STRBUF_INIT;
 
1180                  * Pre-generate scanf formats from ref_rev_parse_rules[].
 
1181                  * Generate a format suitable for scanf from a
 
1182                  * ref_rev_parse_rules rule by interpolating "%s" at the
 
1183                  * location of the "%.*s".
 
1185                 size_t total_len = 0;
 
1188                 /* the rule list is NULL terminated, count them first */
 
1189                 for (nr_rules = 0; ref_rev_parse_rules[nr_rules]; nr_rules++)
 
1190                         /* -2 for strlen("%.*s") - strlen("%s"); +1 for NUL */
 
1191                         total_len += strlen(ref_rev_parse_rules[nr_rules]) - 2 + 1;
 
1193                 scanf_fmts = xmalloc(st_add(st_mult(sizeof(char *), nr_rules), total_len));
 
1196                 for (i = 0; i < nr_rules; i++) {
 
1197                         assert(offset < total_len);
 
1198                         scanf_fmts[i] = (char *)&scanf_fmts[nr_rules] + offset;
 
1199                         offset += xsnprintf(scanf_fmts[i], total_len - offset,
 
1200                                             ref_rev_parse_rules[i], 2, "%s") + 1;
 
1204         /* bail out if there are no rules */
 
1206                 return xstrdup(refname);
 
1208         /* buffer for scanf result, at most refname must fit */
 
1209         short_name = xstrdup(refname);
 
1211         /* skip first rule, it will always match */
 
1212         for (i = nr_rules - 1; i > 0 ; --i) {
 
1214                 int rules_to_fail = i;
 
1217                 if (1 != sscanf(refname, scanf_fmts[i], short_name))
 
1220                 short_name_len = strlen(short_name);
 
1223                  * in strict mode, all (except the matched one) rules
 
1224                  * must fail to resolve to a valid non-ambiguous ref
 
1227                         rules_to_fail = nr_rules;
 
1230                  * check if the short name resolves to a valid ref,
 
1231                  * but use only rules prior to the matched one
 
1233                 for (j = 0; j < rules_to_fail; j++) {
 
1234                         const char *rule = ref_rev_parse_rules[j];
 
1236                         /* skip matched rule */
 
1241                          * the short name is ambiguous, if it resolves
 
1242                          * (with this previous rule) to a valid ref
 
1243                          * read_ref() returns 0 on success
 
1245                         strbuf_reset(&resolved_buf);
 
1246                         strbuf_addf(&resolved_buf, rule,
 
1247                                     short_name_len, short_name);
 
1248                         if (refs_ref_exists(refs, resolved_buf.buf))
 
1253                  * short name is non-ambiguous if all previous rules
 
1254                  * haven't resolved to a valid ref
 
1256                 if (j == rules_to_fail) {
 
1257                         strbuf_release(&resolved_buf);
 
1262         strbuf_release(&resolved_buf);
 
1264         return xstrdup(refname);
 
1267 char *shorten_unambiguous_ref(const char *refname, int strict)
 
1269         return refs_shorten_unambiguous_ref(get_main_ref_store(the_repository),
 
1273 static struct string_list *hide_refs;
 
1275 int parse_hide_refs_config(const char *var, const char *value, const char *section)
 
1278         if (!strcmp("transfer.hiderefs", var) ||
 
1279             (!parse_config_key(var, section, NULL, NULL, &key) &&
 
1280              !strcmp(key, "hiderefs"))) {
 
1285                         return config_error_nonbool(var);
 
1286                 ref = xstrdup(value);
 
1288                 while (len && ref[len - 1] == '/')
 
1291                         hide_refs = xcalloc(1, sizeof(*hide_refs));
 
1292                         hide_refs->strdup_strings = 1;
 
1294                 string_list_append(hide_refs, ref);
 
1299 int ref_is_hidden(const char *refname, const char *refname_full)
 
1305         for (i = hide_refs->nr - 1; i >= 0; i--) {
 
1306                 const char *match = hide_refs->items[i].string;
 
1307                 const char *subject;
 
1311                 if (*match == '!') {
 
1316                 if (*match == '^') {
 
1317                         subject = refname_full;
 
1323                 /* refname can be NULL when namespaces are used. */
 
1325                     skip_prefix(subject, match, &p) &&
 
1332 const char *find_descendant_ref(const char *dirname,
 
1333                                 const struct string_list *extras,
 
1334                                 const struct string_list *skip)
 
1342          * Look at the place where dirname would be inserted into
 
1343          * extras. If there is an entry at that position that starts
 
1344          * with dirname (remember, dirname includes the trailing
 
1345          * slash) and is not in skip, then we have a conflict.
 
1347         for (pos = string_list_find_insert_index(extras, dirname, 0);
 
1348              pos < extras->nr; pos++) {
 
1349                 const char *extra_refname = extras->items[pos].string;
 
1351                 if (!starts_with(extra_refname, dirname))
 
1354                 if (!skip || !string_list_has_string(skip, extra_refname))
 
1355                         return extra_refname;
 
1360 int refs_rename_ref_available(struct ref_store *refs,
 
1361                               const char *old_refname,
 
1362                               const char *new_refname)
 
1364         struct string_list skip = STRING_LIST_INIT_NODUP;
 
1365         struct strbuf err = STRBUF_INIT;
 
1368         string_list_insert(&skip, old_refname);
 
1369         ok = !refs_verify_refname_available(refs, new_refname,
 
1372                 error("%s", err.buf);
 
1374         string_list_clear(&skip, 0);
 
1375         strbuf_release(&err);
 
1379 int refs_head_ref(struct ref_store *refs, each_ref_fn fn, void *cb_data)
 
1381         struct object_id oid;
 
1384         if (!refs_read_ref_full(refs, "HEAD", RESOLVE_REF_READING,
 
1386                 return fn("HEAD", &oid, flag, cb_data);
 
1391 int head_ref(each_ref_fn fn, void *cb_data)
 
1393         return refs_head_ref(get_main_ref_store(the_repository), fn, cb_data);
 
1396 struct ref_iterator *refs_ref_iterator_begin(
 
1397                 struct ref_store *refs,
 
1398                 const char *prefix, int trim, int flags)
 
1400         struct ref_iterator *iter;
 
1402         if (ref_paranoia < 0)
 
1403                 ref_paranoia = git_env_bool("GIT_REF_PARANOIA", 0);
 
1405                 flags |= DO_FOR_EACH_INCLUDE_BROKEN;
 
1407         iter = refs->be->iterator_begin(refs, prefix, flags);
 
1410          * `iterator_begin()` already takes care of prefix, but we
 
1411          * might need to do some trimming:
 
1414                 iter = prefix_ref_iterator_begin(iter, "", trim);
 
1416         /* Sanity check for subclasses: */
 
1418                 BUG("reference iterator is not ordered");
 
1424  * Call fn for each reference in the specified submodule for which the
 
1425  * refname begins with prefix. If trim is non-zero, then trim that
 
1426  * many characters off the beginning of each refname before passing
 
1427  * the refname to fn. flags can be DO_FOR_EACH_INCLUDE_BROKEN to
 
1428  * include broken references in the iteration. If fn ever returns a
 
1429  * non-zero value, stop the iteration and return that value;
 
1430  * otherwise, return 0.
 
1432 static int do_for_each_repo_ref(struct repository *r, const char *prefix,
 
1433                                 each_repo_ref_fn fn, int trim, int flags,
 
1436         struct ref_iterator *iter;
 
1437         struct ref_store *refs = get_main_ref_store(r);
 
1442         iter = refs_ref_iterator_begin(refs, prefix, trim, flags);
 
1444         return do_for_each_repo_ref_iterator(r, iter, fn, cb_data);
 
1447 struct do_for_each_ref_help {
 
1452 static int do_for_each_ref_helper(struct repository *r,
 
1453                                   const char *refname,
 
1454                                   const struct object_id *oid,
 
1458         struct do_for_each_ref_help *hp = cb_data;
 
1460         return hp->fn(refname, oid, flags, hp->cb_data);
 
1463 static int do_for_each_ref(struct ref_store *refs, const char *prefix,
 
1464                            each_ref_fn fn, int trim, int flags, void *cb_data)
 
1466         struct ref_iterator *iter;
 
1467         struct do_for_each_ref_help hp = { fn, cb_data };
 
1472         iter = refs_ref_iterator_begin(refs, prefix, trim, flags);
 
1474         return do_for_each_repo_ref_iterator(the_repository, iter,
 
1475                                         do_for_each_ref_helper, &hp);
 
1478 int refs_for_each_ref(struct ref_store *refs, each_ref_fn fn, void *cb_data)
 
1480         return do_for_each_ref(refs, "", fn, 0, 0, cb_data);
 
1483 int for_each_ref(each_ref_fn fn, void *cb_data)
 
1485         return refs_for_each_ref(get_main_ref_store(the_repository), fn, cb_data);
 
1488 int refs_for_each_ref_in(struct ref_store *refs, const char *prefix,
 
1489                          each_ref_fn fn, void *cb_data)
 
1491         return do_for_each_ref(refs, prefix, fn, strlen(prefix), 0, cb_data);
 
1494 int for_each_ref_in(const char *prefix, each_ref_fn fn, void *cb_data)
 
1496         return refs_for_each_ref_in(get_main_ref_store(the_repository), prefix, fn, cb_data);
 
1499 int for_each_fullref_in(const char *prefix, each_ref_fn fn, void *cb_data, unsigned int broken)
 
1501         unsigned int flag = 0;
 
1504                 flag = DO_FOR_EACH_INCLUDE_BROKEN;
 
1505         return do_for_each_ref(get_main_ref_store(the_repository),
 
1506                                prefix, fn, 0, flag, cb_data);
 
1509 int refs_for_each_fullref_in(struct ref_store *refs, const char *prefix,
 
1510                              each_ref_fn fn, void *cb_data,
 
1511                              unsigned int broken)
 
1513         unsigned int flag = 0;
 
1516                 flag = DO_FOR_EACH_INCLUDE_BROKEN;
 
1517         return do_for_each_ref(refs, prefix, fn, 0, flag, cb_data);
 
1520 int for_each_replace_ref(struct repository *r, each_repo_ref_fn fn, void *cb_data)
 
1522         return do_for_each_repo_ref(r, git_replace_ref_base, fn,
 
1523                                     strlen(git_replace_ref_base),
 
1524                                     DO_FOR_EACH_INCLUDE_BROKEN, cb_data);
 
1527 int for_each_namespaced_ref(each_ref_fn fn, void *cb_data)
 
1529         struct strbuf buf = STRBUF_INIT;
 
1531         strbuf_addf(&buf, "%srefs/", get_git_namespace());
 
1532         ret = do_for_each_ref(get_main_ref_store(the_repository),
 
1533                               buf.buf, fn, 0, 0, cb_data);
 
1534         strbuf_release(&buf);
 
1538 int refs_for_each_rawref(struct ref_store *refs, each_ref_fn fn, void *cb_data)
 
1540         return do_for_each_ref(refs, "", fn, 0,
 
1541                                DO_FOR_EACH_INCLUDE_BROKEN, cb_data);
 
1544 int for_each_rawref(each_ref_fn fn, void *cb_data)
 
1546         return refs_for_each_rawref(get_main_ref_store(the_repository), fn, cb_data);
 
1549 static int refs_read_special_head(struct ref_store *ref_store,
 
1550                                   const char *refname, struct object_id *oid,
 
1551                                   struct strbuf *referent, unsigned int *type)
 
1553         struct strbuf full_path = STRBUF_INIT;
 
1554         struct strbuf content = STRBUF_INIT;
 
1556         strbuf_addf(&full_path, "%s/%s", ref_store->gitdir, refname);
 
1558         if (strbuf_read_file(&content, full_path.buf, 0) < 0)
 
1561         result = parse_loose_ref_contents(content.buf, oid, referent, type);
 
1564         strbuf_release(&full_path);
 
1565         strbuf_release(&content);
 
1569 int refs_read_raw_ref(struct ref_store *ref_store,
 
1570                       const char *refname, struct object_id *oid,
 
1571                       struct strbuf *referent, unsigned int *type)
 
1573         if (!strcmp(refname, "FETCH_HEAD") || !strcmp(refname, "MERGE_HEAD")) {
 
1574                 return refs_read_special_head(ref_store, refname, oid, referent,
 
1578         return ref_store->be->read_raw_ref(ref_store, refname, oid, referent,
 
1582 /* This function needs to return a meaningful errno on failure */
 
1583 const char *refs_resolve_ref_unsafe(struct ref_store *refs,
 
1584                                     const char *refname,
 
1586                                     struct object_id *oid, int *flags)
 
1588         static struct strbuf sb_refname = STRBUF_INIT;
 
1589         struct object_id unused_oid;
 
1596                 flags = &unused_flags;
 
1600         if (check_refname_format(refname, REFNAME_ALLOW_ONELEVEL)) {
 
1601                 if (!(resolve_flags & RESOLVE_REF_ALLOW_BAD_NAME) ||
 
1602                     !refname_is_safe(refname)) {
 
1608                  * dwim_ref() uses REF_ISBROKEN to distinguish between
 
1609                  * missing refs and refs that were present but invalid,
 
1610                  * to complain about the latter to stderr.
 
1612                  * We don't know whether the ref exists, so don't set
 
1615                 *flags |= REF_BAD_NAME;
 
1618         for (symref_count = 0; symref_count < SYMREF_MAXDEPTH; symref_count++) {
 
1619                 unsigned int read_flags = 0;
 
1621                 if (refs_read_raw_ref(refs, refname,
 
1622                                       oid, &sb_refname, &read_flags)) {
 
1623                         *flags |= read_flags;
 
1625                         /* In reading mode, refs must eventually resolve */
 
1626                         if (resolve_flags & RESOLVE_REF_READING)
 
1630                          * Otherwise a missing ref is OK. But the files backend
 
1631                          * may show errors besides ENOENT if there are
 
1632                          * similarly-named refs.
 
1634                         if (errno != ENOENT &&
 
1640                         if (*flags & REF_BAD_NAME)
 
1641                                 *flags |= REF_ISBROKEN;
 
1645                 *flags |= read_flags;
 
1647                 if (!(read_flags & REF_ISSYMREF)) {
 
1648                         if (*flags & REF_BAD_NAME) {
 
1650                                 *flags |= REF_ISBROKEN;
 
1655                 refname = sb_refname.buf;
 
1656                 if (resolve_flags & RESOLVE_REF_NO_RECURSE) {
 
1660                 if (check_refname_format(refname, REFNAME_ALLOW_ONELEVEL)) {
 
1661                         if (!(resolve_flags & RESOLVE_REF_ALLOW_BAD_NAME) ||
 
1662                             !refname_is_safe(refname)) {
 
1667                         *flags |= REF_ISBROKEN | REF_BAD_NAME;
 
1675 /* backend functions */
 
1676 int refs_init_db(struct strbuf *err)
 
1678         struct ref_store *refs = get_main_ref_store(the_repository);
 
1680         return refs->be->init_db(refs, err);
 
1683 const char *resolve_ref_unsafe(const char *refname, int resolve_flags,
 
1684                                struct object_id *oid, int *flags)
 
1686         return refs_resolve_ref_unsafe(get_main_ref_store(the_repository), refname,
 
1687                                        resolve_flags, oid, flags);
 
1690 int resolve_gitlink_ref(const char *submodule, const char *refname,
 
1691                         struct object_id *oid)
 
1693         struct ref_store *refs;
 
1696         refs = get_submodule_ref_store(submodule);
 
1701         if (!refs_resolve_ref_unsafe(refs, refname, 0, oid, &flags) ||
 
1707 struct ref_store_hash_entry
 
1709         struct hashmap_entry ent;
 
1711         struct ref_store *refs;
 
1713         /* NUL-terminated identifier of the ref store: */
 
1714         char name[FLEX_ARRAY];
 
1717 static int ref_store_hash_cmp(const void *unused_cmp_data,
 
1718                               const struct hashmap_entry *eptr,
 
1719                               const struct hashmap_entry *entry_or_key,
 
1720                               const void *keydata)
 
1722         const struct ref_store_hash_entry *e1, *e2;
 
1725         e1 = container_of(eptr, const struct ref_store_hash_entry, ent);
 
1726         e2 = container_of(entry_or_key, const struct ref_store_hash_entry, ent);
 
1727         name = keydata ? keydata : e2->name;
 
1729         return strcmp(e1->name, name);
 
1732 static struct ref_store_hash_entry *alloc_ref_store_hash_entry(
 
1733                 const char *name, struct ref_store *refs)
 
1735         struct ref_store_hash_entry *entry;
 
1737         FLEX_ALLOC_STR(entry, name, name);
 
1738         hashmap_entry_init(&entry->ent, strhash(name));
 
1743 /* A hashmap of ref_stores, stored by submodule name: */
 
1744 static struct hashmap submodule_ref_stores;
 
1746 /* A hashmap of ref_stores, stored by worktree id: */
 
1747 static struct hashmap worktree_ref_stores;
 
1750  * Look up a ref store by name. If that ref_store hasn't been
 
1751  * registered yet, return NULL.
 
1753 static struct ref_store *lookup_ref_store_map(struct hashmap *map,
 
1756         struct ref_store_hash_entry *entry;
 
1759         if (!map->tablesize)
 
1760                 /* It's initialized on demand in register_ref_store(). */
 
1763         hash = strhash(name);
 
1764         entry = hashmap_get_entry_from_hash(map, hash, name,
 
1765                                         struct ref_store_hash_entry, ent);
 
1766         return entry ? entry->refs : NULL;
 
1770  * Create, record, and return a ref_store instance for the specified
 
1773 static struct ref_store *ref_store_init(const char *gitdir,
 
1776         const char *be_name = "files";
 
1777         struct ref_storage_be *be = find_ref_storage_backend(be_name);
 
1778         struct ref_store *refs;
 
1781                 BUG("reference backend %s is unknown", be_name);
 
1783         refs = be->init(gitdir, flags);
 
1787 struct ref_store *get_main_ref_store(struct repository *r)
 
1789         if (r->refs_private)
 
1790                 return r->refs_private;
 
1793                 BUG("attempting to get main_ref_store outside of repository");
 
1795         r->refs_private = ref_store_init(r->gitdir, REF_STORE_ALL_CAPS);
 
1796         r->refs_private = maybe_debug_wrap_ref_store(r->gitdir, r->refs_private);
 
1797         return r->refs_private;
 
1801  * Associate a ref store with a name. It is a fatal error to call this
 
1802  * function twice for the same name.
 
1804 static void register_ref_store_map(struct hashmap *map,
 
1806                                    struct ref_store *refs,
 
1809         struct ref_store_hash_entry *entry;
 
1811         if (!map->tablesize)
 
1812                 hashmap_init(map, ref_store_hash_cmp, NULL, 0);
 
1814         entry = alloc_ref_store_hash_entry(name, refs);
 
1815         if (hashmap_put(map, &entry->ent))
 
1816                 BUG("%s ref_store '%s' initialized twice", type, name);
 
1819 struct ref_store *get_submodule_ref_store(const char *submodule)
 
1821         struct strbuf submodule_sb = STRBUF_INIT;
 
1822         struct ref_store *refs;
 
1823         char *to_free = NULL;
 
1829         len = strlen(submodule);
 
1830         while (len && is_dir_sep(submodule[len - 1]))
 
1836                 /* We need to strip off one or more trailing slashes */
 
1837                 submodule = to_free = xmemdupz(submodule, len);
 
1839         refs = lookup_ref_store_map(&submodule_ref_stores, submodule);
 
1843         strbuf_addstr(&submodule_sb, submodule);
 
1844         if (!is_nonbare_repository_dir(&submodule_sb))
 
1847         if (submodule_to_gitdir(&submodule_sb, submodule))
 
1850         /* assume that add_submodule_odb() has been called */
 
1851         refs = ref_store_init(submodule_sb.buf,
 
1852                               REF_STORE_READ | REF_STORE_ODB);
 
1853         register_ref_store_map(&submodule_ref_stores, "submodule",
 
1857         strbuf_release(&submodule_sb);
 
1863 struct ref_store *get_worktree_ref_store(const struct worktree *wt)
 
1865         struct ref_store *refs;
 
1869                 return get_main_ref_store(the_repository);
 
1871         id = wt->id ? wt->id : "/";
 
1872         refs = lookup_ref_store_map(&worktree_ref_stores, id);
 
1877                 refs = ref_store_init(git_common_path("worktrees/%s", wt->id),
 
1878                                       REF_STORE_ALL_CAPS);
 
1880                 refs = ref_store_init(get_git_common_dir(),
 
1881                                       REF_STORE_ALL_CAPS);
 
1884                 register_ref_store_map(&worktree_ref_stores, "worktree",
 
1889 void base_ref_store_init(struct ref_store *refs,
 
1890                          const struct ref_storage_be *be)
 
1895 /* backend functions */
 
1896 int refs_pack_refs(struct ref_store *refs, unsigned int flags)
 
1898         return refs->be->pack_refs(refs, flags);
 
1901 int refs_peel_ref(struct ref_store *refs, const char *refname,
 
1902                   struct object_id *oid)
 
1905         struct object_id base;
 
1907         if (current_ref_iter && current_ref_iter->refname == refname) {
 
1908                 struct object_id peeled;
 
1910                 if (ref_iterator_peel(current_ref_iter, &peeled))
 
1912                 oidcpy(oid, &peeled);
 
1916         if (refs_read_ref_full(refs, refname,
 
1917                                RESOLVE_REF_READING, &base, &flag))
 
1920         return peel_object(&base, oid);
 
1923 int peel_ref(const char *refname, struct object_id *oid)
 
1925         return refs_peel_ref(get_main_ref_store(the_repository), refname, oid);
 
1928 int refs_create_symref(struct ref_store *refs,
 
1929                        const char *ref_target,
 
1930                        const char *refs_heads_master,
 
1936         msg = normalize_reflog_message(logmsg);
 
1937         retval = refs->be->create_symref(refs, ref_target, refs_heads_master,
 
1943 int create_symref(const char *ref_target, const char *refs_heads_master,
 
1946         return refs_create_symref(get_main_ref_store(the_repository), ref_target,
 
1947                                   refs_heads_master, logmsg);
 
1950 int ref_update_reject_duplicates(struct string_list *refnames,
 
1953         size_t i, n = refnames->nr;
 
1957         for (i = 1; i < n; i++) {
 
1958                 int cmp = strcmp(refnames->items[i - 1].string,
 
1959                                  refnames->items[i].string);
 
1963                                     _("multiple updates for ref '%s' not allowed"),
 
1964                                     refnames->items[i].string);
 
1966                 } else if (cmp > 0) {
 
1967                         BUG("ref_update_reject_duplicates() received unsorted list");
 
1973 static int run_transaction_hook(struct ref_transaction *transaction,
 
1976         struct child_process proc = CHILD_PROCESS_INIT;
 
1977         struct strbuf buf = STRBUF_INIT;
 
1981         hook = find_hook("reference-transaction");
 
1985         strvec_pushl(&proc.args, hook, state, NULL);
 
1987         proc.stdout_to_stderr = 1;
 
1988         proc.trace2_hook_name = "reference-transaction";
 
1990         ret = start_command(&proc);
 
1994         sigchain_push(SIGPIPE, SIG_IGN);
 
1996         for (i = 0; i < transaction->nr; i++) {
 
1997                 struct ref_update *update = transaction->updates[i];
 
2000                 strbuf_addf(&buf, "%s %s %s\n",
 
2001                             oid_to_hex(&update->old_oid),
 
2002                             oid_to_hex(&update->new_oid),
 
2005                 if (write_in_full(proc.in, buf.buf, buf.len) < 0) {
 
2013         sigchain_pop(SIGPIPE);
 
2014         strbuf_release(&buf);
 
2016         ret |= finish_command(&proc);
 
2020 int ref_transaction_prepare(struct ref_transaction *transaction,
 
2023         struct ref_store *refs = transaction->ref_store;
 
2026         switch (transaction->state) {
 
2027         case REF_TRANSACTION_OPEN:
 
2030         case REF_TRANSACTION_PREPARED:
 
2031                 BUG("prepare called twice on reference transaction");
 
2033         case REF_TRANSACTION_CLOSED:
 
2034                 BUG("prepare called on a closed reference transaction");
 
2037                 BUG("unexpected reference transaction state");
 
2041         if (getenv(GIT_QUARANTINE_ENVIRONMENT)) {
 
2043                               _("ref updates forbidden inside quarantine environment"));
 
2047         ret = refs->be->transaction_prepare(refs, transaction, err);
 
2051         ret = run_transaction_hook(transaction, "prepared");
 
2053                 ref_transaction_abort(transaction, err);
 
2054                 die(_("ref updates aborted by hook"));
 
2060 int ref_transaction_abort(struct ref_transaction *transaction,
 
2063         struct ref_store *refs = transaction->ref_store;
 
2066         switch (transaction->state) {
 
2067         case REF_TRANSACTION_OPEN:
 
2068                 /* No need to abort explicitly. */
 
2070         case REF_TRANSACTION_PREPARED:
 
2071                 ret = refs->be->transaction_abort(refs, transaction, err);
 
2073         case REF_TRANSACTION_CLOSED:
 
2074                 BUG("abort called on a closed reference transaction");
 
2077                 BUG("unexpected reference transaction state");
 
2081         run_transaction_hook(transaction, "aborted");
 
2083         ref_transaction_free(transaction);
 
2087 int ref_transaction_commit(struct ref_transaction *transaction,
 
2090         struct ref_store *refs = transaction->ref_store;
 
2093         switch (transaction->state) {
 
2094         case REF_TRANSACTION_OPEN:
 
2095                 /* Need to prepare first. */
 
2096                 ret = ref_transaction_prepare(transaction, err);
 
2100         case REF_TRANSACTION_PREPARED:
 
2101                 /* Fall through to finish. */
 
2103         case REF_TRANSACTION_CLOSED:
 
2104                 BUG("commit called on a closed reference transaction");
 
2107                 BUG("unexpected reference transaction state");
 
2111         ret = refs->be->transaction_finish(refs, transaction, err);
 
2113                 run_transaction_hook(transaction, "committed");
 
2117 int refs_verify_refname_available(struct ref_store *refs,
 
2118                                   const char *refname,
 
2119                                   const struct string_list *extras,
 
2120                                   const struct string_list *skip,
 
2124         const char *extra_refname;
 
2125         struct strbuf dirname = STRBUF_INIT;
 
2126         struct strbuf referent = STRBUF_INIT;
 
2127         struct object_id oid;
 
2129         struct ref_iterator *iter;
 
2134          * For the sake of comments in this function, suppose that
 
2135          * refname is "refs/foo/bar".
 
2140         strbuf_grow(&dirname, strlen(refname) + 1);
 
2141         for (slash = strchr(refname, '/'); slash; slash = strchr(slash + 1, '/')) {
 
2142                 /* Expand dirname to the new prefix, not including the trailing slash: */
 
2143                 strbuf_add(&dirname, refname + dirname.len, slash - refname - dirname.len);
 
2146                  * We are still at a leading dir of the refname (e.g.,
 
2147                  * "refs/foo"; if there is a reference with that name,
 
2148                  * it is a conflict, *unless* it is in skip.
 
2150                 if (skip && string_list_has_string(skip, dirname.buf))
 
2153                 if (!refs_read_raw_ref(refs, dirname.buf, &oid, &referent, &type)) {
 
2154                         strbuf_addf(err, _("'%s' exists; cannot create '%s'"),
 
2155                                     dirname.buf, refname);
 
2159                 if (extras && string_list_has_string(extras, dirname.buf)) {
 
2160                         strbuf_addf(err, _("cannot process '%s' and '%s' at the same time"),
 
2161                                     refname, dirname.buf);
 
2167          * We are at the leaf of our refname (e.g., "refs/foo/bar").
 
2168          * There is no point in searching for a reference with that
 
2169          * name, because a refname isn't considered to conflict with
 
2170          * itself. But we still need to check for references whose
 
2171          * names are in the "refs/foo/bar/" namespace, because they
 
2174         strbuf_addstr(&dirname, refname + dirname.len);
 
2175         strbuf_addch(&dirname, '/');
 
2177         iter = refs_ref_iterator_begin(refs, dirname.buf, 0,
 
2178                                        DO_FOR_EACH_INCLUDE_BROKEN);
 
2179         while ((ok = ref_iterator_advance(iter)) == ITER_OK) {
 
2181                     string_list_has_string(skip, iter->refname))
 
2184                 strbuf_addf(err, _("'%s' exists; cannot create '%s'"),
 
2185                             iter->refname, refname);
 
2186                 ref_iterator_abort(iter);
 
2190         if (ok != ITER_DONE)
 
2191                 BUG("error while iterating over references");
 
2193         extra_refname = find_descendant_ref(dirname.buf, extras, skip);
 
2195                 strbuf_addf(err, _("cannot process '%s' and '%s' at the same time"),
 
2196                             refname, extra_refname);
 
2201         strbuf_release(&referent);
 
2202         strbuf_release(&dirname);
 
2206 int refs_for_each_reflog(struct ref_store *refs, each_ref_fn fn, void *cb_data)
 
2208         struct ref_iterator *iter;
 
2209         struct do_for_each_ref_help hp = { fn, cb_data };
 
2211         iter = refs->be->reflog_iterator_begin(refs);
 
2213         return do_for_each_repo_ref_iterator(the_repository, iter,
 
2214                                              do_for_each_ref_helper, &hp);
 
2217 int for_each_reflog(each_ref_fn fn, void *cb_data)
 
2219         return refs_for_each_reflog(get_main_ref_store(the_repository), fn, cb_data);
 
2222 int refs_for_each_reflog_ent_reverse(struct ref_store *refs,
 
2223                                      const char *refname,
 
2224                                      each_reflog_ent_fn fn,
 
2227         return refs->be->for_each_reflog_ent_reverse(refs, refname,
 
2231 int for_each_reflog_ent_reverse(const char *refname, each_reflog_ent_fn fn,
 
2234         return refs_for_each_reflog_ent_reverse(get_main_ref_store(the_repository),
 
2235                                                 refname, fn, cb_data);
 
2238 int refs_for_each_reflog_ent(struct ref_store *refs, const char *refname,
 
2239                              each_reflog_ent_fn fn, void *cb_data)
 
2241         return refs->be->for_each_reflog_ent(refs, refname, fn, cb_data);
 
2244 int for_each_reflog_ent(const char *refname, each_reflog_ent_fn fn,
 
2247         return refs_for_each_reflog_ent(get_main_ref_store(the_repository), refname,
 
2251 int refs_reflog_exists(struct ref_store *refs, const char *refname)
 
2253         return refs->be->reflog_exists(refs, refname);
 
2256 int reflog_exists(const char *refname)
 
2258         return refs_reflog_exists(get_main_ref_store(the_repository), refname);
 
2261 int refs_create_reflog(struct ref_store *refs, const char *refname,
 
2262                        int force_create, struct strbuf *err)
 
2264         return refs->be->create_reflog(refs, refname, force_create, err);
 
2267 int safe_create_reflog(const char *refname, int force_create,
 
2270         return refs_create_reflog(get_main_ref_store(the_repository), refname,
 
2274 int refs_delete_reflog(struct ref_store *refs, const char *refname)
 
2276         return refs->be->delete_reflog(refs, refname);
 
2279 int delete_reflog(const char *refname)
 
2281         return refs_delete_reflog(get_main_ref_store(the_repository), refname);
 
2284 int refs_reflog_expire(struct ref_store *refs,
 
2285                        const char *refname, const struct object_id *oid,
 
2287                        reflog_expiry_prepare_fn prepare_fn,
 
2288                        reflog_expiry_should_prune_fn should_prune_fn,
 
2289                        reflog_expiry_cleanup_fn cleanup_fn,
 
2290                        void *policy_cb_data)
 
2292         return refs->be->reflog_expire(refs, refname, oid, flags,
 
2293                                        prepare_fn, should_prune_fn,
 
2294                                        cleanup_fn, policy_cb_data);
 
2297 int reflog_expire(const char *refname, const struct object_id *oid,
 
2299                   reflog_expiry_prepare_fn prepare_fn,
 
2300                   reflog_expiry_should_prune_fn should_prune_fn,
 
2301                   reflog_expiry_cleanup_fn cleanup_fn,
 
2302                   void *policy_cb_data)
 
2304         return refs_reflog_expire(get_main_ref_store(the_repository),
 
2305                                   refname, oid, flags,
 
2306                                   prepare_fn, should_prune_fn,
 
2307                                   cleanup_fn, policy_cb_data);
 
2310 int initial_ref_transaction_commit(struct ref_transaction *transaction,
 
2313         struct ref_store *refs = transaction->ref_store;
 
2315         return refs->be->initial_transaction_commit(refs, transaction, err);
 
2318 int refs_delete_refs(struct ref_store *refs, const char *logmsg,
 
2319                      struct string_list *refnames, unsigned int flags)
 
2324         msg = normalize_reflog_message(logmsg);
 
2325         retval = refs->be->delete_refs(refs, msg, refnames, flags);
 
2330 int delete_refs(const char *msg, struct string_list *refnames,
 
2333         return refs_delete_refs(get_main_ref_store(the_repository), msg, refnames, flags);
 
2336 int refs_rename_ref(struct ref_store *refs, const char *oldref,
 
2337                     const char *newref, const char *logmsg)
 
2342         msg = normalize_reflog_message(logmsg);
 
2343         retval = refs->be->rename_ref(refs, oldref, newref, msg);
 
2348 int rename_ref(const char *oldref, const char *newref, const char *logmsg)
 
2350         return refs_rename_ref(get_main_ref_store(the_repository), oldref, newref, logmsg);
 
2353 int refs_copy_existing_ref(struct ref_store *refs, const char *oldref,
 
2354                     const char *newref, const char *logmsg)
 
2359         msg = normalize_reflog_message(logmsg);
 
2360         retval = refs->be->copy_ref(refs, oldref, newref, msg);
 
2365 int copy_existing_ref(const char *oldref, const char *newref, const char *logmsg)
 
2367         return refs_copy_existing_ref(get_main_ref_store(the_repository), oldref, newref, logmsg);