Blame include/git2/refs.h

Packit Service 20376f
/*
Packit Service 20376f
 * Copyright (C) the libgit2 contributors. All rights reserved.
Packit Service 20376f
 *
Packit Service 20376f
 * This file is part of libgit2, distributed under the GNU GPL v2 with
Packit Service 20376f
 * a Linking Exception. For full terms see the included COPYING file.
Packit Service 20376f
 */
Packit Service 20376f
#ifndef INCLUDE_git_refs_h__
Packit Service 20376f
#define INCLUDE_git_refs_h__
Packit Service 20376f
Packit Service 20376f
#include "common.h"
Packit Service 20376f
#include "types.h"
Packit Service 20376f
#include "oid.h"
Packit Service 20376f
#include "strarray.h"
Packit Service 20376f
Packit Service 20376f
/**
Packit Service 20376f
 * @file git2/refs.h
Packit Service 20376f
 * @brief Git reference management routines
Packit Service 20376f
 * @defgroup git_reference Git reference management routines
Packit Service 20376f
 * @ingroup Git
Packit Service 20376f
 * @{
Packit Service 20376f
 */
Packit Service 20376f
GIT_BEGIN_DECL
Packit Service 20376f
Packit Service 20376f
/**
Packit Service 20376f
 * Lookup a reference by name in a repository.
Packit Service 20376f
 *
Packit Service 20376f
 * The returned reference must be freed by the user.
Packit Service 20376f
 *
Packit Service 20376f
 * The name will be checked for validity.
Packit Service 20376f
 * See `git_reference_symbolic_create()` for rules about valid names.
Packit Service 20376f
 *
Packit Service 20376f
 * @param out pointer to the looked-up reference
Packit Service 20376f
 * @param repo the repository to look up the reference
Packit Service 20376f
 * @param name the long name for the reference (e.g. HEAD, refs/heads/master, refs/tags/v0.1.0, ...)
Packit Service 20376f
 * @return 0 on success, GIT_ENOTFOUND, GIT_EINVALIDSPEC or an error code.
Packit Service 20376f
 */
Packit Service 20376f
GIT_EXTERN(int) git_reference_lookup(git_reference **out, git_repository *repo, const char *name);
Packit Service 20376f
Packit Service 20376f
/**
Packit Service 20376f
 * Lookup a reference by name and resolve immediately to OID.
Packit Service 20376f
 *
Packit Service 20376f
 * This function provides a quick way to resolve a reference name straight
Packit Service 20376f
 * through to the object id that it refers to.  This avoids having to
Packit Service 20376f
 * allocate or free any `git_reference` objects for simple situations.
Packit Service 20376f
 *
Packit Service 20376f
 * The name will be checked for validity.
Packit Service 20376f
 * See `git_reference_symbolic_create()` for rules about valid names.
Packit Service 20376f
 *
Packit Service 20376f
 * @param out Pointer to oid to be filled in
Packit Service 20376f
 * @param repo The repository in which to look up the reference
Packit Service 20376f
 * @param name The long name for the reference (e.g. HEAD, refs/heads/master, refs/tags/v0.1.0, ...)
Packit Service 20376f
 * @return 0 on success, GIT_ENOTFOUND, GIT_EINVALIDSPEC or an error code.
Packit Service 20376f
 */
Packit Service 20376f
GIT_EXTERN(int) git_reference_name_to_id(
Packit Service 20376f
	git_oid *out, git_repository *repo, const char *name);
Packit Service 20376f
Packit Service 20376f
/**
Packit Service 20376f
 * Lookup a reference by DWIMing its short name
Packit Service 20376f
 *
Packit Service 20376f
 * Apply the git precendence rules to the given shorthand to determine
Packit Service 20376f
 * which reference the user is referring to.
Packit Service 20376f
 *
Packit Service 20376f
 * @param out pointer in which to store the reference
Packit Service 20376f
 * @param repo the repository in which to look
Packit Service 20376f
 * @param shorthand the short name for the reference
Packit Service 20376f
 * @return 0 or an error code
Packit Service 20376f
 */
Packit Service 20376f
GIT_EXTERN(int) git_reference_dwim(git_reference **out, git_repository *repo, const char *shorthand);
Packit Service 20376f
Packit Service 20376f
/**
Packit Service 20376f
 * Conditionally create a new symbolic reference.
Packit Service 20376f
 *
Packit Service 20376f
 * A symbolic reference is a reference name that refers to another
Packit Service 20376f
 * reference name.  If the other name moves, the symbolic name will move,
Packit Service 20376f
 * too.  As a simple example, the "HEAD" reference might refer to
Packit Service 20376f
 * "refs/heads/master" while on the "master" branch of a repository.
Packit Service 20376f
 *
Packit Service 20376f
 * The symbolic reference will be created in the repository and written to
Packit Service 20376f
 * the disk.  The generated reference object must be freed by the user.
Packit Service 20376f
 *
Packit Service 20376f
 * Valid reference names must follow one of two patterns:
Packit Service 20376f
 *
Packit Service 20376f
 * 1. Top-level names must contain only capital letters and underscores,
Packit Service 20376f
 *    and must begin and end with a letter. (e.g. "HEAD", "ORIG_HEAD").
Packit Service 20376f
 * 2. Names prefixed with "refs/" can be almost anything.  You must avoid
Packit Service 20376f
 *    the characters '~', '^', ':', '\\', '?', '[', and '*', and the
Packit Service 20376f
 *    sequences ".." and "@{" which have special meaning to revparse.
Packit Service 20376f
 *
Packit Service 20376f
 * This function will return an error if a reference already exists with the
Packit Service 20376f
 * given name unless `force` is true, in which case it will be overwritten.
Packit Service 20376f
 *
Packit Service 20376f
 * The message for the reflog will be ignored if the reference does
Packit Service 20376f
 * not belong in the standard set (HEAD, branches and remote-tracking
Packit Service 20376f
 * branches) and it does not have a reflog.
Packit Service 20376f
 *
Packit Service 20376f
 * It will return GIT_EMODIFIED if the reference's value at the time
Packit Service 20376f
 * of updating does not match the one passed through `current_value`
Packit Service 20376f
 * (i.e. if the ref has changed since the user read it).
Packit Service 20376f
 *
Packit Service 20376f
 * @param out Pointer to the newly created reference
Packit Service 20376f
 * @param repo Repository where that reference will live
Packit Service 20376f
 * @param name The name of the reference
Packit Service 20376f
 * @param target The target of the reference
Packit Service 20376f
 * @param force Overwrite existing references
Packit Service 20376f
 * @param current_value The expected value of the reference when updating
Packit Service 20376f
 * @param log_message The one line long message to be appended to the reflog
Packit Service 20376f
 * @return 0 on success, GIT_EEXISTS, GIT_EINVALIDSPEC, GIT_EMODIFIED or an error code
Packit Service 20376f
 */
