Coverage Report

Created: 2026-03-21 06:46

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
/src/git/refs.h
Line
Count
Source
1
#ifndef REFS_H
2
#define REFS_H
3
4
#include "commit.h"
5
#include "repository.h"
6
#include "repo-settings.h"
7
8
struct fsck_options;
9
struct object_id;
10
struct ref_store;
11
struct strbuf;
12
struct string_list;
13
struct string_list_item;
14
struct worktree;
15
16
enum ref_storage_format ref_storage_format_by_name(const char *name);
17
const char *ref_storage_format_to_name(enum ref_storage_format ref_storage_format);
18
19
enum ref_transaction_error {
20
  /* Default error code */
21
  REF_TRANSACTION_ERROR_GENERIC = -1,
22
  /* Ref name conflict like A vs A/B */
23
  REF_TRANSACTION_ERROR_NAME_CONFLICT = -2,
24
  /* Ref to be created already exists */
25
  REF_TRANSACTION_ERROR_CREATE_EXISTS = -3,
26
  /* ref expected but doesn't exist */
27
  REF_TRANSACTION_ERROR_NONEXISTENT_REF = -4,
28
  /* Provided old_oid or old_target of reference doesn't match actual */
29
  REF_TRANSACTION_ERROR_INCORRECT_OLD_VALUE = -5,
30
  /* Provided new_oid or new_target is invalid */
31
  REF_TRANSACTION_ERROR_INVALID_NEW_VALUE = -6,
32
  /* Expected ref to be symref, but is a regular ref */
33
  REF_TRANSACTION_ERROR_EXPECTED_SYMREF = -7,
34
  /* Cannot create ref due to case-insensitive filesystem */
35
  REF_TRANSACTION_ERROR_CASE_CONFLICT = -8,
36
};
37
38
/*
39
 * Resolve a reference, recursively following symbolic references.
40
 *
41
 * Return the name of the non-symbolic reference that ultimately pointed
42
 * at the resolved object name.  The return value, if not NULL, is a
43
 * pointer into either a static buffer or the input ref.
44
 *
45
 * If oid is non-NULL, store the referred-to object's name in it.
46
 *
47
 * If the reference cannot be resolved to an object, the behavior
48
 * depends on the RESOLVE_REF_READING flag:
49
 *
50
 * - If RESOLVE_REF_READING is set, return NULL.
51
 *
52
 * - If RESOLVE_REF_READING is not set, clear oid and return the name of
53
 *   the last reference name in the chain, which will either be a non-symbolic
54
 *   reference or an undefined reference.  If this is a prelude to
55
 *   "writing" to the ref, the return value is the name of the ref
56
 *   that will actually be created or changed.
57
 *
58
 * If the RESOLVE_REF_NO_RECURSE flag is passed, only resolves one
59
 * level of symbolic reference.  The value stored in oid for a symbolic
60
 * reference will always be null_oid in this case, and the return
61
 * value is the reference that the symref refers to directly.
62
 *
63
 * If flags is non-NULL, set the value that it points to the
64
 * combination of REF_ISPACKED (if the reference was found among the
65
 * packed references), REF_ISSYMREF (if the initial reference was a
66
 * symbolic reference), REF_BAD_NAME (if the reference name is ill
67
 * formed --- see RESOLVE_REF_ALLOW_BAD_NAME below), and REF_ISBROKEN
68
 * (if the ref is malformed or has a bad name). See refs.h for more detail
69
 * on each flag.
70
 *
71
 * If ref is not a properly-formatted, normalized reference, return
72
 * NULL.  If more than MAXDEPTH recursive symbolic lookups are needed,
73
 * give up and return NULL.
74
 *
75
 * RESOLVE_REF_ALLOW_BAD_NAME allows resolving refs even when their
76
 * name is invalid according to git-check-ref-format(1).  If the name
77
 * is bad then the value stored in oid will be null_oid and the two
78
 * flags REF_ISBROKEN and REF_BAD_NAME will be set.
79
 *
80
 * Even with RESOLVE_REF_ALLOW_BAD_NAME, names that escape the refs/
81
 * directory and do not consist of all caps and underscores cannot be
82
 * resolved. The function returns NULL for such ref names.
83
 * Caps and underscores refers to the pseudorefs, such as HEAD,
84
 * FETCH_HEAD and friends, that all live outside of the refs/ directory.
85
 */
86
0
#define RESOLVE_REF_READING 0x01
87
0
#define RESOLVE_REF_NO_RECURSE 0x02
88
0
#define RESOLVE_REF_ALLOW_BAD_NAME 0x04
89
90
const char *refs_resolve_ref_unsafe(struct ref_store *refs,
91
            const char *refname,
92
            int resolve_flags,
93
            struct object_id *oid,
94
            int *flags);
95
96
char *refs_resolve_refdup(struct ref_store *refs,
97
        const char *refname, int resolve_flags,
98
        struct object_id *oid, int *flags);
99
100
int refs_read_ref_full(struct ref_store *refs, const char *refname,
101
           int resolve_flags, struct object_id *oid, int *flags);
102
103
int refs_read_ref(struct ref_store *refs, const char *refname, struct object_id *oid);
104
105
0
#define NOT_A_SYMREF -2
106
107
/*
108
 * Read the symbolic ref named "refname" and write its immediate referent into
109
 * the provided buffer. Referent is left empty if "refname" is not a symbolic
110
 * ref. It does not resolve the symbolic reference recursively in case the
111
 * target is also a symbolic ref.
112
 *
113
 * Returns 0 on success, -2 if the "refname" is not a symbolic ref,
114
 * -1 otherwise.
115
 */
116
int refs_read_symbolic_ref(struct ref_store *ref_store, const char *refname,
117
         struct strbuf *referent);
118
119
/*
120
 * Return 0 if a reference named refname could be created without
121
 * conflicting with the name of an existing reference. Otherwise,
122
 * return a negative value and write an explanation to err. If extras
123
 * is non-NULL, it is a list of additional refnames with which refname
124
 * is not allowed to conflict. If skip is non-NULL, ignore potential
125
 * conflicts with refs in skip (e.g., because they are scheduled for
126
 * deletion in the same operation). Behavior is undefined if the same
127
 * name is listed in both extras and skip.
128
 *
129
 * Two reference names conflict if one of them exactly matches the
130
 * leading components of the other; e.g., "foo/bar" conflicts with
131
 * both "foo" and with "foo/bar/baz" but not with "foo/bar" or
132
 * "foo/barbados".
133
 *
134
 * If `initial_transaction` is truish, then all collision checks with
135
 * preexisting refs are skipped.
136
 *
137
 * extras and skip must be sorted.
138
 */
139
enum ref_transaction_error refs_verify_refname_available(struct ref_store *refs,
140
             const char *refname,
141
             const struct string_list *extras,
142
             const struct string_list *skip,
143
             unsigned int initial_transaction,
144
             struct strbuf *err);
145
146
int refs_ref_exists(struct ref_store *refs, const char *refname);
147
148
int should_autocreate_reflog(enum log_refs_config log_all_ref_updates,
149
           const char *refname);
150
151
int is_branch(const char *refname);
152
153
0
#define REF_STORE_CREATE_ON_DISK_IS_WORKTREE (1 << 0)
154
155
int ref_store_create_on_disk(struct ref_store *refs, int flags, struct strbuf *err);
156
157
/*
158
 * Release all memory and resources associated with the ref store.
159
 */
160
void ref_store_release(struct ref_store *ref_store);
161
162
/*
163
 * Remove the ref store from disk. This deletes all associated data.
164
 */
165
int ref_store_remove_on_disk(struct ref_store *refs, struct strbuf *err);
166
167
/*
168
 * Return the peeled value of the oid currently being iterated via
169
 * for_each_ref(), etc. This is equivalent to calling:
170
 *
171
 *   peel_object(r, oid, &peeled);
172
 *
173
 * with the "oid" value given to the refs_for_each_cb callback, except
174
 * that some ref storage may be able to answer the query without
175
 * actually loading the object in memory.
176
 */
