Blame include/git2/sys/refdb_backend.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_sys_git_refdb_backend_h__
Packit Service 20376f
#define INCLUDE_sys_git_refdb_backend_h__
Packit Service 20376f
Packit Service 20376f
#include "git2/common.h"
Packit Service 20376f
#include "git2/types.h"
Packit Service 20376f
#include "git2/oid.h"
Packit Service 20376f
Packit Service 20376f
/**
Packit Service 20376f
 * @file git2/refdb_backend.h
Packit Service 20376f
 * @brief Git custom refs backend functions
Packit Service 20376f
 * @defgroup git_refdb_backend Git custom refs backend API
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
/**
Packit Service 20376f
 * Every backend's iterator must have a pointer to itself as the first
Packit Service 20376f
 * element, so the API can talk to it. You'd define your iterator as
Packit Service 20376f
 *
Packit Service 20376f
 *     struct my_iterator {
Packit Service 20376f
 *             git_reference_iterator parent;
Packit Service 20376f
 *             ...
Packit Service 20376f
 *     }
Packit Service 20376f
 *
Packit Service 20376f
 * and assign `iter->parent.backend` to your `git_refdb_backend`.
Packit Service 20376f
 */
Packit Service 20376f
struct git_reference_iterator {
Packit Service 20376f
	git_refdb *db;
Packit Service 20376f
Packit Service 20376f
	/**
Packit Service 20376f
	 * Return the current reference and advance the iterator.
Packit Service 20376f
	 */
Packit Service 20376f
	int (*next)(
Packit Service 20376f
		git_reference **ref,
Packit Service 20376f
		git_reference_iterator *iter);
Packit Service 20376f
Packit Service 20376f
	/**
Packit Service 20376f
	 * Return the name of the current reference and advance the iterator
Packit Service 20376f
	 */
Packit Service 20376f
	int (*next_name)(
Packit Service 20376f
		const char **ref_name,
Packit Service 20376f
		git_reference_iterator *iter);
Packit Service 20376f
Packit Service 20376f
	/**
Packit Service 20376f
	 * Free the iterator
Packit Service 20376f
	 */
Packit Service 20376f
	void (*free)(
Packit Service 20376f
		git_reference_iterator *iter);
Packit Service 20376f
};
Packit Service 20376f
Packit Service 20376f
/** An instance for a custom backend */
Packit Service 20376f
struct git_refdb_backend {
Packit Service 20376f
	unsigned int version;
Packit Service 20376f
Packit Service 20376f
	/**
Packit Service 20376f
	 * Queries the refdb backend to determine if the given ref_name
Packit Service 20376f
	 * exists.  A refdb implementation must provide this function.
Packit Service 20376f
	 */
Packit Service 20376f
	int (*exists)(
Packit Service 20376f
		int *exists,
Packit Service 20376f
		git_refdb_backend *backend,
Packit Service 20376f
		const char *ref_name);
Packit Service 20376f
Packit Service 20376f
	/**
Packit Service 20376f
	 * Queries the refdb backend for a given reference.  A refdb
Packit Service 20376f
	 * implementation must provide this function.
Packit Service 20376f
	 */
Packit Service 20376f
	int (*lookup)(
Packit Service 20376f
		git_reference **out,
Packit Service 20376f
		git_refdb_backend *backend,
Packit Service 20376f
		const char *ref_name);
Packit Service 20376f
Packit Service 20376f
	/**
Packit Service 20376f
	 * Allocate an iterator object for the backend.
Packit Service 20376f
	 *
Packit Service 20376f
	 * A refdb implementation must provide this function.
Packit Service 20376f
	 */
Packit Service 20376f
	int (*iterator)(
Packit Service 20376f
		git_reference_iterator **iter,
Packit Service 20376f
		struct git_refdb_backend *backend,
Packit Service 20376f
		const char *glob);
Packit Service 20376f
Packit Service 20376f
	/*
Packit Service 20376f
	 * Writes the given reference to the refdb.  A refdb implementation
Packit Service 20376f
	 * must provide this function.
Packit Service 20376f
	 */
Packit Service 20376f
	int (*write)(git_refdb_backend *backend,
Packit Service 20376f
		     const git_reference *ref, int force,
Packit Service 20376f
		     const git_signature *who, const char *message,
Packit Service 20376f
		     const git_oid *old, const char *old_target);
Packit Service 20376f
Packit Service 20376f
	int (*rename)(
Packit Service 20376f
		git_reference **out, git_refdb_backend *backend,
Packit Service 20376f
		const char *old_name, const char *new_name, int force,
Packit Service 20376f
		const git_signature *who, const char *message);
Packit Service 20376f
Packit Service 20376f
	/**
Packit Service 20376f
	 * Deletes the given reference (and if necessary its reflog)
Packit Service 20376f
	 * from the refdb.  A refdb implementation must provide this
Packit Service 20376f
	 * function.
Packit Service 20376f
	 */
Packit Service 20376f
	int (*del)(git_refdb_backend *backend, const char *ref_name, const git_oid *old_id, const char *old_target);
Packit Service 20376f
Packit Service 20376f
	/**
Packit Service 20376f
	 * Suggests that the given refdb compress or optimize its references.
Packit Service 20376f
	 * This mechanism is implementation specific.  (For on-disk reference
Packit Service 20376f
	 * databases, this may pack all loose references.)    A refdb
Packit Service 20376f
	 * implementation may provide this function; if it is not provided,
Packit Service 20376f
	 * nothing will be done.
Packit Service 20376f
	 */
Packit Service 20376f
	int (*compress)(git_refdb_backend *backend);
Packit Service 20376f
Packit Service 20376f
	/**
Packit Service 20376f
	 * Query whether a particular reference has a log (may be empty)
Packit Service 20376f
	 */
Packit Service 20376f
	int (*has_log)(git_refdb_backend *backend, const char *refname);
Packit Service 20376f
Packit Service 20376f
	/**
Packit Service 20376f
	 * Make sure a particular reference will have a reflog which
Packit Service 20376f
	 * will be appended to on writes.
Packit Service 20376f
	 */
Packit Service 20376f
	int (*ensure_log)(git_refdb_backend *backend, const char *refname);
Packit Service 20376f
Packit Service 20376f
	/**
Packit Service 20376f
	 * Frees any resources held by the refdb (including the `git_refdb_backend`
Packit Service 20376f
	 * itself). A refdb backend implementation must provide this function.
Packit Service 20376f
	 */
Packit Service 20376f
	void (*free)(git_refdb_backend *backend);
Packit Service 20376f
Packit Service 20376f
	/**
Packit Service 20376f
	 * Read the reflog for the given reference name.
Packit Service 20376f
	 */
Packit Service 20376f
	int (*reflog_read)(git_reflog **out, git_refdb_backend *backend, const char *name);
Packit Service 20376f
Packit Service 20376f
	/**
Packit Service 20376f
	 * Write a reflog to disk.
Packit Service 20376f
	 */
Packit Service 20376f
	int (*reflog_write)(git_refdb_backend *backend, git_reflog *reflog);
Packit Service 20376f
Packit Service 20376f
	/**
Packit Service 20376f
	 * Rename a reflog
Packit Service 20376f
	 */
Packit Service 20376f
	int (*reflog_rename)(git_refdb_backend *_backend, const char *old_name, const char *new_name);
Packit Service 20376f
Packit Service 20376f
	/**
Packit Service 20376f
	 * Remove a reflog.
Packit Service 20376f
	 */
Packit Service 20376f
	int (*reflog_delete)(git_refdb_backend *backend, const char *name);
Packit Service 20376f
Packit Service 20376f
	/**
Packit Service 20376f
	 * Lock a reference. The opaque parameter will be passed to the unlock function
Packit Service 20376f
	 */
Packit Service 20376f
	int (*lock)(void **payload_out, git_refdb_backend *backend, const char *refname);
Packit Service 20376f
Packit Service 20376f
	/**
Packit Service 20376f
	 * Unlock a reference. Only one of target or symbolic_target
Packit Service 20376f
	 * will be set. success indicates whether to update the
Packit Service 20376f
	 * reference or discard the lock (if it's false)
Packit Service 20376f
	 */
Packit Service 20376f
	int (*unlock)(git_refdb_backend *backend, void *payload, int success, int update_reflog,
Packit Service 20376f
		      const git_reference *ref, const git_signature *sig, const char *message);
Packit Service 20376f
};
Packit Service 20376f
Packit Service 20376f
#define GIT_REFDB_BACKEND_VERSION 1
Packit Service 20376f
#define GIT_REFDB_BACKEND_INIT {GIT_REFDB_BACKEND_VERSION}
Packit Service 20376f
Packit Service 20376f
/**
Packit Service 20376f
 * Initializes a `git_refdb_backend` with default values. Equivalent to
Packit Service 20376f
 * creating an instance with GIT_REFDB_BACKEND_INIT.
Packit Service 20376f
 *
Packit Service 20376f
 * @param backend the `git_refdb_backend` struct to initialize
Packit Service 20376f
 * @param version Version of struct; pass `GIT_REFDB_BACKEND_VERSION`
Packit Service 20376f
 * @return Zero on success; -1 on failure.
Packit Service 20376f
 */