Packit Service 20376f
GIT_EXTERN(int) git_reference_symbolic_create_matching(git_reference **out, git_repository *repo, const char *name, const char *target, int force, const char *current_value, const char *log_message);
Packit Service 20376f
Packit Service 20376f
/**
Packit Service 20376f
 * Create a new symbolic reference.
Packit Service 20376f
 *
Packit Service 20376f
 * A symbolic reference is a reference name that refers to another
Packit Service 20376f
 * reference name.  If the other name moves, the symbolic name will move,
Packit Service 20376f
 * too.  As a simple example, the "HEAD" reference might refer to
Packit Service 20376f
 * "refs/heads/master" while on the "master" branch of a repository.
Packit Service 20376f
 *
Packit Service 20376f
 * The symbolic reference will be created in the repository and written to
Packit Service 20376f
 * the disk.  The generated reference object must be freed by the user.
Packit Service 20376f
 *
Packit Service 20376f
 * Valid reference names must follow one of two patterns:
Packit Service 20376f
 *
Packit Service 20376f
 * 1. Top-level names must contain only capital letters and underscores,
Packit Service 20376f
 *    and must begin and end with a letter. (e.g. "HEAD", "ORIG_HEAD").
Packit Service 20376f
 * 2. Names prefixed with "refs/" can be almost anything.  You must avoid
Packit Service 20376f
 *    the characters '~', '^', ':', '\\', '?', '[', and '*', and the
Packit Service 20376f
 *    sequences ".." and "@{" which have special meaning to revparse.
Packit Service 20376f
 *
Packit Service 20376f
 * This function will return an error if a reference already exists with the
Packit Service 20376f
 * given name unless `force` is true, in which case it will be overwritten.
Packit Service 20376f
 *
Packit Service 20376f
 * The message for the reflog will be ignored if the reference does
Packit Service 20376f
 * not belong in the standard set (HEAD, branches and remote-tracking
Packit Service 20376f
 * branches) and it does not have a reflog.
Packit Service 20376f
 *
Packit Service 20376f
 * @param out Pointer to the newly created reference
Packit Service 20376f
 * @param repo Repository where that reference will live
Packit Service 20376f
 * @param name The name of the reference
Packit Service 20376f
 * @param target The target of the reference
Packit Service 20376f
 * @param force Overwrite existing references
Packit Service 20376f
 * @param log_message The one line long message to be appended to the reflog
Packit Service 20376f
 * @return 0 on success, GIT_EEXISTS, GIT_EINVALIDSPEC or an error code
Packit Service 20376f
 */
Packit Service 20376f
GIT_EXTERN(int) git_reference_symbolic_create(git_reference **out, git_repository *repo, const char *name, const char *target, int force, const char *log_message);
Packit Service 20376f
Packit Service 20376f
/**
Packit Service 20376f
 * Create a new direct reference.
Packit Service 20376f
 *
Packit Service 20376f
 * A direct reference (also called an object id reference) refers directly
Packit Service 20376f
 * to a specific object id (a.k.a. OID or SHA) in the repository.  The id
Packit Service 20376f
 * permanently refers to the object (although the reference itself can be
Packit Service 20376f
 * moved).  For example, in libgit2 the direct ref "refs/tags/v0.17.0"
Packit Service 20376f
 * refers to OID 5b9fac39d8a76b9139667c26a63e6b3f204b3977.
Packit Service 20376f
 *
Packit Service 20376f
 * The direct reference will be created in the repository and written to
Packit Service 20376f
 * the disk.  The generated reference object must be freed by the user.
Packit Service 20376f
 *
Packit Service 20376f
 * Valid reference names must follow one of two patterns:
Packit Service 20376f
 *
Packit Service 20376f
 * 1. Top-level names must contain only capital letters and underscores,
Packit Service 20376f
 *    and must begin and end with a letter. (e.g. "HEAD", "ORIG_HEAD").
Packit Service 20376f
 * 2. Names prefixed with "refs/" can be almost anything.  You must avoid
Packit Service 20376f
 *    the characters '~', '^', ':', '\\', '?', '[', and '*', and the
Packit Service 20376f
 *    sequences ".." and "@{" which have special meaning to revparse.
Packit Service 20376f
 *
Packit Service 20376f
 * This function will return an error if a reference already exists with the
Packit Service 20376f
 * given name unless `force` is true, in which case it will be overwritten.
Packit Service 20376f
 *
Packit Service 20376f
 * The message for the reflog will be ignored if the reference does
Packit Service 20376f
 * not belong in the standard set (HEAD, branches and remote-tracking
Packit Service 20376f
 * branches) and and it does not have a reflog.
Packit Service 20376f
 *
Packit Service 20376f
 * @param out Pointer to the newly created reference
Packit Service 20376f
 * @param repo Repository where that reference will live
Packit Service 20376f
 * @param name The name of the reference
Packit Service 20376f
 * @param id The object id pointed to by the reference.
Packit Service 20376f
 * @param force Overwrite existing references
Packit Service 20376f
 * @param log_message The one line long message to be appended to the reflog
Packit Service 20376f
 * @return 0 on success, GIT_EEXISTS, GIT_EINVALIDSPEC or an error code
Packit Service 20376f
 */