177
int peel_iterated_oid(struct repository *r,
178
          const struct object_id *base, struct object_id *peeled);
179
180
/**
181
 * Resolve refname in the nested "gitlink" repository in the specified
182
 * submodule (which must be non-NULL). If the resolution is
183
 * successful, return 0 and set oid to the name of the object;
184
 * otherwise, return a non-zero value.
185
 */
186
int repo_resolve_gitlink_ref(struct repository *r,
187
           const char *submodule, const char *refname,
188
           struct object_id *oid);
189
190
/*
191
 * Return true iff abbrev_name is a possible abbreviation for
192
 * full_name according to the rules defined by ref_rev_parse_rules in
193
 * refs.c.
194
 */
195
int refname_match(const char *abbrev_name, const char *full_name);
196
197
/*
198
 * Given a 'prefix' expand it by the rules in 'ref_rev_parse_rules' and add
199
 * the results to 'prefixes'
200
 */
201
struct strvec;
202
void expand_ref_prefix(struct strvec *prefixes, const char *prefix);
203
204
int expand_ref(struct repository *r, const char *str, int len, struct object_id *oid, char **ref);
205
int repo_dwim_ref(struct repository *r, const char *str, int len,
206
      struct object_id *oid, char **ref, int nonfatal_dangling_mark);
207
int repo_dwim_log(struct repository *r, const char *str, int len, struct object_id *oid, char **ref);
208
209
/*
210
 * Retrieves the default branch name for newly-initialized repositories.
211
 *
212
 * The return value is an allocated string.
213
 */
214
char *repo_default_branch_name(struct repository *r, int quiet);
215
216
/*
217
 * Copy "name" to "sb", expanding any special @-marks as handled by
218
 * repo_interpret_branch_name(). The result is a non-qualified branch name
219
 * (so "foo" or "origin/master" instead of "refs/heads/foo" or
220
 * "refs/remotes/origin/master").
221
 *
222
 * Note that the resulting name may not be a syntactically valid refname.
223
 *
224
 * If "allowed" is non-zero, restrict the set of allowed expansions. See
225
 * repo_interpret_branch_name() for details.
226
 */
227
void copy_branchname(struct strbuf *sb, const char *name,
228
           unsigned allowed);
229
230
/*
231
 * Like copy_branchname() above, but confirm that the result is
232
 * syntactically valid to be used as a local branch name in refs/heads/.
233
 *
234
 * The return value is "0" if the result is valid, and "-1" otherwise.
235
 */
236
int check_branch_ref(struct strbuf *sb, const char *name);
237
238
/*
239
 * Similar for a tag name in refs/tags/.
240
 *
241
 * The return value is "0" if the result is valid, and "-1" otherwise.
242
 */
243
int check_tag_ref(struct strbuf *sb, const char *name);
244
245
/*
246
 * A ref_transaction represents a collection of reference updates that
247
 * should succeed or fail together.
248
 *
249
 * Calling sequence
250
 * ----------------
251
 *
252
 * - Allocate and initialize a `struct ref_transaction` by calling
253
 *   `ref_transaction_begin()`.
254
 *
255
 * - Specify the intended ref updates by calling one or more of the
256
 *   following functions:
257
 *   - `ref_transaction_update()`
258
 *   - `ref_transaction_create()`
259
 *   - `ref_transaction_delete()`
260
 *   - `ref_transaction_verify()`
261
 *
262
 * - Then either:
263
 *
264
 *   - Optionally call `ref_transaction_prepare()` to prepare the
265
 *     transaction. This locks all references, checks preconditions,
266
 *     etc. but doesn't finalize anything. If this step fails, the
267
 *     transaction has been closed and can only be freed. If this step
268
 *     succeeds, then `ref_transaction_commit()` is almost certain to
269
 *     succeed. However, you can still call `ref_transaction_abort()`
270
 *     if you decide not to commit the transaction after all.
271
 *
272
 *   - Call `ref_transaction_commit()` to execute the transaction,
273
 *     make the changes permanent, and release all locks. If you
274
 *     haven't already called `ref_transaction_prepare()`, then
275
 *     `ref_transaction_commit()` calls it for you.
276
 *
277
 *   Or
278
 *
279
 *   - Call `ref_transaction_begin()` with REF_TRANSACTION_FLAG_INITIAL if the
280
 *     ref database is known to be empty and have no other writers (e.g. during
281
 *     clone). This is likely to be much faster than without the flag.
282
 *
283
 * - Then finally, call `ref_transaction_free()` to free the
284
 *   `ref_transaction` data structure.
285
 *
286
 * At any time before calling `ref_transaction_commit()`, you can call
287
 * `ref_transaction_abort()` to abort the transaction, rollback any
288
 * locks, and free any associated resources (including the
289
 * `ref_transaction` data structure).
290
 *
291
 * Putting it all together, a complete reference update looks like
292
 *
293
 *         struct ref_transaction *transaction;
294
 *         struct strbuf err = STRBUF_INIT;
295
 *         int ret = 0;
296
 *
297
 *         transaction = ref_store_transaction_begin(refs, 0, &err);
298
 *         if (!transaction ||
299
 *             ref_transaction_update(...) ||
300
 *             ref_transaction_create(...) ||
301
 *             ...etc... ||
302
 *             ref_transaction_commit(transaction, &err)) {
303
 *                 error("%s", err.buf);
304
 *                 ret = -1;
305
 *         }
306
 *         ref_transaction_free(transaction);
307
 *         strbuf_release(&err);
308
 *         return ret;
309
 *
310
 * Error handling
311
 * --------------
312
 *
313
 * On error, transaction functions append a message about what
314
 * went wrong to the 'err' argument.  The message mentions what
315
 * ref was being updated (if any) when the error occurred so it
316
 * can be passed to 'die' or 'error' as-is.
317
 *
318
 * The message is appended to err without first clearing err.
319
 * err will not be '\n' terminated.
320
 *
321
 * Caveats
322
 * -------
323
 *
324
 * Note that no locks are taken, and no refs are read, until
325
 * `ref_transaction_prepare()` or `ref_transaction_commit()` is
326
 * called. So, for example, `ref_transaction_verify()` won't report a
327
 * verification failure until the commit is attempted.
328
 */
329
struct ref_transaction;
330
331
/*
332
 * Bit values set in the flags argument passed to refs_for_each_cb() and
333
 * stored in ref_iterator::flags. Other bits are for internal use
334
 * only:
335
 */
336
enum reference_status {
337
  /* Reference is a symbolic reference. */
338
  REF_ISSYMREF = (1 << 0),
339
340
  /* Reference is a packed reference. */
341
  REF_ISPACKED = (1 << 1),
342
343
  /*
344
   * Reference cannot be resolved to an object name: dangling symbolic
345
   * reference (directly or indirectly), corrupt reference file,
346
   * reference exists but name is bad, or symbolic reference refers to
347
   * ill-formatted reference name.
348
   */
349
  REF_ISBROKEN = (1 << 2),
350
351
  /*
352
   * Reference name is not well formed.
353
   *
354
   * See git-check-ref-format(1) for the definition of well formed ref names.
355
   */
356
  REF_BAD_NAME = (1 << 3),
357
};
358
359
/* A reference passed to `for_each_ref()`-style callbacks. */
360
struct reference {
361
  /* The fully-qualified name of the reference. */
362
  const char *name;
363
364
  /* The target of a symbolic ref. `NULL` for direct references. */
365
  const char *target;
366
367
  /*
368
   * The object ID of a reference. Either the direct object ID or the
369
   * resolved object ID in the case of a symbolic ref. May be the zero
370
   * object ID in case the symbolic ref cannot be resolved.
371
   */
372
  const struct object_id *oid;
373
374
  /*
375
   * An optional peeled object ID. This field _may_ be set for tags in
376
   * case the peeled value is present in the backend. Please refer to
377
   * `reference_get_peeled_oid()`.
378
   */
379
  const struct object_id *peeled_oid;
380
381
  /* A bitfield of `enum reference_status` flags. */
382
  unsigned flags;
383
};
384
385
/*
386
 * Peel the tag to a non-tag commit. If present, this uses the peeled object ID
387
 * exposed by the reference backend. Otherwise, the object is peeled via the
388
 * object database, which is less efficient.
389
 *
390
 * Return `0` if the reference could be peeled, a negative error code
391
 * otherwise.
392
 */