Packit Service 20376f
GIT_EXTERN(int) git_refdb_init_backend(
Packit Service 20376f
	git_refdb_backend *backend,
Packit Service 20376f
	unsigned int version);
Packit Service 20376f
Packit Service 20376f
/**
Packit Service 20376f
 * Constructors for default filesystem-based refdb backend
Packit Service 20376f
 *
Packit Service 20376f
 * Under normal usage, this is called for you when the repository is
Packit Service 20376f
 * opened / created, but you can use this to explicitly construct a
Packit Service 20376f
 * filesystem refdb backend for a repository.
Packit Service 20376f
 *
Packit Service 20376f
 * @param backend_out Output pointer to the git_refdb_backend object
Packit Service 20376f
 * @param repo Git repository to access
Packit Service 20376f
 * @return 0 on success, <0 error code on failure
Packit Service 20376f
 */
Packit Service 20376f
GIT_EXTERN(int) git_refdb_backend_fs(
Packit Service 20376f
	git_refdb_backend **backend_out,
Packit Service 20376f
	git_repository *repo);
Packit Service 20376f
Packit Service 20376f
/**
Packit Service 20376f
 * Sets the custom backend to an existing reference DB
Packit Service 20376f
 *
Packit Service 20376f
 * The `git_refdb` will take ownership of the `git_refdb_backend` so you
Packit Service 20376f
 * should NOT free it after calling this function.
Packit Service 20376f
 *
Packit Service 20376f
 * @param refdb database to add the backend to
Packit Service 20376f
 * @param backend pointer to a git_refdb_backend instance
Packit Service 20376f
 * @return 0 on success; error code otherwise
Packit Service 20376f
 */
Packit Service 20376f
GIT_EXTERN(int) git_refdb_set_backend(
Packit Service 20376f
	git_refdb *refdb,
Packit Service 20376f
	git_refdb_backend *backend);
Packit Service 20376f
Packit Service 20376f
GIT_END_DECL
Packit Service 20376f
Packit Service 20376f
#endif