Packit Service 20376f
GIT_EXTERN(int) git_reference_create(git_reference **out, git_repository *repo, const char *name, const git_oid *id, int force, const char *log_message);
Packit Service 20376f
Packit Service 20376f
/**
Packit Service 20376f
 * Conditionally create new direct reference
Packit Service 20376f
 *
Packit Service 20376f
 * A direct reference (also called an object id reference) refers directly
Packit Service 20376f
 * to a specific object id (a.k.a. OID or SHA) in the repository.  The id
Packit Service 20376f
 * permanently refers to the object (although the reference itself can be
Packit Service 20376f
 * moved).  For example, in libgit2 the direct ref "refs/tags/v0.17.0"
Packit Service 20376f
 * refers to OID 5b9fac39d8a76b9139667c26a63e6b3f204b3977.
Packit Service 20376f
 *
Packit Service 20376f
 * The direct reference will be created in the repository and written to
Packit Service 20376f
 * the disk.  The generated reference object must be freed by the user.
Packit Service 20376f
 *
Packit Service 20376f
 * Valid reference names must follow one of two patterns:
Packit Service 20376f
 *
Packit Service 20376f
 * 1. Top-level names must contain only capital letters and underscores,
Packit Service 20376f
 *    and must begin and end with a letter. (e.g. "HEAD", "ORIG_HEAD").
Packit Service 20376f
 * 2. Names prefixed with "refs/" can be almost anything.  You must avoid
Packit Service 20376f
 *    the characters '~', '^', ':', '\\', '?', '[', and '*', and the
Packit Service 20376f
 *    sequences ".." and "@{" which have special meaning to revparse.
Packit Service 20376f
 *
Packit Service 20376f
 * This function will return an error if a reference already exists with the
Packit Service 20376f
 * given name unless `force` is true, in which case it will be overwritten.
Packit Service 20376f
 *
Packit Service 20376f
 * The message for the reflog will be ignored if the reference does
Packit Service 20376f
 * not belong in the standard set (HEAD, branches and remote-tracking
Packit Service 20376f
 * branches) and and it does not have a reflog.
Packit Service 20376f
 *
Packit Service 20376f
 * It will return GIT_EMODIFIED if the reference's value at the time
Packit Service 20376f
 * of updating does not match the one passed through `current_id`
Packit Service 20376f
 * (i.e. if the ref has changed since the user read it).
Packit Service 20376f
 *
Packit Service 20376f
 * @param out Pointer to the newly created reference
Packit Service 20376f
 * @param repo Repository where that reference will live
Packit Service 20376f
 * @param name The name of the reference
Packit Service 20376f
 * @param id The object id pointed to by the reference.
Packit Service 20376f
 * @param force Overwrite existing references
Packit Service 20376f
 * @param current_id The expected value of the reference at the time of update
Packit Service 20376f
 * @param log_message The one line long message to be appended to the reflog
Packit Service 20376f
 * @return 0 on success, GIT_EMODIFIED if the value of the reference
Packit Service 20376f
 * has changed, GIT_EEXISTS, GIT_EINVALIDSPEC or an error code
Packit Service 20376f
 */
Packit Service 20376f
GIT_EXTERN(int) git_reference_create_matching(git_reference **out, git_repository *repo, const char *name, const git_oid *id, int force, const git_oid *current_id, const char *log_message);
Packit Service 20376f
Packit Service 20376f
/**
Packit Service 20376f
 * Get the OID pointed to by a direct reference.
Packit Service 20376f
 *
Packit Service 20376f
 * Only available if the reference is direct (i.e. an object id reference,
Packit Service 20376f
 * not a symbolic one).
Packit Service 20376f
 *
Packit Service 20376f
 * To find the OID of a symbolic ref, call `git_reference_resolve()` and
Packit Service 20376f
 * then this function (or maybe use `git_reference_name_to_id()` to
Packit Service 20376f
 * directly resolve a reference name all the way through to an OID).
Packit Service 20376f
 *
Packit Service 20376f
 * @param ref The reference
Packit Service 20376f
 * @return a pointer to the oid if available, NULL otherwise
Packit Service 20376f
 */
Packit Service 20376f
GIT_EXTERN(const git_oid *) git_reference_target(const git_reference *ref);
Packit Service 20376f
Packit Service 20376f
/**
Packit Service 20376f
 * Return the peeled OID target of this reference.
Packit Service 20376f
 *
Packit Service 20376f
 * This peeled OID only applies to direct references that point to
Packit Service 20376f
 * a hard Tag object: it is the result of peeling such Tag.
Packit Service 20376f
 *
Packit Service 20376f
 * @param ref The reference
Packit Service 20376f
 * @return a pointer to the oid if available, NULL otherwise
Packit Service 20376f
 */