393
int reference_get_peeled_oid(struct repository *repo,
394
           const struct reference *ref,
395
           struct object_id *peeled_oid);
396
397
/*
398
 * The signature for the callback function for the for_each_*()
399
 * functions below.  The memory pointed to by the `struct reference`
400
 * argument is only guaranteed to be valid for the duration of a
401
 * single callback invocation.
402
 */
403
typedef int refs_for_each_cb(const struct reference *ref, void *cb_data);
404
405
/*
406
 * These flags are passed to refs_ref_iterator_begin() (and do_for_each_ref(),
407
 * which feeds it).
408
 */
409
enum refs_for_each_flag {
410
  /*
411
   * Include broken references in a do_for_each_ref*() iteration, which
412
   * would normally be omitted. This includes both refs that point to
413
   * missing objects (a true repository corruption), ones with illegal
414
   * names (which we prefer not to expose to callers), as well as
415
   * dangling symbolic refs (i.e., those that point to a non-existent
416
   * ref; this is not a corruption, but as they have no valid oid, we
417
   * omit them from normal iteration results).
418
   */
419
  REFS_FOR_EACH_INCLUDE_BROKEN = (1 << 0),
420
421
  /*
422
   * Only include per-worktree refs in a do_for_each_ref*() iteration.
423
   * Normally this will be used with a files ref_store, since that's
424
   * where all reference backends will presumably store their
425
   * per-worktree refs.
426
   */
427
  REFS_FOR_EACH_PER_WORKTREE_ONLY = (1 << 1),
428
429
  /*
430
   * Omit dangling symrefs from output; this only has an effect with
431
   * INCLUDE_BROKEN, since they are otherwise not included at all.
432
   */
433
  REFS_FOR_EACH_OMIT_DANGLING_SYMREFS = (1 << 2),
434
435
  /*
436
   * Include root refs i.e. HEAD and pseudorefs along with the regular
437
   * refs.
438
   */
439
  REFS_FOR_EACH_INCLUDE_ROOT_REFS = (1 << 3),
440
};
441
442
/*
443
 * The following functions invoke the specified callback function for
444
 * each reference indicated.  If the function ever returns a nonzero
445
 * value, stop the iteration and return that value.  Please note that
446
 * it is not safe to modify references while an iteration is in
447
 * progress, unless the same callback function invocation that
448
 * modifies the reference also returns a nonzero value to immediately
449
 * stop the iteration. Returned references are sorted.
450
 */
451
int refs_head_ref(struct ref_store *refs,
452
      refs_for_each_cb fn, void *cb_data);
453
int refs_head_ref_namespaced(struct ref_store *refs,
454
           refs_for_each_cb fn, void *cb_data);
455
456
457
struct refs_for_each_ref_options {
458
  /* Only iterate over references that have this given prefix. */
459
  const char *prefix;
460
461
  /*
462
   * A globbing pattern that can be used to only yield refs that match.
463
   * If given, refs will be matched against the pattern with
464
   * `wildmatch()`.
465
   *
466
   * If the pattern doesn't contain any globbing characters then it is
467
   * treated as if it was ending with "/" and "*".
468
   */
469
  const char *pattern;
470
471
  /*
472
   * If set, only yield refs part of the configured namespace. Exclude
473
   * patterns will be rewritten to apply to the namespace, and the prefix
474
   * will be considered relative to the namespace.
475
   */
476
  const char *namespace;
477
478
  /*
479
   * Exclude any references that match any of these patterns on a
480
   * best-effort basis. The caller needs to be prepared for the exclude
481
   * patterns to be ignored.
482
   *
483
   * The array must be terminated with a NULL sentinel value.
484
   */
485
  const char **exclude_patterns;
486
487
  /*
488
   * The number of bytes to trim from the refname. Note that the trimmed
489
   * bytes must not cause the reference to become empty. As such, this
490
   * field should typically only be set when one uses a `prefix` ending
491
   * in a slash.
492
   */
493
  size_t trim_prefix;
494
495
  /* Flags that change which refs will be included. */
496
  enum refs_for_each_flag flags;
497
};
498
499
int refs_for_each_ref(struct ref_store *refs,
500
          refs_for_each_cb fn, void *cb_data);
501
int refs_for_each_ref_ext(struct ref_store *refs,
502
        refs_for_each_cb cb, void *cb_data,
503
        const struct refs_for_each_ref_options *opts);
504
int refs_for_each_tag_ref(struct ref_store *refs,
505
        refs_for_each_cb fn, void *cb_data);
506
int refs_for_each_branch_ref(struct ref_store *refs,
507
           refs_for_each_cb fn, void *cb_data);
508
int refs_for_each_remote_ref(struct ref_store *refs,
509
           refs_for_each_cb fn, void *cb_data);
510
int refs_for_each_replace_ref(struct ref_store *refs,
511
            refs_for_each_cb fn, void *cb_data);
512
513
/**
514
 * Iterate all refs in "prefixes" by partitioning prefixes into disjoint sets
515
 * and iterating the longest-common prefix of each set.
516
 */
517
int refs_for_each_ref_in_prefixes(struct ref_store *refs,
518
          const char **prefixes,
519
          const struct refs_for_each_ref_options *opts,
520
          refs_for_each_cb cb, void *cb_data);
521
522
/*
523
 * Normalizes partial refs to their fully qualified form.
524
 * Will prepend <prefix> to the <pattern> if it doesn't start with 'refs/'.
525
 * <prefix> will default to 'refs/' if NULL.
526
 *
527
 * item.string will be set to the result.
528
 * item.util will be set to NULL if <pattern> contains glob characters, or
529
 * non-NULL if it doesn't.
530
 */
531
void normalize_glob_ref(struct string_list_item *item, const char *prefix,
532
      const char *pattern);
