|
Packit |
ae9e2a |
/*
|
|
Packit |
ae9e2a |
* Copyright (C) the libgit2 contributors. All rights reserved.
|
|
Packit |
ae9e2a |
*
|
|
Packit |
ae9e2a |
* This file is part of libgit2, distributed under the GNU GPL v2 with
|
|
Packit |
ae9e2a |
* a Linking Exception. For full terms see the included COPYING file.
|
|
Packit |
ae9e2a |
*/
|
|
Packit |
ae9e2a |
#ifndef INCLUDE_git_checkout_h__
|
|
Packit |
ae9e2a |
#define INCLUDE_git_checkout_h__
|
|
Packit |
ae9e2a |
|
|
Packit |
ae9e2a |
#include "common.h"
|
|
Packit |
ae9e2a |
#include "types.h"
|
|
Packit |
ae9e2a |
#include "diff.h"
|
|
Packit |
ae9e2a |
|
|
Packit |
ae9e2a |
/**
|
|
Packit |
ae9e2a |
* @file git2/checkout.h
|
|
Packit |
ae9e2a |
* @brief Git checkout routines
|
|
Packit |
ae9e2a |
* @defgroup git_checkout Git checkout routines
|
|
Packit |
ae9e2a |
* @ingroup Git
|
|
Packit |
ae9e2a |
* @{
|
|
Packit |
ae9e2a |
*/
|
|
Packit |
ae9e2a |
GIT_BEGIN_DECL
|
|
Packit |
ae9e2a |
|
|
Packit |
ae9e2a |
/**
|
|
Packit |
ae9e2a |
* Checkout behavior flags
|
|
Packit |
ae9e2a |
*
|
|
Packit |
ae9e2a |
* In libgit2, checkout is used to update the working directory and index
|
|
Packit |
ae9e2a |
* to match a target tree. Unlike git checkout, it does not move the HEAD
|
|
Packit |
ae9e2a |
* commit for you - use `git_repository_set_head` or the like to do that.
|
|
Packit |
ae9e2a |
*
|
|
Packit |
ae9e2a |
* Checkout looks at (up to) four things: the "target" tree you want to
|
|
Packit |
ae9e2a |
* check out, the "baseline" tree of what was checked out previously, the
|
|
Packit |
ae9e2a |
* working directory for actual files, and the index for staged changes.
|
|
Packit |
ae9e2a |
*
|
|
Packit |
ae9e2a |
* You give checkout one of three strategies for update:
|
|
Packit |
ae9e2a |
*
|
|
Packit |
ae9e2a |
* - `GIT_CHECKOUT_NONE` is a dry-run strategy that checks for conflicts,
|
|
Packit |
ae9e2a |
* etc., but doesn't make any actual changes.
|
|
Packit |
ae9e2a |
*
|
|
Packit |
ae9e2a |
* - `GIT_CHECKOUT_FORCE` is at the opposite extreme, taking any action to
|
|
Packit |
ae9e2a |
* make the working directory match the target (including potentially
|
|
Packit |
ae9e2a |
* discarding modified files).
|
|
Packit |
ae9e2a |
*
|
|
Packit |
ae9e2a |
* - `GIT_CHECKOUT_SAFE` is between these two options, it will only make
|
|
Packit |
ae9e2a |
* modifications that will not lose changes.
|
|
Packit |
ae9e2a |
*
|
|
Packit |
ae9e2a |
* | target == baseline | target != baseline |
|
|
Packit |
ae9e2a |
* ---------------------|-----------------------|----------------------|
|
|
Packit |
ae9e2a |
* workdir == baseline | no action | create, update, or |
|
|
Packit |
ae9e2a |
* | | delete file |
|
|
Packit |
ae9e2a |
* ---------------------|-----------------------|----------------------|
|
|
Packit |
ae9e2a |
* workdir exists and | no action | conflict (notify |
|
|
Packit |
ae9e2a |
* is != baseline | notify dirty MODIFIED | and cancel checkout) |
|
|
Packit |
ae9e2a |
* ---------------------|-----------------------|----------------------|
|
|
Packit |
ae9e2a |
* workdir missing, | notify dirty DELETED | create file |
|
|
Packit |
ae9e2a |
* baseline present | | |
|
|
Packit |
ae9e2a |
* ---------------------|-----------------------|----------------------|
|
|
Packit |
ae9e2a |
*
|
|
Packit |
ae9e2a |
* To emulate `git checkout`, use `GIT_CHECKOUT_SAFE` with a checkout
|
|
Packit |
ae9e2a |
* notification callback (see below) that displays information about dirty
|
|
Packit |
ae9e2a |
* files. The default behavior will cancel checkout on conflicts.
|
|
Packit |
ae9e2a |
*
|
|
Packit |
ae9e2a |
* To emulate `git checkout-index`, use `GIT_CHECKOUT_SAFE` with a
|
|
Packit |
ae9e2a |
* notification callback that cancels the operation if a dirty-but-existing
|
|
Packit |
ae9e2a |
* file is found in the working directory. This core git command isn't
|
|
Packit |
ae9e2a |
* quite "force" but is sensitive about some types of changes.
|
|
Packit |
ae9e2a |
*
|
|
Packit |
ae9e2a |
* To emulate `git checkout -f`, use `GIT_CHECKOUT_FORCE`.
|
|
Packit |
ae9e2a |
*
|
|
Packit |
ae9e2a |
*
|
|
Packit |
ae9e2a |
* There are some additional flags to modified the behavior of checkout:
|
|
Packit |
ae9e2a |
*
|
|
Packit |
ae9e2a |
* - GIT_CHECKOUT_ALLOW_CONFLICTS makes SAFE mode apply safe file updates
|
|
Packit |
ae9e2a |
* even if there are conflicts (instead of cancelling the checkout).
|
|
Packit |
ae9e2a |
*
|
|
Packit |
ae9e2a |
* - GIT_CHECKOUT_REMOVE_UNTRACKED means remove untracked files (i.e. not
|
|
Packit |
ae9e2a |
* in target, baseline, or index, and not ignored) from the working dir.
|
|
Packit |
ae9e2a |
*
|
|
Packit |
ae9e2a |
* - GIT_CHECKOUT_REMOVE_IGNORED means remove ignored files (that are also
|
|
Packit |
ae9e2a |
* untracked) from the working directory as well.
|
|
Packit |
ae9e2a |
*
|
|
Packit |
ae9e2a |
* - GIT_CHECKOUT_UPDATE_ONLY means to only update the content of files that
|
|
Packit |
ae9e2a |
* already exist. Files will not be created nor deleted. This just skips
|
|
Packit |
ae9e2a |
* applying adds, deletes, and typechanges.
|
|
Packit |
ae9e2a |
*
|
|
Packit |
ae9e2a |
* - GIT_CHECKOUT_DONT_UPDATE_INDEX prevents checkout from writing the
|
|
Packit |
ae9e2a |
* updated files' information to the index.
|
|
Packit |
ae9e2a |
*
|
|
Packit |
ae9e2a |
* - Normally, checkout will reload the index and git attributes from disk
|
|
Packit |
ae9e2a |
* before any operations. GIT_CHECKOUT_NO_REFRESH prevents this reload.
|
|
Packit |
ae9e2a |
*
|
|
Packit |
ae9e2a |
* - Unmerged index entries are conflicts. GIT_CHECKOUT_SKIP_UNMERGED skips
|
|
Packit |
ae9e2a |
* files with unmerged index entries instead. GIT_CHECKOUT_USE_OURS and
|
|
Packit |
ae9e2a |
* GIT_CHECKOUT_USE_THEIRS to proceed with the checkout using either the
|
|
Packit |
ae9e2a |
* stage 2 ("ours") or stage 3 ("theirs") version of files in the index.
|
|
Packit |
ae9e2a |
*
|
|
Packit |
ae9e2a |
* - GIT_CHECKOUT_DONT_OVERWRITE_IGNORED prevents ignored files from being
|
|
Packit |
ae9e2a |
* overwritten. Normally, files that are ignored in the working directory
|
|
Packit |
ae9e2a |
* are not considered "precious" and may be overwritten if the checkout
|
|
Packit |
ae9e2a |
* target contains that file.
|
|
Packit |
ae9e2a |
*
|
|
Packit |
ae9e2a |
* - GIT_CHECKOUT_DONT_REMOVE_EXISTING prevents checkout from removing
|
|
Packit |
ae9e2a |
* files or folders that fold to the same name on case insensitive
|
|
Packit |
ae9e2a |
* filesystems. This can cause files to retain their existing names
|
|
Packit |
ae9e2a |
* and write through existing symbolic links.
|
|
Packit |
ae9e2a |
*/
|
|
Packit |
ae9e2a |
typedef enum {
|
|
Packit |
ae9e2a |
GIT_CHECKOUT_NONE = 0, /**< default is a dry run, no actual updates */
|
|
Packit |
ae9e2a |
|
|
Packit |
ae9e2a |
/** Allow safe updates that cannot overwrite uncommitted data */
|
|
Packit |
ae9e2a |
GIT_CHECKOUT_SAFE = (1u << 0),
|
|
Packit |
ae9e2a |
|
|
Packit |
ae9e2a |
/** Allow all updates to force working directory to look like index */
|
|
Packit |
ae9e2a |
GIT_CHECKOUT_FORCE = (1u << 1),
|
|
Packit |
ae9e2a |
|
|
Packit |
ae9e2a |
|
|
Packit |
ae9e2a |
/** Allow checkout to recreate missing files */
|
|
Packit |
ae9e2a |
GIT_CHECKOUT_RECREATE_MISSING = (1u << 2),
|
|
Packit |
ae9e2a |
|
|
Packit |
ae9e2a |
/** Allow checkout to make safe updates even if conflicts are found */
|
|
Packit |
ae9e2a |
GIT_CHECKOUT_ALLOW_CONFLICTS = (1u << 4),
|
|
Packit |
ae9e2a |
|
|
Packit |
ae9e2a |
/** Remove untracked files not in index (that are not ignored) */
|
|
Packit |
ae9e2a |
GIT_CHECKOUT_REMOVE_UNTRACKED = (1u << 5),
|
|
Packit |
ae9e2a |
|
|
Packit |
ae9e2a |
/** Remove ignored files not in index */
|
|
Packit |
ae9e2a |
GIT_CHECKOUT_REMOVE_IGNORED = (1u << 6),
|
|
Packit |
ae9e2a |
|
|
Packit |
ae9e2a |
/** Only update existing files, don't create new ones */
|
|
Packit |
ae9e2a |
GIT_CHECKOUT_UPDATE_ONLY = (1u << 7),
|
|
Packit |
ae9e2a |
|
|
Packit |
ae9e2a |
/**
|
|
Packit |
ae9e2a |
* Normally checkout updates index entries as it goes; this stops that.
|
|
Packit |
ae9e2a |
* Implies `GIT_CHECKOUT_DONT_WRITE_INDEX`.
|
|
Packit |
ae9e2a |
*/
|
|
Packit |
ae9e2a |
GIT_CHECKOUT_DONT_UPDATE_INDEX = (1u << 8),
|
|
Packit |
ae9e2a |
|
|
Packit |
ae9e2a |
/** Don't refresh index/config/etc before doing checkout */
|
|
Packit |
ae9e2a |
GIT_CHECKOUT_NO_REFRESH = (1u << 9),
|
|
Packit |
ae9e2a |
|
|
Packit |
ae9e2a |
/** Allow checkout to skip unmerged files */
|
|
Packit |
ae9e2a |
GIT_CHECKOUT_SKIP_UNMERGED = (1u << 10),
|
|
Packit |
ae9e2a |
/** For unmerged files, checkout stage 2 from index */
|
|
Packit |
ae9e2a |
GIT_CHECKOUT_USE_OURS = (1u << 11),
|
|
Packit |
ae9e2a |
/** For unmerged files, checkout stage 3 from index */
|
|
Packit |
ae9e2a |
GIT_CHECKOUT_USE_THEIRS = (1u << 12),
|
|
Packit |
ae9e2a |
|
|
Packit |
ae9e2a |
/** Treat pathspec as simple list of exact match file paths */
|
|
Packit |
ae9e2a |
GIT_CHECKOUT_DISABLE_PATHSPEC_MATCH = (1u << 13),
|
|
Packit |
ae9e2a |
|
|
Packit |
ae9e2a |
/** Ignore directories in use, they will be left empty */
|
|
Packit |
ae9e2a |
GIT_CHECKOUT_SKIP_LOCKED_DIRECTORIES = (1u << 18),
|
|
Packit |
ae9e2a |
|
|
Packit |
ae9e2a |
/** Don't overwrite ignored files that exist in the checkout target */
|
|
Packit |
ae9e2a |
GIT_CHECKOUT_DONT_OVERWRITE_IGNORED = (1u << 19),
|
|
Packit |
ae9e2a |
|
|
Packit |
ae9e2a |
/** Write normal merge files for conflicts */
|
|
Packit |
ae9e2a |
GIT_CHECKOUT_CONFLICT_STYLE_MERGE = (1u << 20),
|
|
Packit |
ae9e2a |
|
|
Packit |
ae9e2a |
/** Include common ancestor data in diff3 format files for conflicts */
|
|
Packit |
ae9e2a |
GIT_CHECKOUT_CONFLICT_STYLE_DIFF3 = (1u << 21),
|
|
Packit |
ae9e2a |
|
|
Packit |
ae9e2a |
/** Don't overwrite existing files or folders */
|
|
Packit |
ae9e2a |
GIT_CHECKOUT_DONT_REMOVE_EXISTING = (1u << 22),
|
|
Packit |
ae9e2a |
|
|
Packit |
ae9e2a |
/** Normally checkout writes the index upon completion; this prevents that. */
|
|
Packit |
ae9e2a |
GIT_CHECKOUT_DONT_WRITE_INDEX = (1u << 23),
|
|
Packit |
ae9e2a |
|
|
Packit |
ae9e2a |
/**
|
|
Packit |
ae9e2a |
* THE FOLLOWING OPTIONS ARE NOT YET IMPLEMENTED
|
|
Packit |
ae9e2a |
*/
|
|
Packit |
ae9e2a |
|
|
Packit |
ae9e2a |
/** Recursively checkout submodules with same options (NOT IMPLEMENTED) */
|
|
Packit |
ae9e2a |
GIT_CHECKOUT_UPDATE_SUBMODULES = (1u << 16),
|
|
Packit |
ae9e2a |
/** Recursively checkout submodules if HEAD moved in super repo (NOT IMPLEMENTED) */
|
|
Packit |
ae9e2a |
GIT_CHECKOUT_UPDATE_SUBMODULES_IF_CHANGED = (1u << 17),
|
|
Packit |
ae9e2a |
|
|
Packit |
ae9e2a |
} git_checkout_strategy_t;
|
|
Packit |
ae9e2a |
|
|
Packit |
ae9e2a |
/**
|
|
Packit |
ae9e2a |
* Checkout notification flags
|
|
Packit |
ae9e2a |
*
|
|
Packit |
ae9e2a |
* Checkout will invoke an options notification callback (`notify_cb`) for
|
|
Packit |
ae9e2a |
* certain cases - you pick which ones via `notify_flags`:
|
|
Packit |
ae9e2a |
*
|
|
Packit |
ae9e2a |
* - GIT_CHECKOUT_NOTIFY_CONFLICT invokes checkout on conflicting paths.
|
|
Packit |
ae9e2a |
*
|
|
Packit |
ae9e2a |
* - GIT_CHECKOUT_NOTIFY_DIRTY notifies about "dirty" files, i.e. those that
|
|
Packit |
ae9e2a |
* do not need an update but no longer match the baseline. Core git
|
|
Packit |
ae9e2a |
* displays these files when checkout runs, but won't stop the checkout.
|
|
Packit |
ae9e2a |
*
|
|
Packit |
ae9e2a |
* - GIT_CHECKOUT_NOTIFY_UPDATED sends notification for any file changed.
|
|
Packit |
ae9e2a |
*
|
|
Packit |
ae9e2a |
* - GIT_CHECKOUT_NOTIFY_UNTRACKED notifies about untracked files.
|
|
Packit |
ae9e2a |
*
|
|
Packit |
ae9e2a |
* - GIT_CHECKOUT_NOTIFY_IGNORED notifies about ignored files.
|
|
Packit |
ae9e2a |
*
|
|
Packit |
ae9e2a |
* Returning a non-zero value from this callback will cancel the checkout.
|
|
Packit |
ae9e2a |
* The non-zero return value will be propagated back and returned by the
|
|
Packit |
ae9e2a |
* git_checkout_... call.
|
|
Packit |
ae9e2a |
*
|
|
Packit |
ae9e2a |
* Notification callbacks are made prior to modifying any files on disk,
|
|
Packit |
ae9e2a |
* so canceling on any notification will still happen prior to any files
|
|
Packit |
ae9e2a |
* being modified.
|
|
Packit |
ae9e2a |
*/
|
|
Packit |
ae9e2a |
typedef enum {
|
|
Packit |
ae9e2a |
GIT_CHECKOUT_NOTIFY_NONE = 0,
|
|
Packit |
ae9e2a |
GIT_CHECKOUT_NOTIFY_CONFLICT = (1u << 0),
|
|
Packit |
ae9e2a |
GIT_CHECKOUT_NOTIFY_DIRTY = (1u << 1),
|
|
Packit |
ae9e2a |
GIT_CHECKOUT_NOTIFY_UPDATED = (1u << 2),
|
|
Packit |
ae9e2a |
GIT_CHECKOUT_NOTIFY_UNTRACKED = (1u << 3),
|
|
Packit |
ae9e2a |
GIT_CHECKOUT_NOTIFY_IGNORED = (1u << 4),
|
|
Packit |
ae9e2a |
|
|
Packit |
ae9e2a |
GIT_CHECKOUT_NOTIFY_ALL = 0x0FFFFu
|
|
Packit |
ae9e2a |
} git_checkout_notify_t;
|
|
Packit |
ae9e2a |
|
|
Packit |
ae9e2a |
typedef struct {
|
|
Packit |
ae9e2a |
size_t mkdir_calls;
|
|
Packit |
ae9e2a |
size_t stat_calls;
|
|
Packit |
ae9e2a |
size_t chmod_calls;
|
|
Packit |
ae9e2a |
} git_checkout_perfdata;
|
|
Packit |
ae9e2a |
|
|
Packit |
ae9e2a |
/** Checkout notification callback function */
|
|
Packit |
ae9e2a |
typedef int (*git_checkout_notify_cb)(
|
|
Packit |
ae9e2a |
git_checkout_notify_t why,
|
|
Packit |
ae9e2a |
const char *path,
|
|
Packit |
ae9e2a |
const git_diff_file *baseline,
|
|
Packit |
ae9e2a |
const git_diff_file *target,
|
|
Packit |
ae9e2a |
const git_diff_file *workdir,
|
|
Packit |
ae9e2a |
void *payload);
|
|
Packit |
ae9e2a |
|
|
Packit |
ae9e2a |
/** Checkout progress notification function */
|
|
Packit |
ae9e2a |
typedef void (*git_checkout_progress_cb)(
|
|
Packit |
ae9e2a |
const char *path,
|
|
Packit |
ae9e2a |
size_t completed_steps,
|
|
Packit |
ae9e2a |
size_t total_steps,
|
|
Packit |
ae9e2a |
void *payload);
|
|
Packit |
ae9e2a |
|
|
Packit |
ae9e2a |
/** Checkout perfdata notification function */
|
|
Packit |
ae9e2a |
typedef void (*git_checkout_perfdata_cb)(
|
|
Packit |
ae9e2a |
const git_checkout_perfdata *perfdata,
|
|
Packit |
ae9e2a |
void *payload);
|
|
Packit |
ae9e2a |
|
|
Packit |
ae9e2a |
/**
|
|
Packit |
ae9e2a |
* Checkout options structure
|
|
Packit |
ae9e2a |
*
|
|
Packit |
ae9e2a |
* Zero out for defaults. Initialize with `GIT_CHECKOUT_OPTIONS_INIT` macro to
|
|
Packit |
ae9e2a |
* correctly set the `version` field. E.g.
|
|
Packit |
ae9e2a |
*
|
|
Packit |
ae9e2a |
* git_checkout_options opts = GIT_CHECKOUT_OPTIONS_INIT;
|
|
Packit |
ae9e2a |
*/
|
|
Packit |
ae9e2a |
typedef struct git_checkout_options {
|
|
Packit |
ae9e2a |
unsigned int version;
|
|
Packit |
ae9e2a |
|
|
Packit |
ae9e2a |
unsigned int checkout_strategy; /**< default will be a dry run */
|
|
Packit |
ae9e2a |
|
|
Packit |
ae9e2a |
int disable_filters; /**< don't apply filters like CRLF conversion */
|
|
Packit |
ae9e2a |
unsigned int dir_mode; /**< default is 0755 */
|
|
Packit |
ae9e2a |
unsigned int file_mode; /**< default is 0644 or 0755 as dictated by blob */
|
|
Packit |
ae9e2a |
int file_open_flags; /**< default is O_CREAT | O_TRUNC | O_WRONLY */
|
|
Packit |
ae9e2a |
|
|
Packit |
ae9e2a |
unsigned int notify_flags; /**< see `git_checkout_notify_t` above */
|
|
Packit |
ae9e2a |
git_checkout_notify_cb notify_cb;
|
|
Packit |
ae9e2a |
void *notify_payload;
|
|
Packit |
ae9e2a |
|
|
Packit |
ae9e2a |
/** Optional callback to notify the consumer of checkout progress. */
|
|
Packit |
ae9e2a |
git_checkout_progress_cb progress_cb;
|
|
Packit |
ae9e2a |
void *progress_payload;
|
|
Packit |
ae9e2a |
|
|
Packit |
ae9e2a |
/** When not zeroed out, array of fnmatch patterns specifying which
|
|
Packit |
ae9e2a |
* paths should be taken into account, otherwise all files. Use
|
|
Packit |
ae9e2a |
* GIT_CHECKOUT_DISABLE_PATHSPEC_MATCH to treat as simple list.
|
|
Packit |
ae9e2a |
*/
|
|
Packit |
ae9e2a |
git_strarray paths;
|
|
Packit |
ae9e2a |
|
|
Packit |
ae9e2a |
/** The expected content of the working directory; defaults to HEAD.
|
|
Packit |
ae9e2a |
* If the working directory does not match this baseline information,
|
|
Packit |
ae9e2a |
* that will produce a checkout conflict.
|
|
Packit |
ae9e2a |
*/
|
|
Packit |
ae9e2a |
git_tree *baseline;
|
|
Packit |
ae9e2a |
|
|
Packit |
ae9e2a |
/** Like `baseline` above, though expressed as an index. This
|
|
Packit |
ae9e2a |
* option overrides `baseline`.
|
|
Packit |
ae9e2a |
*/
|
|
Packit |
ae9e2a |
git_index *baseline_index; /**< expected content of workdir, expressed as an index. */
|
|
Packit |
ae9e2a |
|
|
Packit |
ae9e2a |
const char *target_directory; /**< alternative checkout path to workdir */
|
|
Packit |
ae9e2a |
|
|
Packit |
ae9e2a |
const char *ancestor_label; /**< the name of the common ancestor side of conflicts */
|
|
Packit |
ae9e2a |
const char *our_label; /**< the name of the "our" side of conflicts */
|
|
Packit |
ae9e2a |
const char *their_label; /**< the name of the "their" side of conflicts */
|
|
Packit |
ae9e2a |
|
|
Packit |
ae9e2a |
/** Optional callback to notify the consumer of performance data. */
|
|
Packit |
ae9e2a |
git_checkout_perfdata_cb perfdata_cb;
|
|
Packit |
ae9e2a |
void *perfdata_payload;
|
|
Packit |
ae9e2a |
} git_checkout_options;
|
|
Packit |
ae9e2a |
|
|
Packit |
ae9e2a |
#define GIT_CHECKOUT_OPTIONS_VERSION 1
|
|
Packit |
ae9e2a |
#define GIT_CHECKOUT_OPTIONS_INIT {GIT_CHECKOUT_OPTIONS_VERSION}
|
|
Packit |
ae9e2a |
|
|
Packit |
ae9e2a |
/**
|
|
Packit |
ae9e2a |
* Initializes a `git_checkout_options` with default values. Equivalent to
|
|
Packit |
ae9e2a |
* creating an instance with GIT_CHECKOUT_OPTIONS_INIT.
|
|
Packit |
ae9e2a |
*
|
|
Packit |
ae9e2a |
* @param opts the `git_checkout_options` struct to initialize.
|
|
Packit |
ae9e2a |
* @param version Version of struct; pass `GIT_CHECKOUT_OPTIONS_VERSION`
|
|
Packit |
ae9e2a |
* @return Zero on success; -1 on failure.
|
|
Packit |
ae9e2a |
*/
|
|
Packit |
ae9e2a |
GIT_EXTERN(int) git_checkout_init_options(
|
|
Packit |
ae9e2a |
git_checkout_options *opts,
|
|
Packit |
ae9e2a |
unsigned int version);
|
|
Packit |
ae9e2a |
|
|
Packit |
ae9e2a |
/**
|
|
Packit |
ae9e2a |
* Updates files in the index and the working tree to match the content of
|
|
Packit |
ae9e2a |
* the commit pointed at by HEAD.
|
|
Packit |
ae9e2a |
*
|
|
Packit |
ae9e2a |
* Note that this is _not_ the correct mechanism used to switch branches;
|
|
Packit |
ae9e2a |
* do not change your `HEAD` and then call this method, that would leave
|
|
Packit |
ae9e2a |
* you with checkout conflicts since your working directory would then
|
|
Packit |
ae9e2a |
* appear to be dirty. Instead, checkout the target of the branch and
|
|
Packit |
ae9e2a |
* then update `HEAD` using `git_repository_set_head` to point to the
|
|
Packit |
ae9e2a |
* branch you checked out.
|
|
Packit |
ae9e2a |
*
|
|
Packit |
ae9e2a |
* @param repo repository to check out (must be non-bare)
|
|
Packit |
ae9e2a |
* @param opts specifies checkout options (may be NULL)
|
|
Packit |
ae9e2a |
* @return 0 on success, GIT_EUNBORNBRANCH if HEAD points to a non
|
|
Packit |
ae9e2a |
* existing branch, non-zero value returned by `notify_cb`, or
|
|
Packit |
ae9e2a |
* other error code < 0 (use giterr_last for error details)
|
|
Packit |
ae9e2a |
*/
|
|
Packit |
ae9e2a |
GIT_EXTERN(int) git_checkout_head(
|
|
Packit |
ae9e2a |
git_repository *repo,
|
|
Packit |
ae9e2a |
const git_checkout_options *opts);
|
|
Packit |
ae9e2a |
|
|
Packit |
ae9e2a |
/**
|
|
Packit |
ae9e2a |
* Updates files in the working tree to match the content of the index.
|
|
Packit |
ae9e2a |
*
|
|
Packit |
ae9e2a |
* @param repo repository into which to check out (must be non-bare)
|
|
Packit |
ae9e2a |
* @param index index to be checked out (or NULL to use repository index)
|
|
Packit |
ae9e2a |
* @param opts specifies checkout options (may be NULL)
|
|
Packit |
ae9e2a |
* @return 0 on success, non-zero return value from `notify_cb`, or error
|
|
Packit |
ae9e2a |
* code < 0 (use giterr_last for error details)
|
|
Packit |
ae9e2a |
*/
|
|
Packit |
ae9e2a |
GIT_EXTERN(int) git_checkout_index(
|
|
Packit |
ae9e2a |
git_repository *repo,
|
|
Packit |
ae9e2a |
git_index *index,
|
|
Packit |
ae9e2a |
const git_checkout_options *opts);
|
|
Packit |
ae9e2a |
|
|
Packit |
ae9e2a |
/**
|
|
Packit |
ae9e2a |
* Updates files in the index and working tree to match the content of the
|
|
Packit |
ae9e2a |
* tree pointed at by the treeish.
|
|
Packit |
ae9e2a |
*
|
|
Packit |
ae9e2a |
* @param repo repository to check out (must be non-bare)
|
|
Packit |
ae9e2a |
* @param treeish a commit, tag or tree which content will be used to update
|
|
Packit |
ae9e2a |
* the working directory (or NULL to use HEAD)
|
|
Packit |
ae9e2a |
* @param opts specifies checkout options (may be NULL)
|
|
Packit |
ae9e2a |
* @return 0 on success, non-zero return value from `notify_cb`, or error
|
|
Packit |
ae9e2a |
* code < 0 (use giterr_last for error details)
|
|
Packit |
ae9e2a |
*/
|
|
Packit |
ae9e2a |
GIT_EXTERN(int) git_checkout_tree(
|
|
Packit |
ae9e2a |
git_repository *repo,
|
|
Packit |
ae9e2a |
const git_object *treeish,
|
|
Packit |
ae9e2a |
const git_checkout_options *opts);
|
|
Packit |
ae9e2a |
|
|
Packit |
ae9e2a |
/** @} */
|
|
Packit |
ae9e2a |
GIT_END_DECL
|
|
Packit |
ae9e2a |
#endif
|