Packit Service 20376f
GIT_EXTERN(const git_oid *) git_reference_target_peel(const git_reference *ref);
Packit Service 20376f
Packit Service 20376f
/**
Packit Service 20376f
 * Get full name to the reference pointed to by a symbolic reference.
Packit Service 20376f
 *
Packit Service 20376f
 * Only available if the reference is symbolic.
Packit Service 20376f
 *
Packit Service 20376f
 * @param ref The reference
Packit Service 20376f
 * @return a pointer to the name if available, NULL otherwise
Packit Service 20376f
 */
Packit Service 20376f
GIT_EXTERN(const char *) git_reference_symbolic_target(const git_reference *ref);
Packit Service 20376f
Packit Service 20376f
/**
Packit Service 20376f
 * Get the type of a reference.
Packit Service 20376f
 *
Packit Service 20376f
 * Either direct (GIT_REF_OID) or symbolic (GIT_REF_SYMBOLIC)
Packit Service 20376f
 *
Packit Service 20376f
 * @param ref The reference
Packit Service 20376f
 * @return the type
Packit Service 20376f
 */
Packit Service 20376f
GIT_EXTERN(git_ref_t) git_reference_type(const git_reference *ref);
Packit Service 20376f
Packit Service 20376f
/**
Packit Service 20376f
 * Get the full name of a reference.
Packit Service 20376f
 *
Packit Service 20376f
 * See `git_reference_symbolic_create()` for rules about valid names.
Packit Service 20376f
 *
Packit Service 20376f
 * @param ref The reference
Packit Service 20376f
 * @return the full name for the ref
Packit Service 20376f
 */
Packit Service 20376f
GIT_EXTERN(const char *) git_reference_name(const git_reference *ref);
Packit Service 20376f
Packit Service 20376f
/**
Packit Service 20376f
 * Resolve a symbolic reference to a direct reference.
Packit Service 20376f
 *
Packit Service 20376f
 * This method iteratively peels a symbolic reference until it resolves to
Packit Service 20376f
 * a direct reference to an OID.
Packit Service 20376f
 *
Packit Service 20376f
 * The peeled reference is returned in the `resolved_ref` argument, and
Packit Service 20376f
 * must be freed manually once it's no longer needed.
Packit Service 20376f
 *
Packit Service 20376f
 * If a direct reference is passed as an argument, a copy of that
Packit Service 20376f
 * reference is returned. This copy must be manually freed too.
Packit Service 20376f
 *
Packit Service 20376f
 * @param out Pointer to the peeled reference
Packit Service 20376f
 * @param ref The reference
Packit Service 20376f
 * @return 0 or an error code
Packit Service 20376f
 */
Packit Service 20376f
GIT_EXTERN(int) git_reference_resolve(git_reference **out, const git_reference *ref);
Packit Service 20376f
Packit Service 20376f
/**
Packit Service 20376f
 * Get the repository where a reference resides.
Packit Service 20376f
 *
Packit Service 20376f
 * @param ref The reference
Packit Service 20376f
 * @return a pointer to the repo
Packit Service 20376f
 */
Packit Service 20376f
GIT_EXTERN(git_repository *) git_reference_owner(const git_reference *ref);
Packit Service 20376f
Packit Service 20376f
/**
Packit Service 20376f
 * Create a new reference with the same name as the given reference but a
Packit Service 20376f
 * different symbolic target. The reference must be a symbolic reference,
Packit Service 20376f
 * otherwise this will fail.
Packit Service 20376f
 *
Packit Service 20376f
 * The new reference will be written to disk, overwriting the given reference.
Packit Service 20376f
 *
Packit Service 20376f
 * The target name will be checked for validity.
Packit Service 20376f
 * See `git_reference_symbolic_create()` for rules about valid names.
Packit Service 20376f
 *
Packit Service 20376f
 * The message for the reflog will be ignored if the reference does
Packit Service 20376f
 * not belong in the standard set (HEAD, branches and remote-tracking
Packit Service 20376f
 * branches) and and it does not have a reflog.
Packit Service 20376f
 *
Packit Service 20376f
 * @param out Pointer to the newly created reference
Packit Service 20376f
 * @param ref The reference
Packit Service 20376f
 * @param target The new target for the reference
Packit Service 20376f
 * @param log_message The one line long message to be appended to the reflog
Packit Service 20376f
 * @return 0 on success, GIT_EINVALIDSPEC or an error code
Packit Service 20376f
 */
Packit Service 20376f
GIT_EXTERN(int) git_reference_symbolic_set_target(
Packit Service 20376f
	git_reference **out,
Packit Service 20376f
	git_reference *ref,
Packit Service 20376f
	const char *target,
Packit Service 20376f
	const char *log_message);
Packit Service 20376f
Packit Service 20376f
/**
Packit Service 20376f
 * Conditionally create a new reference with the same name as the given reference but a
Packit Service 20376f
 * different OID target. The reference must be a direct reference, otherwise
Packit Service 20376f
 * this will fail.
Packit Service 20376f
 *
Packit Service 20376f
 * The new reference will be written to disk, overwriting the given reference.
Packit Service 20376f
 *
Packit Service 20376f
 * @param out Pointer to the newly created reference
Packit Service 20376f
 * @param ref The reference
Packit Service 20376f
 * @param id The new target OID for the reference
Packit Service 20376f
 * @param log_message The one line long message to be appended to the reflog
Packit Service 20376f
 * @return 0 on success, GIT_EMODIFIED if the value of the reference
Packit Service 20376f
 * has changed since it was read, or an error code
Packit Service 20376f
 */