533
534
static inline const char *has_glob_specials(const char *pattern)
535
0
{
536
0
  return strpbrk(pattern, "?*[");
537
0
}
Unexecuted instantiation: symlinks.c:has_glob_specials
Unexecuted instantiation: trace.c:has_glob_specials
Unexecuted instantiation: config.c:has_glob_specials
Unexecuted instantiation: dir.c:has_glob_specials
Unexecuted instantiation: environment.c:has_glob_specials
Unexecuted instantiation: mailmap.c:has_glob_specials
Unexecuted instantiation: object-file.c:has_glob_specials
Unexecuted instantiation: object-name.c:has_glob_specials
Unexecuted instantiation: odb.c:has_glob_specials
Unexecuted instantiation: path.c:has_glob_specials
Unexecuted instantiation: pathspec.c:has_glob_specials
Unexecuted instantiation: read-cache.c:has_glob_specials
Unexecuted instantiation: reflog-walk.c:has_glob_specials
Unexecuted instantiation: refs.c:has_glob_specials
Unexecuted instantiation: debug.c:has_glob_specials
Unexecuted instantiation: files-backend.c:has_glob_specials
Unexecuted instantiation: reftable-backend.c:has_glob_specials
Unexecuted instantiation: iterator.c:has_glob_specials
Unexecuted instantiation: packed-backend.c:has_glob_specials
Unexecuted instantiation: ref-cache.c:has_glob_specials
Unexecuted instantiation: remote.c:has_glob_specials
Unexecuted instantiation: replace-object.c:has_glob_specials
Unexecuted instantiation: repo-settings.c:has_glob_specials
Unexecuted instantiation: repository.c:has_glob_specials
Unexecuted instantiation: revision.c:has_glob_specials
Unexecuted instantiation: setup.c:has_glob_specials
Unexecuted instantiation: shallow.c:has_glob_specials
Unexecuted instantiation: submodule.c:has_glob_specials
Unexecuted instantiation: transport.c:has_glob_specials
Unexecuted instantiation: worktree.c:has_glob_specials
Unexecuted instantiation: wt-status.c:has_glob_specials
Unexecuted instantiation: attr.c:has_glob_specials
Unexecuted instantiation: bisect.c:has_glob_specials
Unexecuted instantiation: branch.c:has_glob_specials
Unexecuted instantiation: bundle-uri.c:has_glob_specials
Unexecuted instantiation: bundle.c:has_glob_specials
Unexecuted instantiation: combine-diff.c:has_glob_specials
Unexecuted instantiation: commit-graph.c:has_glob_specials
Unexecuted instantiation: commit.c:has_glob_specials
Unexecuted instantiation: connect.c:has_glob_specials
Unexecuted instantiation: diff-lib.c:has_glob_specials
Unexecuted instantiation: diff.c:has_glob_specials
Unexecuted instantiation: fetch-pack.c:has_glob_specials
Unexecuted instantiation: fsck.c:has_glob_specials
Unexecuted instantiation: hook.c:has_glob_specials
Unexecuted instantiation: line-log.c:has_glob_specials
Unexecuted instantiation: log-tree.c:has_glob_specials
Unexecuted instantiation: merge-ort.c:has_glob_specials
Unexecuted instantiation: midx.c:has_glob_specials
Unexecuted instantiation: notes-cache.c:has_glob_specials
Unexecuted instantiation: notes.c:has_glob_specials
Unexecuted instantiation: parse-options-cb.c:has_glob_specials
Unexecuted instantiation: refspec.c:has_glob_specials
Unexecuted instantiation: sequencer.c:has_glob_specials
Unexecuted instantiation: transport-helper.c:has_glob_specials
Unexecuted instantiation: unpack-trees.c:has_glob_specials
Unexecuted instantiation: apply.c:has_glob_specials
Unexecuted instantiation: default.c:has_glob_specials
Unexecuted instantiation: skipping.c:has_glob_specials
Unexecuted instantiation: notes-utils.c:has_glob_specials
Unexecuted instantiation: reset.c:has_glob_specials
538
539
void refs_warn_dangling_symrefs(struct ref_store *refs, FILE *fp,
540
        const char *indent, int dry_run,
541
        const struct string_list *refnames);
542
543
/*
544
 * Flags for controlling behaviour of refs_optimize()
545
 * REFS_OPTIMIZE_PRUNE: Prune loose refs after packing
546
 * REFS_OPTIMIZE_AUTO: Pack refs on a best effort basis. The heuristics and end
547
 *                     result are decided by the ref backend. Backends may ignore
548
 *                     this flag and fall back to a normal repack.
549
 */
550
0
#define REFS_OPTIMIZE_PRUNE (1 << 0)
551
0
#define REFS_OPTIMIZE_AUTO  (1 << 1)
552
553
struct refs_optimize_opts {
554
  unsigned int flags;
555
  struct ref_exclusions *exclusions;
556
  struct string_list *includes;
557
};
558
559
/*
560
 * Optimize the ref store. The exact behavior is up to the backend.
561
 * For the files backend, this is equivalent to packing refs.
562
 */
563
int refs_optimize(struct ref_store *refs, struct refs_optimize_opts *opts);
564
565
/*
566
 * Check if refs backend can be optimized by calling 'refs_optimize'.
567
 */
568
int refs_optimize_required(struct ref_store *ref_store,
569
         struct refs_optimize_opts *opts,
570
         bool *required);
571
572
/*
573
 * Setup reflog before using. Fill in err and return -1 on failure.
574
 */
575
int refs_create_reflog(struct ref_store *refs, const char *refname,
576
           struct strbuf *err);
577
578
/**
579
 * Reads log for the value of ref during at_time (in which case "cnt" should be
580
 * negative) or the reflog "cnt" entries from the top (in which case "at_time"
581
 * should be 0).
582
 *
583
 * If we found the reflog entry in question, returns 0 (and details of the
584
 * entry can be found in the out-parameters).
585
 *
586
 * If we ran out of reflog entries, the out-parameters are filled with the
587
 * details of the oldest entry we did find, and the function returns 1. Note
588
 * that there is one important special case here! If the reflog was empty
589
 * and the caller asked for the 0-th cnt, we will return "1" but leave the
590
 * "oid" field untouched.
591
 **/
592
int read_ref_at(struct ref_store *refs,
593
    const char *refname, unsigned int flags,
594
    timestamp_t at_time, int cnt,
595
    struct object_id *oid, char **msg,
596
    timestamp_t *cutoff_time, int *cutoff_tz, int *cutoff_cnt);
597
598
/** Check if a particular reflog exists */
599
int refs_reflog_exists(struct ref_store *refs, const char *refname);
600
601
/*
602
 * Delete the specified reference. If old_oid is non-NULL, then
603
 * verify that the current value of the reference is old_oid before
604
 * deleting it. If old_oid is NULL, delete the reference if it
605
 * exists, regardless of its old value. It is an error for old_oid to
606
 * be null_oid. msg and flags are passed through to
607
 * ref_transaction_delete().
608
 */
609
int refs_delete_ref(struct ref_store *refs, const char *msg,
610
        const char *refname,
611
        const struct object_id *old_oid,
612
        unsigned int flags);
613
614
/*
615
 * Delete the specified references. If there are any problems, emit
616
 * errors but attempt to keep going (i.e., the deletes are not done in
617
 * an all-or-nothing transaction). msg and flags are passed through to
618
 * ref_transaction_delete().
619
 */
620
int refs_delete_refs(struct ref_store *refs, const char *msg,
621
         struct string_list *refnames, unsigned int flags);
622
623
/** Delete a reflog */
624
int refs_delete_reflog(struct ref_store *refs, const char *refname);
625
626
/*
627
 * Callback to process a reflog entry found by the iteration functions (see
628
 * below).
629
 *
630
 * The committer parameter is a single string, in the form
631
 * "$GIT_COMMITTER_NAME <$GIT_COMMITTER_EMAIL>" (without double quotes).
632
 *
633
 * The timestamp parameter gives the time when entry was created as the number
634
 * of seconds since the UNIX epoch.
635
 *
636
 * The tz parameter gives the timezone offset for the user who created
637
 * the reflog entry, and its value gives a positive or negative offset
638
 * from UTC.  Its absolute value is formed by multiplying the hour
639
 * part by 100 and adding the minute part.  For example, 1 hour ahead
640
 * of UTC, CET == "+0100", is represented as positive one hundred (not
641
 * positive sixty).
642
 *
643
 * The msg parameter is a single complete line; a reflog message given
644
 * to refs_delete_ref, refs_update_ref, etc. is returned to the
645
 * callback normalized---each run of whitespaces are squashed into a
646
 * single whitespace, trailing whitespace, if exists, is trimmed, and
647
 * then a single LF is added at the end.
648
 *
649
 * The cb_data is a caller-supplied pointer given to the iterator
650
 * functions.
651
 */
652
typedef int each_reflog_ent_fn(const char *refname,
653
             struct object_id *old_oid,
654
             struct object_id *new_oid,
655
             const char *committer,
656
             timestamp_t timestamp,
657
             int tz, const char *msg,
658
             void *cb_data);
659
660
/* Iterate over reflog entries in the log for `refname`. */
661
662
/* oldest entry first */
663
int refs_for_each_reflog_ent(struct ref_store *refs, const char *refname,
664
           each_reflog_ent_fn fn, void *cb_data);
665
666
/* youngest entry first */
667
int refs_for_each_reflog_ent_reverse(struct ref_store *refs,
668
             const char *refname,
669
             each_reflog_ent_fn fn,
670
             void *cb_data);
671
672
/*
673
 * The signature for the callback function for the refs_for_each_reflog()
674
 * functions below. The memory pointed to by the refname argument is only
675
 * guaranteed to be valid for the duration of a single callback invocation.
676
 */
677
typedef int each_reflog_fn(const char *refname, void *cb_data);
678
679
/*
680
 * Calls the specified function for each reflog file until it returns nonzero,
681
 * and returns the value. Reflog file order is unspecified.
682
 */