Packit Service 20376f
GIT_EXTERN(int) git_reference_set_target(
Packit Service 20376f
	git_reference **out,
Packit Service 20376f
	git_reference *ref,
Packit Service 20376f
	const git_oid *id,
Packit Service 20376f
	const char *log_message);
Packit Service 20376f
Packit Service 20376f
/**
Packit Service 20376f
 * Rename an existing reference.
Packit Service 20376f
 *
Packit Service 20376f
 * This method works for both direct and symbolic references.
Packit Service 20376f
 *
Packit Service 20376f
 * The new name will be checked for validity.
Packit Service 20376f
 * See `git_reference_symbolic_create()` for rules about valid names.
Packit Service 20376f
 *
Packit Service 20376f
 * If the `force` flag is not enabled, and there's already
Packit Service 20376f
 * a reference with the given name, the renaming will fail.
Packit Service 20376f
 *
Packit Service 20376f
 * IMPORTANT:
Packit Service 20376f
 * The user needs to write a proper reflog entry if the
Packit Service 20376f
 * reflog is enabled for the repository. We only rename
Packit Service 20376f
 * the reflog if it exists.
Packit Service 20376f
 *
Packit Service 20376f
 * @param ref The reference to rename
Packit Service 20376f
 * @param new_name The new name for the reference
Packit Service 20376f
 * @param force Overwrite an existing reference
Packit Service 20376f
 * @param log_message The one line long message to be appended to the reflog
Packit Service 20376f
 * @return 0 on success, GIT_EINVALIDSPEC, GIT_EEXISTS or an error code
Packit Service 20376f
 *
Packit Service 20376f
 */
Packit Service 20376f
GIT_EXTERN(int) git_reference_rename(
Packit Service 20376f
	git_reference **new_ref,
Packit Service 20376f
	git_reference *ref,
Packit Service 20376f
	const char *new_name,
Packit Service 20376f
	int force,
Packit Service 20376f
	const char *log_message);
Packit Service 20376f
Packit Service 20376f
/**
Packit Service 20376f
 * Delete an existing reference.
Packit Service 20376f
 *
Packit Service 20376f
 * This method works for both direct and symbolic references.  The reference
Packit Service 20376f
 * will be immediately removed on disk but the memory will not be freed.
Packit Service 20376f
 * Callers must call `git_reference_free`.
Packit Service 20376f
 *
Packit Service 20376f
 * This function will return an error if the reference has changed
Packit Service 20376f
 * from the time it was looked up.
Packit Service 20376f
 *
Packit Service 20376f
 * @param ref The reference to remove
Packit Service 20376f
 * @return 0, GIT_EMODIFIED or an error code
Packit Service 20376f
 */
Packit Service 20376f
GIT_EXTERN(int) git_reference_delete(git_reference *ref);
Packit Service 20376f
Packit Service 20376f
/**
Packit Service 20376f
 * Delete an existing reference by name
Packit Service 20376f
 *
Packit Service 20376f
 * This method removes the named reference from the repository without
Packit Service 20376f
 * looking at its old value.
Packit Service 20376f
 *
Packit Service 20376f
 * @param name The reference to remove
Packit Service 20376f
 * @return 0 or an error code
Packit Service 20376f
 */
Packit Service 20376f
GIT_EXTERN(int) git_reference_remove(git_repository *repo, const char *name);
Packit Service 20376f
Packit Service 20376f
/**
Packit Service 20376f
 * Fill a list with all the references that can be found in a repository.
Packit Service 20376f
 *
Packit Service 20376f
 * The string array will be filled with the names of all references; these
Packit Service 20376f
 * values are owned by the user and should be free'd manually when no
Packit Service 20376f
 * longer needed, using `git_strarray_free()`.
Packit Service 20376f
 *
Packit Service 20376f
 * @param array Pointer to a git_strarray structure where
Packit Service 20376f
 *		the reference names will be stored
Packit Service 20376f
 * @param repo Repository where to find the refs
Packit Service 20376f
 * @return 0 or an error code
Packit Service 20376f
 */
Packit Service 20376f
GIT_EXTERN(int) git_reference_list(git_strarray *array, git_repository *repo);
Packit Service 20376f
Packit Service 20376f
typedef int (*git_reference_foreach_cb)(git_reference *reference, void *payload);
Packit Service 20376f
typedef int (*git_reference_foreach_name_cb)(const char *name, void *payload);
Packit Service 20376f
Packit Service 20376f
/**
Packit Service 20376f
 * Perform a callback on each reference in the repository.
Packit Service 20376f
 *
Packit Service 20376f
 * The `callback` function will be called for each reference in the
Packit Service 20376f
 * repository, receiving the reference object and the `payload` value
Packit Service 20376f
 * passed to this method.  Returning a non-zero value from the callback
Packit Service 20376f
 * will terminate the iteration.
Packit Service 20376f
 *
Packit Service 20376f
 * @param repo Repository where to find the refs
Packit Service 20376f
 * @param callback Function which will be called for every listed ref
Packit Service 20376f
 * @param payload Additional data to pass to the callback
Packit Service 20376f
 * @return 0 on success, non-zero callback return value, or error code
Packit Service 20376f
 */
Packit Service 20376f
GIT_EXTERN(int) git_reference_foreach(
Packit Service 20376f
	git_repository *repo,
Packit Service 20376f
	git_reference_foreach_cb callback,
Packit Service 20376f
	void *payload);