683
int refs_for_each_reflog(struct ref_store *refs, each_reflog_fn fn, void *cb_data);
684
685
0
#define REFNAME_ALLOW_ONELEVEL 1
686
0
#define REFNAME_REFSPEC_PATTERN 2
687
688
/*
689
 * Return 0 iff refname has the correct format for a refname according
690
 * to the rules described in Documentation/git-check-ref-format.adoc.
691
 * If REFNAME_ALLOW_ONELEVEL is set in flags, then accept one-level
692
 * reference names.  If REFNAME_REFSPEC_PATTERN is set in flags, then
693
 * allow a single "*" wildcard character in the refspec. No leading or
694
 * repeated slashes are accepted.
695
 */
696
int check_refname_format(const char *refname, int flags);
697
698
struct fsck_ref_report;
699
700
/*
701
 * Perform generic checks for a specific direct ref. This function is
702
 * expected to be called by the ref backends for every symbolic ref.
703
 */
704
int refs_fsck_ref(struct ref_store *refs, struct fsck_options *o,
705
      struct fsck_ref_report *report,
706
      const char *refname, const struct object_id *oid);
707
708
/*
709
 * Perform generic checks for a specific symref target. This function is
710
 * expected to be called by the ref backends for every symbolic ref.
711
 */
712
int refs_fsck_symref(struct ref_store *refs, struct fsck_options *o,
713
         struct fsck_ref_report *report,
714
         const char *refname, const char *target);
715
716
/*
717
 * Check the reference database for consistency. Return 0 if refs and
718
 * reflogs are consistent, and non-zero otherwise. The errors will be
719
 * written to stderr.
720
 */
721
int refs_fsck(struct ref_store *refs, struct fsck_options *o,
722
        struct worktree *wt);
723
724
/*
725
 * Apply the rules from check_refname_format, but mutate the result until it
726
 * is acceptable, and place the result in "out".
727
 */
728
void sanitize_refname_component(const char *refname, struct strbuf *out);
729
730
const char *prettify_refname(const char *refname);
731
732
char *refs_shorten_unambiguous_ref(struct ref_store *refs,
733
           const char *refname, int strict);
734
735
/** rename ref, return 0 on success **/
736
int refs_rename_ref(struct ref_store *refs, const char *oldref,
737
        const char *newref, const char *logmsg);
738
739
/** copy ref, return 0 on success **/
740
int refs_copy_existing_ref(struct ref_store *refs, const char *oldref,
741
        const char *newref, const char *logmsg);
742
743
int refs_update_symref(struct ref_store *refs, const char *refname,
744
           const char *target, const char *logmsg);
745
746
int refs_update_symref_extended(struct ref_store *refs, const char *refname,
747
           const char *target, const char *logmsg,
748
           struct strbuf *referent, int create_only);
749
750
enum action_on_err {
751
  UPDATE_REFS_MSG_ON_ERR,
752
  UPDATE_REFS_DIE_ON_ERR,
753
  UPDATE_REFS_QUIET_ON_ERR
754
};
755
756
enum ref_transaction_flag {
757
  /*
758
   * The ref transaction is part of the initial creation of the ref store
759
   * and can thus assume that the ref store is completely empty. This
760
   * allows the backend to perform the transaction more efficiently by
761
   * skipping certain checks.
762
   *
763
   * It is a bug to set this flag when there might be other processes
764
   * accessing the repository or if there are existing references that
765
   * might conflict with the ones being created. All old_oid values must
766
   * either be absent or null_oid.
767
   */
768
  REF_TRANSACTION_FLAG_INITIAL = (1 << 0),
769
770
  /*
771
   * The transaction mechanism by default fails all updates if any conflict
772
   * is detected. This flag allows transactions to partially apply updates
773
   * while rejecting updates which do not match the expected state.
774
   */
775
  REF_TRANSACTION_ALLOW_FAILURE = (1 << 1),
776
};
777
778
/*
779
 * Begin a reference transaction.  The reference transaction must
780
 * be freed by calling ref_transaction_free().
781
 */
782
struct ref_transaction *ref_store_transaction_begin(struct ref_store *refs,
783
                unsigned int flags,
784
                struct strbuf *err);
785
786
/*
787
 * Reference transaction updates
788
 *
789
 * The following four functions add a reference check or update to a
790
 * ref_transaction.  They have some common similar parameters:
791
 *
792
 *     transaction -- a pointer to an open ref_transaction, obtained
793
 *         from ref_transaction_begin().
794
 *
795
 *     refname -- the name of the reference to be affected.
796
 *
797
 *     new_oid -- the object ID that should be set to be the new value
798
 *         of the reference. Some functions allow this parameter to be
799
 *         NULL, meaning that the reference is not changed, or
800
 *         null_oid, meaning that the reference should be deleted. A
801
 *         copy of this value is made in the transaction.
802
 *
803
 *     old_oid -- the object ID that the reference must have before
804
 *         the update. Some functions allow this parameter to be NULL,
805
 *         meaning that the old value of the reference is not checked,
806
 *         or null_oid, meaning that the reference must not exist
807
 *         before the update. A copy of this value is made in the
808
 *         transaction.
809
 *
810
 *     new_target -- the target reference that the reference will be
811
 *         updated to point to. If the reference is a regular reference,
812
 *         it will be converted to a symbolic reference. Cannot be set
813
 *         together with `new_oid`. A copy of this value is made in the
814
 *         transaction.
815
 *
816
 *     old_target -- the reference that the reference must be pointing to.
817
 *         Canont be set together with `old_oid`. A copy of this value is
818
 *         made in the transaction.
819
 *
820
 *     flags -- flags affecting the update, passed to
821
 *         update_ref_lock(). Possible flags: REF_NO_DEREF,
822
 *         REF_FORCE_CREATE_REFLOG. See those constants for more
823
 *         information.
824
 *
825
 *     msg -- a message describing the change (for the reflog).
826
 *
827
 *     err -- a strbuf for receiving a description of any error that
828
 *         might have occurred.
829
 *
830
 * The functions make internal copies of refname and msg, so the
831
 * caller retains ownership of these parameters.
832
 *
833
 * The functions return 0 on success and non-zero on failure. A
834
 * failure means that the transaction as a whole has failed and needs
835
 * to be rolled back.
836
 */
837
838
/*
839
 * The following flags can be passed to ref_transaction_update() etc.
840
 * Internally, they are stored in `ref_update::flags`, along with some
841
 * internal flags.
842
 */
843
844
/*
845
 * Act on the ref directly; i.e., without dereferencing symbolic refs.
846
 * If this flag is not specified, then symbolic references are
847
 * dereferenced and the update is applied to the referent.
848
 */
849
0
#define REF_NO_DEREF (1 << 0)
850
851
/*
852
 * Force the creation of a reflog for this reference, even if it
853
 * didn't previously have a reflog.
854
 */
855
0
#define REF_FORCE_CREATE_REFLOG (1 << 1)
856
857
/*
858
 * Blindly write an object_id. This is useful for testing data corruption
859
 * scenarios.
860
 */
861
0
#define REF_SKIP_OID_VERIFICATION (1 << 10)
862
863
/*
864
 * Skip verifying refname. This is useful for testing data corruption scenarios.
865
 */
866
0
#define REF_SKIP_REFNAME_VERIFICATION (1 << 11)
867
868
/*
869
 * Skip creation of a reflog entry, even if it would have otherwise been
870
 * created.
871
 */
872
0
#define REF_SKIP_CREATE_REFLOG (1 << 12)
873
874
/*
875
 * When writing a REF_LOG_ONLY record, use the old and new object IDs provided
876
 * in the update instead of resolving the old object ID. The caller must also
877
 * set both REF_HAVE_OLD and REF_HAVE_NEW.
878
 */
879
0
#define REF_LOG_USE_PROVIDED_OIDS (1 << 13)
880
881
/*
882
 * Bitmask of all of the flags that are allowed to be passed in to
883
 * ref_transaction_update() and friends:
884
 */