Packit Service 20376f
Packit Service 20376f
/**
Packit Service 20376f
 * Perform a callback on the fully-qualified name of each reference.
Packit Service 20376f
 *
Packit Service 20376f
 * The `callback` function will be called for each reference in the
Packit Service 20376f
 * repository, receiving the name of the reference and the `payload` value
Packit Service 20376f
 * passed to this method.  Returning a non-zero value from the callback
Packit Service 20376f
 * will terminate the iteration.
Packit Service 20376f
 *
Packit Service 20376f
 * @param repo Repository where to find the refs
Packit Service 20376f
 * @param callback Function which will be called for every listed ref name
Packit Service 20376f
 * @param payload Additional data to pass to the callback
Packit Service 20376f
 * @return 0 on success, non-zero callback return value, or error code
Packit Service 20376f
 */
Packit Service 20376f
GIT_EXTERN(int) git_reference_foreach_name(
Packit Service 20376f
	git_repository *repo,
Packit Service 20376f
	git_reference_foreach_name_cb callback,
Packit Service 20376f
	void *payload);
Packit Service 20376f
Packit Service 20376f
/**
Packit Service 20376f
 * Create a copy of an existing reference.
Packit Service 20376f
 *
Packit Service 20376f
 * Call `git_reference_free` to free the data.
Packit Service 20376f
 *
Packit Service 20376f
 * @param dest pointer where to store the copy
Packit Service 20376f
 * @param source object to copy
Packit Service 20376f
 * @return 0 or an error code
Packit Service 20376f
 */
Packit Service 20376f
GIT_EXTERN(int) git_reference_dup(git_reference **dest, git_reference *source);
Packit Service 20376f
Packit Service 20376f
/**
Packit Service 20376f
 * Free the given reference.
Packit Service 20376f
 *
Packit Service 20376f
 * @param ref git_reference
Packit Service 20376f
 */
Packit Service 20376f
GIT_EXTERN(void) git_reference_free(git_reference *ref);
Packit Service 20376f
Packit Service 20376f
/**
Packit Service 20376f
 * Compare two references.
Packit Service 20376f
 *
Packit Service 20376f
 * @param ref1 The first git_reference
Packit Service 20376f
 * @param ref2 The second git_reference
Packit Service 20376f
 * @return 0 if the same, else a stable but meaningless ordering.
Packit Service 20376f
 */
Packit Service 20376f
GIT_EXTERN(int) git_reference_cmp(
Packit Service 20376f
	const git_reference *ref1,
Packit Service 20376f
	const git_reference *ref2);
Packit Service 20376f
Packit Service 20376f
/**
Packit Service 20376f
 * Create an iterator for the repo's references
Packit Service 20376f
 *
Packit Service 20376f
 * @param out pointer in which to store the iterator
Packit Service 20376f
 * @param repo the repository
Packit Service 20376f
 * @return 0 or an error code
Packit Service 20376f
 */
Packit Service 20376f
GIT_EXTERN(int) git_reference_iterator_new(
Packit Service 20376f
	git_reference_iterator **out,
Packit Service 20376f
	git_repository *repo);
Packit Service 20376f
Packit Service 20376f
/**
Packit Service 20376f
 * Create an iterator for the repo's references that match the
Packit Service 20376f
 * specified glob
Packit Service 20376f
 *
Packit Service 20376f
 * @param out pointer in which to store the iterator
Packit Service 20376f
 * @param repo the repository
Packit Service 20376f
 * @param glob the glob to match against the reference names
Packit Service 20376f
 * @return 0 or an error code
Packit Service 20376f
 */
Packit Service 20376f
GIT_EXTERN(int) git_reference_iterator_glob_new(
Packit Service 20376f
	git_reference_iterator **out,
Packit Service 20376f
	git_repository *repo,
Packit Service 20376f
	const char *glob);
Packit Service 20376f
Packit Service 20376f
/**
Packit Service 20376f
 * Get the next reference
Packit Service 20376f
 *
Packit Service 20376f
 * @param out pointer in which to store the reference
Packit Service 20376f
 * @param iter the iterator
Packit Service 20376f
 * @return 0, GIT_ITEROVER if there are no more; or an error code
Packit Service 20376f
 */
Packit Service 20376f
GIT_EXTERN(int) git_reference_next(git_reference **out, git_reference_iterator *iter);
Packit Service 20376f
Packit Service 20376f
/**
Packit Service 20376f
 * Get the next reference's name
Packit Service 20376f
 *
Packit Service 20376f
 * This function is provided for convenience in case only the names
Packit Service 20376f
 * are interesting as it avoids the allocation of the `git_reference`
Packit Service 20376f
 * object which `git_reference_next()` needs.
Packit Service 20376f
 *
Packit Service 20376f
 * @param out pointer in which to store the string
Packit Service 20376f
 * @param iter the iterator
Packit Service 20376f
 * @return 0, GIT_ITEROVER if there are no more; or an error code
Packit Service 20376f
 */
Packit Service 20376f
GIT_EXTERN(int) git_reference_next_name(const char **out, git_reference_iterator *iter);
Packit Service 20376f
Packit Service 20376f
/**
Packit Service 20376f
 * Free the iterator and its associated resources
Packit Service 20376f
 *
Packit Service 20376f
 * @param iter the iterator to free
Packit Service 20376f
 */