885
#define REF_TRANSACTION_UPDATE_ALLOWED_FLAGS                                  \
886
0
  (REF_NO_DEREF | REF_FORCE_CREATE_REFLOG | REF_SKIP_OID_VERIFICATION | \
887
0
   REF_SKIP_REFNAME_VERIFICATION | REF_SKIP_CREATE_REFLOG | REF_LOG_USE_PROVIDED_OIDS)
888
889
/*
890
 * Add a reference update to transaction. `new_oid` is the value that
891
 * the reference should have after the update, or `null_oid` if it
892
 * should be deleted. If `new_oid` is NULL, then the reference is not
893
 * changed at all. `old_oid` is the value that the reference must have
894
 * before the update, or `null_oid` if it must not have existed
895
 * beforehand. The old value is checked after the lock is taken to
896
 * prevent races. If the old value doesn't agree with old_oid, the
897
 * whole transaction fails. If old_oid is NULL, then the previous
898
 * value is not checked. If `old_target` is not NULL, treat the reference
899
 * as a symbolic ref and validate that its target before the update is
900
 * `old_target`. If the `new_target` is not NULL, then the reference
901
 * will be updated to a symbolic ref which targets `new_target`.
902
 * Together, these allow us to update between regular refs and symrefs.
903
 *
904
 * See the above comment "Reference transaction updates" for more
905
 * information.
906
 */
907
int ref_transaction_update(struct ref_transaction *transaction,
908
         const char *refname,
909
         const struct object_id *new_oid,
910
         const struct object_id *old_oid,
911
         const char *new_target,
912
         const char *old_target,
913
         unsigned int flags, const char *msg,
914
         struct strbuf *err);
915
916
/*
917
 * Similar to `ref_transaction_update`, but this function is only for adding
918
 * a reflog update. Supports providing custom committer information. The index
919
 * field can be utiltized to order updates as desired. When set to zero, the
920
 * updates default to being ordered by refname.
921
 */
922
int ref_transaction_update_reflog(struct ref_transaction *transaction,
923
          const char *refname,
924
          const struct object_id *new_oid,
925
          const struct object_id *old_oid,
926
          const char *committer_info,
927
          const char *msg,
928
          uint64_t index,
929
          struct strbuf *err);
930
931
/*
932
 * Add a reference creation to transaction. new_oid is the value that
933
 * the reference should have after the update; it must not be
934
 * null_oid. It is verified that the reference does not exist
935
 * already.
936
 *
937
 * See the above comment "Reference transaction updates" for more
938
 * information.
939
 */
940
int ref_transaction_create(struct ref_transaction *transaction,
941
         const char *refname,
942
         const struct object_id *new_oid,
943
         const char *new_target,
944
         unsigned int flags, const char *msg,
945
         struct strbuf *err);
946
947
/*
948
 * Add a reference deletion to transaction. If old_oid is non-NULL,
949
 * then it holds the value that the reference should have had before
950
 * the update (which must not be null_oid).
951
 *
952
 * See the above comment "Reference transaction updates" for more
953
 * information.
954
 */
955
int ref_transaction_delete(struct ref_transaction *transaction,
956
         const char *refname,
957
         const struct object_id *old_oid,
958
         const char *old_target,
959
         unsigned int flags,
960
         const char *msg,
961
         struct strbuf *err);
962
963
/*
964
 * Verify, within a transaction, that refname has the value old_oid,
965
 * or, if old_oid is null_oid, then verify that the reference
966
 * doesn't exist. old_oid must be non-NULL.
967
 *
968
 * See the above comment "Reference transaction updates" for more
969
 * information.
970
 */
971
int ref_transaction_verify(struct ref_transaction *transaction,
972
         const char *refname,
973
         const struct object_id *old_oid,
974
         const char *old_target,
975
         unsigned int flags,
976
         struct strbuf *err);
977
978
/*
979
 * Perform the preparatory stages of committing `transaction`. Acquire
980
 * any needed locks, check preconditions, etc.; basically, do as much
981
 * as possible to ensure that the transaction will be able to go
982
 * through, stopping just short of making any irrevocable or
983
 * user-visible changes. The updates that this function prepares can
984
 * be finished up by calling `ref_transaction_commit()` or rolled back
985
 * by calling `ref_transaction_abort()`.
986
 *
987
 * On success, return 0 and leave the transaction in "prepared" state.
988
 * On failure, abort the transaction, write an error message to `err`,
989
 * and return one of the `TRANSACTION_*` constants.
990
 *
991
 * Callers who don't need such fine-grained control over committing
992
 * reference transactions should just call `ref_transaction_commit()`.
993
 */
994
int ref_transaction_prepare(struct ref_transaction *transaction,
995
          struct strbuf *err);
996
997
/*
998
 * Commit all of the changes that have been queued in transaction, as
999
 * atomically as possible. On success, return 0 and leave the
1000
 * transaction in "closed" state. On failure, roll back the
1001
 * transaction, write an error message to `err`, and return one of the
1002
 * `TRANSACTION_*` constants
1003
 */
1004
int ref_transaction_commit(struct ref_transaction *transaction,
1005
         struct strbuf *err);
1006
1007
/*
1008
 * Abort `transaction`, which has been begun and possibly prepared,
1009
 * but not yet committed.
1010
 */
1011
int ref_transaction_abort(struct ref_transaction *transaction,
1012
        struct strbuf *err);
1013
1014
/*
1015
 * Execute the given callback function for each of the reference updates which
1016
 * have been queued in the given transaction. `old_oid` and `new_oid` may be
1017
 * `NULL` pointers depending on whether the update has these object IDs set or
1018
 * not.
1019
 */
1020
typedef void ref_transaction_for_each_queued_update_fn(const char *refname,
1021
                   const struct object_id *old_oid,
1022
                   const struct object_id *new_oid,
1023
                   void *cb_data);
1024
void ref_transaction_for_each_queued_update(struct ref_transaction *transaction,
1025
              ref_transaction_for_each_queued_update_fn cb,
1026
              void *cb_data);
1027
1028
/*
1029
 * Execute the given callback function for each of the reference updates which
1030
 * have been rejected in the given transaction.
1031
 */
1032
typedef void ref_transaction_for_each_rejected_update_fn(const char *refname,
1033
               const struct object_id *old_oid,
1034
               const struct object_id *new_oid,
1035
               const char *old_target,
1036
               const char *new_target,
1037
               enum ref_transaction_error err,
1038
               const char *details,
1039
               void *cb_data);
1040
void ref_transaction_for_each_rejected_update(struct ref_transaction *transaction,
1041
                ref_transaction_for_each_rejected_update_fn cb,
1042
                void *cb_data);
1043
1044
/*
1045
 * Translate errors to human readable error messages.
1046
 */
1047
const char *ref_transaction_error_msg(enum ref_transaction_error err);
1048
1049
/*
1050
 * Free `*transaction` and all associated data.
1051
 */
1052
void ref_transaction_free(struct ref_transaction *transaction);
1053
1054
/**
1055
 * Lock, update, and unlock a single reference. This function
1056
 * basically does a transaction containing a single call to
1057
 * ref_transaction_update(). The parameters to this function have the
1058
 * same meaning as the corresponding parameters to
1059
 * ref_transaction_update(). Handle errors as requested by the `onerr`
1060
 * argument.
1061
 */
1062
int refs_update_ref(struct ref_store *refs, const char *msg, const char *refname,
1063
        const struct object_id *new_oid, const struct object_id *old_oid,
1064
        unsigned int flags, enum action_on_err onerr);
1065
1066
int parse_hide_refs_config(const char *var, const char *value, const char *,
1067
         struct strvec *);
1068
1069
/*
1070
 * Check whether a ref is hidden. If no namespace is set, both the first and
1071
 * the second parameter point to the full ref name. If a namespace is set and
1072
 * the ref is inside that namespace, the first parameter is a pointer to the
1073
 * name of the ref with the namespace prefix removed. If a namespace is set and
1074
 * the ref is outside that namespace, the first parameter is NULL. The second
1075
 * parameter always points to the full ref name.
1076
 */
1077
int ref_is_hidden(const char *, const char *, const struct strvec *);
1078
1079
/*
1080
 * Returns an array of patterns to use as excluded_patterns, if none of the
1081
 * hidden references use the token '!' or '^'.
1082
 */