Packit Service 20376f
GIT_EXTERN(void) git_reference_iterator_free(git_reference_iterator *iter);
Packit Service 20376f
Packit Service 20376f
/**
Packit Service 20376f
 * Perform a callback on each reference in the repository whose name
Packit Service 20376f
 * matches the given pattern.
Packit Service 20376f
 *
Packit Service 20376f
 * This function acts like `git_reference_foreach()` with an additional
Packit Service 20376f
 * pattern match being applied to the reference name before issuing the
Packit Service 20376f
 * callback function.  See that function for more information.
Packit Service 20376f
 *
Packit Service 20376f
 * The pattern is matched using fnmatch or "glob" style where a '*' matches
Packit Service 20376f
 * any sequence of letters, a '?' matches any letter, and square brackets
Packit Service 20376f
 * can be used to define character ranges (such as "[0-9]" for digits).
Packit Service 20376f
 *
Packit Service 20376f
 * @param repo Repository where to find the refs
Packit Service 20376f
 * @param glob Pattern to match (fnmatch-style) against reference name.
Packit Service 20376f
 * @param callback Function which will be called for every listed ref
Packit Service 20376f
 * @param payload Additional data to pass to the callback
Packit Service 20376f
 * @return 0 on success, GIT_EUSER on non-zero callback, or error code
Packit Service 20376f
 */
Packit Service 20376f
GIT_EXTERN(int) git_reference_foreach_glob(
Packit Service 20376f
	git_repository *repo,
Packit Service 20376f
	const char *glob,
Packit Service 20376f
	git_reference_foreach_name_cb callback,
Packit Service 20376f
	void *payload);
Packit Service 20376f
Packit Service 20376f
/**
Packit Service 20376f
 * Check if a reflog exists for the specified reference.
Packit Service 20376f
 *
Packit Service 20376f
 * @param repo the repository
Packit Service 20376f
 * @param refname the reference's name
Packit Service 20376f
 * @return 0 when no reflog can be found, 1 when it exists;
Packit Service 20376f
 * otherwise an error code.
Packit Service 20376f
 */
Packit Service 20376f
GIT_EXTERN(int) git_reference_has_log(git_repository *repo, const char *refname);
Packit Service 20376f
Packit Service 20376f
/**
Packit Service 20376f
 * Ensure there is a reflog for a particular reference.
Packit Service 20376f
 *
Packit Service 20376f
 * Make sure that successive updates to the reference will append to
Packit Service 20376f
 * its log.
Packit Service 20376f
 *
Packit Service 20376f
 * @param repo the repository
Packit Service 20376f
 * @param refname the reference's name
Packit Service 20376f
 * @return 0 or an error code.
Packit Service 20376f
 */
Packit Service 20376f
GIT_EXTERN(int) git_reference_ensure_log(git_repository *repo, const char *refname);
Packit Service 20376f
Packit Service 20376f
/**
Packit Service 20376f
 * Check if a reference is a local branch.
Packit Service 20376f
 *
Packit Service 20376f
 * @param ref A git reference
Packit Service 20376f
 *
Packit Service 20376f
 * @return 1 when the reference lives in the refs/heads
Packit Service 20376f
 * namespace; 0 otherwise.
Packit Service 20376f
 */
Packit Service 20376f
GIT_EXTERN(int) git_reference_is_branch(const git_reference *ref);
Packit Service 20376f
Packit Service 20376f
/**
Packit Service 20376f
 * Check if a reference is a remote tracking branch
Packit Service 20376f
 *
Packit Service 20376f
 * @param ref A git reference
Packit Service 20376f
 *
Packit Service 20376f
 * @return 1 when the reference lives in the refs/remotes
Packit Service 20376f
 * namespace; 0 otherwise.
Packit Service 20376f
 */
Packit Service 20376f
GIT_EXTERN(int) git_reference_is_remote(const git_reference *ref);
Packit Service 20376f
Packit Service 20376f
/**
Packit Service 20376f
 * Check if a reference is a tag
Packit Service 20376f
 *
Packit Service 20376f
 * @param ref A git reference
Packit Service 20376f
 *
Packit Service 20376f
 * @return 1 when the reference lives in the refs/tags
Packit Service 20376f
 * namespace; 0 otherwise.
Packit Service 20376f
 */
Packit Service 20376f
GIT_EXTERN(int) git_reference_is_tag(const git_reference *ref);
Packit Service 20376f
Packit Service 20376f
/**
Packit Service 20376f
 * Check if a reference is a note
Packit Service 20376f
 *
Packit Service 20376f
 * @param ref A git reference
Packit Service 20376f
 *
Packit Service 20376f
 * @return 1 when the reference lives in the refs/notes
Packit Service 20376f
 * namespace; 0 otherwise.
Packit Service 20376f
 */
Packit Service 20376f
GIT_EXTERN(int) git_reference_is_note(const git_reference *ref);
Packit Service 20376f
Packit Service 20376f
/**
Packit Service 20376f
 * Normalization options for reference lookup
Packit Service 20376f
 */
Packit Service 20376f
typedef enum {
Packit Service 20376f
	/**
Packit Service 20376f
	 * No particular normalization.
Packit Service 20376f
	 */
Packit Service 20376f
	GIT_REF_FORMAT_NORMAL = 0u,
Packit Service 20376f
Packit Service 20376f
	/**
Packit Service 20376f
	 * Control whether one-level refnames are accepted
Packit Service 20376f
	 * (i.e., refnames that do not contain multiple /-separated
Packit Service 20376f
	 * components). Those are expected to be written only using
Packit Service 20376f
	 * uppercase letters and underscore (FETCH_HEAD, ...)
Packit Service 20376f
	 */
Packit Service 20376f
	GIT_REF_FORMAT_ALLOW_ONELEVEL = (1u << 0),
Packit Service 20376f
Packit Service 20376f
	/**
Packit Service 20376f
	 * Interpret the provided name as a reference pattern for a
Packit Service 20376f
	 * refspec (as used with remote repositories). If this option
Packit Service 20376f
	 * is enabled, the name is allowed to contain a single * (<star>)
Packit Service 20376f
	 * in place of a one full pathname component
Packit Service 20376f
	 * (e.g., foo/<star>/bar but not foo/bar<star>).
Packit Service 20376f
	 */
Packit Service 20376f
	GIT_REF_FORMAT_REFSPEC_PATTERN = (1u << 1),
Packit Service 20376f
Packit Service 20376f
	/**
Packit Service 20376f
	 * Interpret the name as part of a refspec in shorthand form
Packit Service 20376f
	 * so the `ONELEVEL` naming rules aren't enforced and 'master'
Packit Service 20376f
	 * becomes a valid name.
Packit Service 20376f
	 */
Packit Service 20376f
	GIT_REF_FORMAT_REFSPEC_SHORTHAND = (1u << 2),
Packit Service 20376f
} git_reference_normalize_t;
Packit Service 20376f
Packit Service 20376f
/**
Packit Service 20376f
 * Normalize reference name and check validity.
Packit Service 20376f
 *
Packit Service 20376f
 * This will normalize the reference name by removing any leading slash
Packit Service 20376f
 * '/' characters and collapsing runs of adjacent slashes between name
Packit Service 20376f
 * components into a single slash.
Packit Service 20376f
 *
Packit Service 20376f
 * Once normalized, if the reference name is valid, it will be returned in
Packit Service 20376f
 * the user allocated buffer.
Packit Service 20376f
 *
Packit Service 20376f
 * See `git_reference_symbolic_create()` for rules about valid names.
Packit Service 20376f
 *
Packit Service 20376f
 * @param buffer_out User allocated buffer to store normalized name
Packit Service 20376f
 * @param buffer_size Size of buffer_out
Packit Service 20376f
 * @param name Reference name to be checked.
Packit Service 20376f
 * @param flags Flags to constrain name validation rules - see the
Packit Service 20376f
 *              GIT_REF_FORMAT constants above.
Packit Service 20376f
 * @return 0 on success, GIT_EBUFS if buffer is too small, GIT_EINVALIDSPEC
Packit Service 20376f
 * or an error code.
Packit Service 20376f
 */
Packit Service 20376f
GIT_EXTERN(int) git_reference_normalize_name(
Packit Service 20376f
	char *buffer_out,
Packit Service 20376f
	size_t buffer_size,
Packit Service 20376f
	const char *name,
Packit Service 20376f
	unsigned int flags);
Packit Service 20376f
Packit Service 20376f
/**
Packit Service 20376f
 * Recursively peel reference until object of the specified type is found.
Packit Service 20376f
 *
Packit Service 20376f
 * The retrieved `peeled` object is owned by the repository
Packit Service 20376f
 * and should be closed with the `git_object_free` method.
Packit Service 20376f
 *
Packit Service 20376f
 * If you pass `GIT_OBJ_ANY` as the target type, then the object
Packit Service 20376f
 * will be peeled until a non-tag object is met.
Packit Service 20376f
 *
Packit Service 20376f
 * @param out Pointer to the peeled git_object
Packit Service 20376f
 * @param ref The reference to be processed
Packit Service 20376f
 * @param type The type of the requested object (GIT_OBJ_COMMIT,
Packit Service 20376f
 * GIT_OBJ_TAG, GIT_OBJ_TREE, GIT_OBJ_BLOB or GIT_OBJ_ANY).
Packit Service 20376f
 * @return 0 on success, GIT_EAMBIGUOUS, GIT_ENOTFOUND or an error code
Packit Service 20376f
 */
Packit Service 20376f
GIT_EXTERN(int) git_reference_peel(
Packit Service 20376f
	git_object **out,
Packit Service 20376f
	git_reference *ref,
Packit Service 20376f
	git_otype type);
Packit Service 20376f
Packit Service 20376f
/**
Packit Service 20376f
 * Ensure the reference name is well-formed.
Packit Service 20376f
 *
Packit Service 20376f
 * Valid reference names must follow one of two patterns:
Packit Service 20376f
 *
Packit Service 20376f
 * 1. Top-level names must contain only capital letters and underscores,
Packit Service 20376f
 *    and must begin and end with a letter. (e.g. "HEAD", "ORIG_HEAD").
Packit Service 20376f
 * 2. Names prefixed with "refs/" can be almost anything.  You must avoid
Packit Service 20376f
 *    the characters '~', '^', ':', '\\', '?', '[', and '*', and the
Packit Service 20376f
 *    sequences ".." and "@{" which have special meaning to revparse.
Packit Service 20376f
 *
Packit Service 20376f
 * @param refname name to be checked.
Packit Service 20376f
 * @return 1 if the reference name is acceptable; 0 if it isn't
Packit Service 20376f
 */
Packit Service 20376f
GIT_EXTERN(int) git_reference_is_valid_name(const char *refname);
Packit Service 20376f
Packit Service 20376f
/**
Packit Service 20376f
 * Get the reference's short name
Packit Service 20376f
 *
Packit Service 20376f
 * This will transform the reference name into a name "human-readable"
Packit Service 20376f
 * version. If no shortname is appropriate, it will return the full
Packit Service 20376f
 * name.
Packit Service 20376f
 *
Packit Service 20376f
 * The memory is owned by the reference and must not be freed.
Packit Service 20376f
 *
Packit Service 20376f
 * @param ref a reference
Packit Service 20376f
 * @return the human-readable version of the name
Packit Service 20376f
 */
Packit Service 20376f
GIT_EXTERN(const char *) git_reference_shorthand(const git_reference *ref);
Packit Service 20376f
Packit Service 20376f
Packit Service 20376f
/** @} */
Packit Service 20376f
GIT_END_DECL
Packit Service 20376f
#endif