1083
const char **hidden_refs_to_excludes(const struct strvec *hide_refs);
1084
1085
/*
1086
 * Prefix all exclude patterns with the namespace, if any. This is required
1087
 * because exclude patterns apply to the stripped reference name, not the full
1088
 * reference name with the namespace.
1089
 */
1090
const char **get_namespaced_exclude_patterns(const char **exclude_patterns,
1091
               const char *namespace,
1092
               struct strvec *out);
1093
1094
/* Is this a per-worktree ref living in the refs/ namespace? */
1095
int is_per_worktree_ref(const char *refname);
1096
1097
/* Describes how a refname relates to worktrees */
1098
enum ref_worktree_type {
1099
  REF_WORKTREE_CURRENT, /* implicitly per worktree, eg. HEAD or
1100
         refs/bisect/SOMETHING */
1101
  REF_WORKTREE_MAIN, /* explicitly in main worktree, eg.
1102
            main-worktree/HEAD */
1103
  REF_WORKTREE_OTHER, /* explicitly in named worktree, eg.
1104
             worktrees/bla/HEAD */
1105
  REF_WORKTREE_SHARED, /* the default, eg. refs/heads/main */
1106
};
1107
1108
/*
1109
 * Parse a `maybe_worktree_ref` as a ref that possibly refers to a worktree ref
1110
 * (ie. either REFNAME, main-worktree/REFNAME or worktree/WORKTREE/REFNAME). It
1111
 * returns what kind of ref was found, and in case of REF_WORKTREE_OTHER, the
1112
 * worktree name is returned in `worktree_name` (pointing into
1113
 * `maybe_worktree_ref`) and `worktree_name_length`. The bare refname (the
1114
 * refname stripped of prefixes) is returned in `bare_refname`. The
1115
 * `worktree_name`, `worktree_name_length` and `bare_refname` arguments may be
1116
 * NULL.
1117
 */
1118
enum ref_worktree_type parse_worktree_ref(const char *maybe_worktree_ref,
1119
            const char **worktree_name,
1120
            int *worktree_name_length,
1121
            const char **bare_refname);
1122
1123
enum expire_reflog_flags {
1124
  EXPIRE_REFLOGS_DRY_RUN = 1 << 0,
1125
  EXPIRE_REFLOGS_UPDATE_REF = 1 << 1,
1126
  EXPIRE_REFLOGS_REWRITE = 1 << 2,
1127
};
1128
1129
/*
1130
 * The following interface is used for reflog expiration. The caller
1131
 * calls refs_reflog_expire(), supplying it with three callback functions,
1132
 * of the following types. The callback functions define the
1133
 * expiration policy that is desired.
1134
 *
1135
 * reflog_expiry_prepare_fn -- Called once after the reference is
1136
 *     locked. Called with the OID of the locked reference.
1137
 *
1138
 * reflog_expiry_should_prune_fn -- Called once for each entry in the
1139
 *     existing reflog. It should return true iff that entry should be
1140
 *     pruned.
1141
 *
1142
 * reflog_expiry_cleanup_fn -- Called once before the reference is
1143
 *     unlocked again.
1144
 */
1145
typedef void reflog_expiry_prepare_fn(const char *refname,
1146
              const struct object_id *oid,
1147
              void *cb_data);
1148
typedef int reflog_expiry_should_prune_fn(struct object_id *ooid,
1149
            struct object_id *noid,
1150
            const char *email,
1151
            timestamp_t timestamp, int tz,
1152
            const char *message, void *cb_data);
1153
typedef void reflog_expiry_cleanup_fn(void *cb_data);
1154
1155
/*
1156
 * Expire reflog entries for the specified reference.
1157
 * flags is a combination of the constants in
1158
 * enum expire_reflog_flags. The three function pointers are described
1159
 * above. On success, return zero.
1160
 */
1161
int refs_reflog_expire(struct ref_store *refs,
1162
           const char *refname,
1163
           unsigned int flags,
1164
           reflog_expiry_prepare_fn prepare_fn,
1165
           reflog_expiry_should_prune_fn should_prune_fn,
1166
           reflog_expiry_cleanup_fn cleanup_fn,
1167
           void *policy_cb_data);
1168
1169
struct ref_store *get_main_ref_store(struct repository *r);
1170
1171
/**
1172
 * Submodules
1173
 * ----------
1174
 *
1175
 * If you want to iterate the refs of a submodule you first need to add the
1176
 * submodules object database. You can do this by a code-snippet like
1177
 * this:
1178
 *
1179
 *  const char *path = "path/to/submodule"
1180
 *  if (add_submodule_odb(path))
1181
 *    die("Error submodule '%s' not populated.", path);
1182
 *
1183
 * `add_submodule_odb()` will return zero on success. If you
1184
 * do not do this you will get an error for each ref that it does not point
1185
 * to a valid object.
1186
 *
1187
 * Note: As a side-effect of this you cannot safely assume that all
1188
 * objects you lookup are available in superproject. All submodule objects
1189
 * will be available the same way as the superprojects objects.
1190
 *
1191
 * Example:
1192
 * --------
1193
 *
1194
 * ----
1195
 * static int handle_remote_ref(const char *refname,
1196
 *    const unsigned char *sha1, int flags, void *cb_data)
1197
 * {
1198
 *  struct strbuf *output = cb_data;
1199
 *  strbuf_addf(output, "%s\n", refname);
1200
 *  return 0;
1201
 * }
1202
 *
1203
 */
1204
1205
/*
1206
 * Return the ref_store instance for the specified submodule. For the
1207
 * main repository, use submodule==NULL; such a call cannot fail. For
1208
 * a submodule, the submodule must exist and be a nonbare repository,
1209
 * otherwise return NULL. If the requested reference store has not yet
1210
 * been initialized, initialize it first.
1211
 *
1212
 * For backwards compatibility, submodule=="" is treated the same as
1213
 * submodule==NULL.
1214
 */
1215
struct ref_store *repo_get_submodule_ref_store(struct repository *repo,
1216
                 const char *submodule);
1217
struct ref_store *get_worktree_ref_store(const struct worktree *wt);
1218
1219
/*
1220
 * Some of the names specified by refs have special meaning to Git.
1221
 * Organize these namespaces in a common 'ref_namespace' array for
1222
 * reference from multiple places in the codebase.
1223
 */
1224
1225
struct ref_namespace_info {
1226
  const char *ref;
1227
  enum decoration_type decoration;
1228
1229
  /*
1230
   * If 'exact' is true, then we must match the 'ref' exactly.
1231
   * Otherwise, use a prefix match.
1232
   *
1233
   * 'ref_updated' is for internal use. It represents whether the
1234
   * 'ref' value was replaced from its original literal version.
1235
   */
1236
  unsigned exact:1,
1237
     ref_updated:1;
1238
};
1239
1240
enum ref_namespace {
1241
  NAMESPACE_HEAD,
1242
  NAMESPACE_BRANCHES,
1243
  NAMESPACE_TAGS,
1244
  NAMESPACE_REMOTE_REFS,
1245
  NAMESPACE_STASH,
1246
  NAMESPACE_REPLACE,
1247
  NAMESPACE_NOTES,
1248
  NAMESPACE_PREFETCH,
1249
  NAMESPACE_REWRITTEN,
1250
1251
  /* Must be last */
1252
  NAMESPACE__COUNT
1253
};
1254
1255
/* See refs.c for the contents of this array. */
1256
extern struct ref_namespace_info ref_namespace[NAMESPACE__COUNT];
1257
1258
/*
1259
 * Some ref namespaces can be modified by config values or environment
1260
 * variables. Modify a namespace as specified by its ref_namespace key.
1261
 */
1262
void update_ref_namespace(enum ref_namespace namespace, char *ref);
1263
1264
/*
1265
 * Check whether the provided name names a root reference. This function only
1266
 * performs a syntactic check.
1267
 *
1268
 * A root ref is a reference that lives in the root of the reference hierarchy.
1269
 * These references must conform to special syntax:
1270
 *
1271
 *   - Their name must be all-uppercase or underscores ("_").
1272
 *
1273
 *   - Their name must end with "_HEAD". As a special rule, "HEAD" is a root
1274
 *     ref, as well.
1275
 *
1276
 *   - Their name may not contain a slash.
1277
 *
1278
 * There is a special set of irregular root refs that exist due to historic
1279
 * reasons, only. This list shall not be expanded in the future:
1280
 *
1281
 *   - AUTO_MERGE
1282
 *
1283
 *   - BISECT_EXPECTED_REV
1284
 *
1285
 *   - NOTES_MERGE_PARTIAL
1286
 *
1287
 *   - NOTES_MERGE_REF
1288
 *
1289
 *   - MERGE_AUTOSTASH
1290
 */
1291
int is_root_ref(const char *refname);
1292
1293
/*
1294
 * Pseudorefs are refs that have different semantics compared to
1295
 * "normal" refs. These refs can thus not be stored in the ref backend,
1296
 * but must always be accessed via the filesystem. The following refs
1297
 * are pseudorefs:
1298
 *
1299
 * - FETCH_HEAD may contain multiple object IDs, and each one of them
1300
 *   carries additional metadata like where it came from.
1301
 *
1302
 * - MERGE_HEAD may contain multiple object IDs when merging multiple
1303
 *   heads.
1304
 *
1305
 * Reading, writing or deleting references must consistently go either
1306
 * through the filesystem (pseudorefs) or through the reference
1307
 * backend (normal ones).
1308
 */
1309
int is_pseudo_ref(const char *refname);
1310
1311
/*
1312
 * The following flags can be passed to `repo_migrate_ref_storage_format()`:
1313
 *
1314
 *   - REPO_MIGRATE_REF_STORAGE_FORMAT_DRYRUN: perform a dry-run migration
1315
 *     without touching the main repository. The result will be written into a
1316
 *     temporary ref storage directory.
1317
 *
1318
 *   - REPO_MIGRATE_REF_STORAGE_FORMAT_SKIP_REFLOG: skip migration of reflogs.
1319
 */
1320
0
#define REPO_MIGRATE_REF_STORAGE_FORMAT_DRYRUN      (1 << 0)
1321
0
#define REPO_MIGRATE_REF_STORAGE_FORMAT_SKIP_REFLOG (1 << 1)
1322
1323
/*
1324
 * Migrate the ref storage format used by the repository to the
1325
 * specified one.
1326
 */
1327
int repo_migrate_ref_storage_format(struct repository *repo,
1328
            enum ref_storage_format format,
1329
            unsigned int flags,
1330
            struct strbuf *err);
1331
1332
/*
1333
 * Reference iterators
1334
 *
1335
 * A reference iterator encapsulates the state of an in-progress
1336
 * iteration over references. Create an instance of `struct
1337
 * ref_iterator` via one of the functions in this module.
1338
 *
1339
 * A freshly-created ref_iterator doesn't yet point at a reference. To
1340
 * advance the iterator, call ref_iterator_advance(). If successful,
1341
 * this sets the iterator's refname, oid, and flags fields to describe
1342
 * the next reference and returns ITER_OK. The data pointed at by
1343
 * refname and oid belong to the iterator; if you want to retain them
1344
 * after calling ref_iterator_advance() again or calling
1345
 * ref_iterator_free(), you must make a copy. When the iteration has
1346
 * been exhausted, ref_iterator_advance() releases any resources
1347
 * associated with the iteration, frees the ref_iterator object, and
1348
 * returns ITER_DONE. If you want to abort the iteration early, call
1349
 * ref_iterator_free(), which also frees the ref_iterator object and
1350
 * any associated resources. If there was an internal error advancing
1351
 * to the next entry, ref_iterator_advance() aborts the iteration,
1352
 * frees the ref_iterator, and returns ITER_ERROR.
1353
 *
1354
 * Putting it all together, a typical iteration looks like this:
1355
 *
1356
 *     int ok;
1357
 *     struct ref_iterator *iter = ...;
1358
 *
1359
 *     while ((ok = ref_iterator_advance(iter)) == ITER_OK) {
1360
 *             if (want_to_stop_iteration()) {
1361
 *                     ok = ITER_DONE;
1362
 *                     break;
1363
 *             }
1364
 *
1365
 *             // Access information about the current reference:
1366
 *             if (!(iter->flags & REF_ISSYMREF))
1367
 *                     printf("%s is %s\n", iter->refname, oid_to_hex(iter->oid));
1368
 *     }
1369
 *
1370
 *     if (ok != ITER_DONE)
1371
 *             handle_error();
1372
 *     ref_iterator_free(iter);
1373
 */
1374
struct ref_iterator;
1375
1376
/*
1377
 * Return an iterator that goes over each reference in `refs` for
1378
 * which the refname begins with prefix. If trim is non-zero, then
1379
 * trim that many characters off the beginning of each refname.
1380
 * The output is ordered by refname.
1381
 */
1382
struct ref_iterator *refs_ref_iterator_begin(
1383
  struct ref_store *refs,
1384
  const char *prefix, const char **exclude_patterns,
1385
  int trim, enum refs_for_each_flag flags);
1386
1387
/*
1388
 * Advance the iterator to the first or next item and return ITER_OK.
1389
 * If the iteration is exhausted, free the resources associated with
1390
 * the ref_iterator and return ITER_DONE. On errors, free the iterator
1391
 * resources and return ITER_ERROR. It is a bug to use ref_iterator or
1392
 * call this function again after it has returned ITER_DONE or
1393
 * ITER_ERROR.
1394
 */
1395
int ref_iterator_advance(struct ref_iterator *ref_iterator);
1396
1397
enum ref_iterator_seek_flag {
1398
  /*
1399
   * When the REF_ITERATOR_SEEK_SET_PREFIX flag is set, the iterator's prefix is
1400
   * updated to match the provided string, affecting all subsequent iterations. If
1401
   * not, the iterator seeks to the specified reference and clears any previously
1402
   * set prefix.
1403
   */
1404
  REF_ITERATOR_SEEK_SET_PREFIX = (1 << 0),
1405
};
1406
1407
/*
1408
 * Seek the iterator to the first reference matching the given seek string.
1409
 * The seek string is matched as a literal string, without regard for path
1410
 * separators. If seek is NULL or the empty string, seek the iterator to the
1411
 * first reference again.
1412
 *
1413
 * This function is expected to behave as if a new ref iterator has been
1414
 * created, but allows reuse of existing iterators for optimization.
1415
 *
1416
 * Returns 0 on success, a negative error code otherwise.
1417
 */
1418
int ref_iterator_seek(struct ref_iterator *ref_iterator, const char *refname,
1419
          unsigned int flags);
1420
1421
/* Free the reference iterator and any associated resources. */
1422
void ref_iterator_free(struct ref_iterator *ref_iterator);
1423
1424
/*
1425
 * The common backend for the for_each_*ref* functions. Call fn for
1426
 * each reference in iter. If the iterator itself ever returns
1427
 * ITER_ERROR, return -1. If fn ever returns a non-zero value, stop
1428
 * the iteration and return that value. Otherwise, return 0. In any
1429
 * case, free the iterator when done. This function is basically an
1430
 * adapter between the callback style of reference iteration and the
1431
 * iterator style.
1432
 */
1433
int do_for_each_ref_iterator(struct ref_iterator *iter,
1434
           refs_for_each_cb fn, void *cb_data);
1435
1436
/*
1437
 * Git only recognizes a directory as a repository if it contains:
1438
 * - HEAD file
1439
 * - refs/ folder
1440
 * While it is necessary within the files backend, newer backends may not
1441
 * follow the same structure. To go around this, we create stubs as necessary.
1442
 *
1443
 * If provided with a 'refs_heads_content', we create the 'refs/heads/head' file
1444
 * with the provided message.
1445
 */
1446
void refs_create_refdir_stubs(struct repository *repo, const char *refdir,
1447
            const char *refs_heads_content);
1448
1449
#endif /* REFS_H */