LibGit2
The LibGit2 module provides bindings to libgit2, a portable C library that implements core functionality for the Git version control system. These bindings are currently used to power Julia’s package manager. It is expected that this module will eventually be moved into a separate package.
Functionality
Some of this documentation assumes some prior knowledge of the libgit2 API. For more information on some of the objects and methods referenced here, consult the upstream libgit2 API reference.
LibGit2.Buffer
A data buffer for exporting data from libgit2. Matches the git_buf
struct.
When fetching data from LibGit2, a typical usage would look like:
buf_ref = Ref(Buffer())
@check ccall(..., (Ptr{Buffer},), buf_ref)
# operation on buf_ref
free(buf_ref)
In particular, note that LibGit2.free
should be called afterward on the Ref
object.
LibGit2.CheckoutOptions
Matches the git_checkout_options
struct.
The fields represent:
version
: version of the struct in use, in case this changes later. For now, always1
.checkout_strategy
: determine how to handle conflicts and whether to force the checkout/recreate missing files.disable_filters
: if nonzero, do not apply filters like CLRF (to convert file newlines between UNIX and DOS).dir_mode
: read/write/access mode for any directories involved in the checkout. Default is0755
.file_mode
: read/write/access mode for any files involved in the checkout. Default is0755
or0644
, depending on the blob.file_open_flags
: bitflags used to open any files during the checkout.notify_flags
: Flags for what sort of conflicts the user should be notified about.notify_cb
: An optional callback function to notify the user if a checkout conflict occurs. If this function returns a non-zero value, the checkout will be cancelled.notify_payload
: Payload for the notify callback function.progress_cb
: An optional callback function to display checkout progress.progress_payload
: Payload for the progress callback.paths
: If not empty, describes which paths to search during the checkout. If empty, the checkout will occur over all files in the repository.baseline
: Expected content of theworkdir
, captured in a (pointer to a)GitTree
. Defaults to the state of the tree at HEAD.baseline_index
: Expected content of theworkdir
, captured in a (pointer to a)GitIndex
. Defaults to the state of the index at HEAD.target_directory
: If not empty, checkout to this directory instead of theworkdir
.ancestor_label
: In case of conflicts, the name of the common ancestor side.our_label
: In case of conflicts, the name of “our” side.their_label
: In case of conflicts, the name of “their” side.perfdata_cb
: An optional callback function to display performance data.perfdata_payload
: Payload for the performance callback.
LibGit2.CloneOptions
Matches the git_clone_options
struct.
The fields represent:
version
: version of the struct in use, in case this changes later. For now, always1
.checkout_opts
: The options for performing the checkout of the remote as part of the clone.fetch_opts
: The options for performing the pre-checkout fetch of the remote as part of the clone.bare
: If0
, clone the full remote repository. If non-zero, perform a bare clone, in which there is no local copy of the source files in the repository and thegitdir
andworkdir
are the same.localclone
: Flag whether to clone a local object database or do a fetch. The default is to let git decide. It will not use the git-aware transport for a local clone, but will use it for URLs which begin withfile://
.checkout_branch
: The name of the branch to checkout. If an empty string, the default branch of the remote will be checked out.repository_cb
: An optional callback which will be used to create the new repository into which the clone is made.repository_cb_payload
: The payload for the repository callback.remote_cb
: An optional callback used to create theGitRemote
before making the clone from it.remote_cb_payload
: The payload for the remote callback.
LibGit2.DescribeOptions
Matches the git_describe_options
struct.
The fields represent:
version
: version of the struct in use, in case this changes later. For now, always1
.max_candidates_tags
: consider this many most recent tags inrefs/tags
to describe a commit. Defaults to 10 (so that the 10 most recent tags would be examined to see if they describe a commit).describe_strategy
: whether to consider all entries inrefs/tags
(equivalent togit-describe --tags
) or all entries inrefs/
(equivalent togit-describe --all
). The default is to only show annotated tags. IfConsts.DESCRIBE_TAGS
is passed, all tags, annotated or not, will be considered. IfConsts.DESCRIBE_ALL
is passed, any ref inrefs/
will be considered.pattern
: only consider tags which matchpattern
. Supports glob expansion.only_follow_first_parent
: when finding the distance from a matching reference to the described object, only consider the distance from the first parent.show_commit_oid_as_fallback
: if no matching reference can be found which describes a commit, show the commit’sGitHash
instead of throwing an error (the default behavior).
LibGit2.DescribeFormatOptions
Matches the git_describe_format_options
struct.
The fields represent:
version
: version of the struct in use, in case this changes later. For now, always1
.abbreviated_size
: lower bound on the size of the abbreviatedGitHash
to use, defaulting to7
.always_use_long_format
: set to1
to use the long format for strings even if a short format can be used.dirty_suffix
: if set, this will be appended to the end of the description string if theworkdir
is dirty.
LibGit2.DiffDelta
Description of changes to one entry. Matches the git_diff_delta
struct.
The fields represent:
status
: One ofConsts.DELTA_STATUS
, indicating whether the file has been added/modified/deleted.flags
: Flags for the delta and the objects on each side. Determines whether to treat the file(s) as binary/text, whether they exist on each side of the diff, and whether the object ids are known to be correct.similarity
: Used to indicate if a file has been renamed or copied.nfiles
: The number of files in the delta (for instance, if the delta was run on a submodule commit id, it may contain more than one file).old_file
: ADiffFile
containing information about the file(s) before the changes.new_file
: ADiffFile
containing information about the file(s) after the changes.
LibGit2.DiffFile
Description of one side of a delta. Matches the git_diff_file
struct.
The fields represent:
id
: theGitHash
of the item in the diff. If the item is empty on this side of the diff (for instance, if the diff is of the removal of a file), this will beGitHash(0)
.path
: aNULL
terminated path to the item relative to the working directory of the repository.size
: the size of the item in bytes.flags
: a combination of thegit_diff_flag_t
flags. Thei
th bit of this integer sets thei
th flag.mode
: thestat
mode for the item.id_abbrev
: only present in LibGit2 versions newer than or equal to0.25.0
. The length of theid
field when converted usingstring
. Usually equal toOID_HEXSZ
(40).
LibGit2.DiffOptionsStruct
Matches the git_diff_options
struct.
The fields represent:
version
: version of the struct in use, in case this changes later. For now, always1
.flags
: flags controlling which files will appear in the diff. Defaults toDIFF_NORMAL
.ignore_submodules
: whether to look at files in submodules or not. Defaults toSUBMODULE_IGNORE_UNSPECIFIED
, which means the submodule’s configuration will control whether it appears in the diff or not.pathspec
: path to files to include in the diff. Default is to use all files in the repository.notify_cb
: optional callback which will notify the user of changes to the diff as file deltas are added to it.progress_cb
: optional callback which will display diff progress. Only relevant on libgit2 versions at least as new as 0.24.0.payload
: the payload to pass tonotify_cb
andprogress_cb
.context_lines
: the number of unchanged lines used to define the edges of a hunk. This is also the number of lines which will be shown before/after a hunk to provide context. Default is 3.interhunk_lines
: the maximum number of unchanged lines between two separate hunks allowed before the hunks will be combined. Default is 0.id_abbrev
: sets the length of the abbreviatedGitHash
to print. Default is7
.max_size
: the maximum file size of a blob. Above this size, it will be treated as a binary blob. The default is 512 MB.old_prefix
: the virtual file directory in which to place old files on one side of the diff. Default is"a"
.new_prefix
: the virtual file directory in which to place new files on one side of the diff. Default is"b"
.
LibGit2.FetchHead
Contains the information about HEAD during a fetch, including the name and URL of the branch fetched from, the oid of the HEAD, and whether the fetched HEAD has been merged locally.
The fields represent:
name
: The name in the local reference database of the fetch head, for example,"refs/heads/master"
.url
: The URL of the fetch head.oid
: TheGitHash
of the tip of the fetch head.ismerge
: Boolean flag indicating whether the changes at the remote have been merged into the local copy yet or not. Iftrue
, the local copy is up to date with the remote fetch head.
LibGit2.FetchOptions
Matches the git_fetch_options
struct.
The fields represent:
version
: version of the struct in use, in case this changes later. For now, always1
.callbacks
: remote callbacks to use during the fetch.prune
: whether to perform a prune after the fetch or not. The default is to use the setting from theGitConfig
.update_fetchhead
: whether to update theFetchHead
after the fetch. The default is to perform the update, which is the normal git behavior.download_tags
: whether to download tags present at the remote or not. The default is to request the tags for objects which are being downloaded anyway from the server.proxy_opts
: options for connecting to the remote through a proxy. SeeProxyOptions
. Only present on libgit2 versions newer than or equal to 0.25.0.custom_headers
: any extra headers needed for the fetch. Only present on libgit2 versions newer than or equal to 0.24.0.
GitAnnotated(repo::GitRepo, commit_id::GitHash)
GitAnnotated(repo::GitRepo, ref::GitReference)
GitAnnotated(repo::GitRepo, fh::FetchHead)
GitAnnotated(repo::GitRepo, comittish::AbstractString)
An annotated git commit carries with it information about how it was looked up and why, so that rebase or merge operations have more information about the context of the commit. Conflict files contain information about the source/target branches in the merge which are conflicting, for instance. An annotated commit can refer to the tip of a remote branch, for instance when a FetchHead
is passed, or to a branch head described using GitReference
.
GitBlame(repo::GitRepo, path::AbstractString; options::BlameOptions=BlameOptions())
Construct a GitBlame
object for the file at path
, using change information gleaned from the history of repo
. The GitBlame
object records who changed which chunks of the file when, and how. options
controls how to separate the contents of the file and which commits to probe - see BlameOptions
for more information.
GitBlob(repo::GitRepo, hash::AbstractGitHash)
GitBlob(repo::GitRepo, spec::AbstractString)
Return a GitBlob
object from repo
specified by hash
/spec
.
hash
is a full (GitHash
) or partial (GitShortHash
) hash.spec
is a textual specification: see the git docs for a full list.
GitCommit(repo::GitRepo, hash::AbstractGitHash)
GitCommit(repo::GitRepo, spec::AbstractString)
Return a GitCommit
object from repo
specified by hash
/spec
.
hash
is a full (GitHash
) or partial (GitShortHash
) hash.spec
is a textual specification: see the git docs for a full list.
GitHash
A git object identifier, based on the sha-1 hash. It is a 20 byte string (40 hex digits) used to identify a GitObject
in a repository.
GitObject(repo::GitRepo, hash::AbstractGitHash)
GitObject(repo::GitRepo, spec::AbstractString)
Return the specified object (GitCommit
, GitBlob
, GitTree
or GitTag
) from repo
specified by hash
/spec
.
hash
is a full (GitHash
) or partial (GitShortHash
) hash.spec
is a textual specification: see the git docs for a full list.
GitRemote(repo::GitRepo, rmt_name::AbstractString, rmt_url::AbstractString) -> GitRemote
Look up a remote git repository using its name and URL. Uses the default fetch refspec.
Examples
repo = LibGit2.init(repo_path)
remote = LibGit2.GitRemote(repo, "upstream", repo_url)
GitRemote(repo::GitRepo, rmt_name::AbstractString, rmt_url::AbstractString, fetch_spec::AbstractString) -> GitRemote
Look up a remote git repository using the repository’s name and URL, as well as specifications for how to fetch from the remote (e.g. which remote branch to fetch from).
Examples
repo = LibGit2.init(repo_path)
refspec = "+refs/heads/mybranch:refs/remotes/origin/mybranch"
remote = LibGit2.GitRemote(repo, "upstream", repo_url, refspec)
GitRemoteAnon(repo::GitRepo, url::AbstractString) -> GitRemote
Look up a remote git repository using only its URL, not its name.
Examples
repo = LibGit2.init(repo_path)
remote = LibGit2.GitRemoteAnon(repo, repo_url)
LibGit2.GitRepo(path::AbstractString)
Open a git repository at path
.
LibGit2.GitRepoExt(path::AbstractString, flags::Cuint = Cuint(Consts.REPOSITORY_OPEN_DEFAULT))
Open a git repository at path
with extended controls (for instance, if the current user must be a member of a special access group to read path
).
GitRevWalker(repo::GitRepo)
A GitRevWalker
walks through the revisions (i.e. commits) of a git repository repo
. It is a collection of the commits in the repository, and supports iteration and calls to map
and count
(for instance, count
could be used to determine what percentage of commits in a repository were made by a certain author).
cnt = LibGit2.with(LibGit2.GitRevWalker(repo)) do walker
count((oid,repo)->(oid == commit_oid1), walker, oid=commit_oid1, by=LibGit2.Consts.SORT_TIME)
end
Here, count
finds the number of commits along the walk with a certain GitHash
. Since the GitHash
is unique to a commit, cnt
will be 1
.
GitShortHash(hash::GitHash, len::Integer)
A shortened git object identifier, which can be used to identify a git object when it is unique, consisting of the initial len
hexadecimal digits of hash
(the remaining digits are ignored).
LibGit2.GitSignature
This is a Julia wrapper around a pointer to a git_signature
object.
LibGit2.GitStatus(repo::GitRepo; status_opts=StatusOptions())
Collect information about the status of each file in the git repository repo
(e.g. is the file modified, staged, etc.). status_opts
can be used to set various options, for instance whether or not to look at untracked files or whether to include submodules or not. See StatusOptions
for more information.
GitTag(repo::GitRepo, hash::AbstractGitHash)
GitTag(repo::GitRepo, spec::AbstractString)
Return a GitTag
object from repo
specified by hash
/spec
.
hash
is a full (GitHash
) or partial (GitShortHash
) hash.spec
is a textual specification: see the git docs for a full list.
GitTree(repo::GitRepo, hash::AbstractGitHash)
GitTree(repo::GitRepo, spec::AbstractString)
Return a GitTree
object from repo
specified by hash
/spec
.
hash
is a full (GitHash
) or partial (GitShortHash
) hash.spec
is a textual specification: see the git docs for a full list.
LibGit2.IndexEntry
In-memory representation of a file entry in the index. Matches the git_index_entry
struct.
LibGit2.IndexTime
Matches the git_index_time
struct.
LibGit2.BlameOptions
Matches the git_blame_options
struct.
The fields represent:
version
: version of the struct in use, in case this changes later. For now, always1
.flags
: one ofConsts.BLAME_NORMAL
orConsts.BLAME_FIRST_PARENT
(the other blame flags are not yet implemented by libgit2).min_match_characters
: the minimum number of alphanumeric characters which much change in a commit in order for the change to be associated with that commit. The default is 20. Only takes effect if one of theConsts.BLAME_*_COPIES
flags are used, which libgit2 does not implement yet.newest_commit
: theGitHash
of the newest commit from which to look at changes.oldest_commit
: theGitHash
of the oldest commit from which to look at changes.min_line
: the first line of the file from which to starting blaming. The default is1
.max_line
: the last line of the file to which to blame. The default is0
, meaning the last line of the file.
LibGit2.MergeOptions
Matches the git_merge_options
struct.
The fields represent:
version
: version of the struct in use, in case this changes later. For now, always1
.flags
: anenum
for flags describing merge behavior. Defined ingit_merge_flag_t
. The corresponding Julia enum isGIT_MERGE
and has values:MERGE_FIND_RENAMES
: detect if a file has been renamed between the common ancestor and the “ours” or “theirs” side of the merge. Allows merges where a file has been renamed.MERGE_FAIL_ON_CONFLICT
: exit immediately if a conflict is found rather than trying to resolve it.MERGE_SKIP_REUC
: do not write the REUC extension on the index resulting from the merge.MERGE_NO_RECURSIVE
: if the commits being merged have multiple merge bases, use the first one, rather than trying to recursively merge the bases.
rename_threshold
: how similar two files must to consider one a rename of the other. This is an integer that sets the percentage similarity. The default is 50.target_limit
: the maximum number of files to compare with to look for renames. The default is 200.metric
: optional custom function to use to determine the similarity between two files for rename detection.recursion_limit
: the upper limit on the number of merges of common ancestors to perform to try to build a new virtual merge base for the merge. The default is no limit. This field is only present on libgit2 versions newer than 0.24.0.default_driver
: the merge driver to use if both sides have changed. This field is only present on libgit2 versions newer than 0.25.0.file_favor
: how to handle conflicting file contents for thetext
driver.MERGE_FILE_FAVOR_NORMAL
: if both sides of the merge have changes to a section, make a note of the conflict in the index whichgit checkout
will use to create a merge file, which the user can then reference to resolve the conflicts. This is the default.MERGE_FILE_FAVOR_OURS
: if both sides of the merge have changes to a section, use the version in the “ours” side of the merge in the index.MERGE_FILE_FAVOR_THEIRS
: if both sides of the merge have changes to a section, use the version in the “theirs” side of the merge in the index.MERGE_FILE_FAVOR_UNION
: if both sides of the merge have changes to a section, include each unique line from both sides in the file which is put into the index.
file_flags
: guidelines for merging files.
LibGit2.ProxyOptions
Options for connecting through a proxy.
Matches the git_proxy_options
struct.
The fields represent:
version
: version of the struct in use, in case this changes later. For now, always1
.proxytype
: anenum
for the type of proxy to use. Defined ingit_proxy_t
. The corresponding Julia enum isGIT_PROXY
and has values:PROXY_NONE
: do not attempt the connection through a proxy.PROXY_AUTO
: attempt to figure out the proxy configuration from the git configuration.PROXY_SPECIFIED
: connect using the URL given in theurl
field of this struct.Default is to auto-detect the proxy type.
url
: the URL of the proxy.credential_cb
: a pointer to a callback function which will be called if the remote requires authentication to connect.certificate_cb
: a pointer to a callback function which will be called if certificate verification fails. This lets the user decide whether or not to keep connecting. If the function returns1
, connecting will be allowed. If it returns0
, the connection will not be allowed. A negative value can be used to return errors.payload
: the payload to be provided to the two callback functions.
Examples
julia> fo = LibGit2.FetchOptions(
proxy_opts = LibGit2.ProxyOptions(url = Cstring("https://my_proxy_url.com")))
julia> fetch(remote, "master", options=fo)
LibGit2.PushOptions
Matches the git_push_options
struct.
The fields represent:
version
: version of the struct in use, in case this changes later. For now, always1
.parallelism
: if a pack file must be created, this variable sets the number of worker threads which will be spawned by the packbuilder. If0
, the packbuilder will auto-set the number of threads to use. The default is1
.callbacks
: the callbacks (e.g. for authentication with the remote) to use for the push.proxy_opts
: only relevant if the LibGit2 version is greater than or equal to0.25.0
. Sets options for using a proxy to communicate with a remote. SeeProxyOptions
for more information.custom_headers
: only relevant if the LibGit2 version is greater than or equal to0.24.0
. Extra headers needed for the push operation.
LibGit2.RebaseOperation
Describes a single instruction/operation to be performed during the rebase. Matches the git_rebase_operation
struct.
The fields represent:
optype
: the type of rebase operation currently being performed. The options are:REBASE_OPERATION_PICK
: cherry-pick the commit in question.REBASE_OPERATION_REWORD
: cherry-pick the commit in question, but rewrite its message using the prompt.REBASE_OPERATION_EDIT
: cherry-pick the commit in question, but allow the user to edit the commit’s contents and its message.REBASE_OPERATION_SQUASH
: squash the commit in question into the previous commit. The commit messages of the two commits will be merged.REBASE_OPERATION_FIXUP
: squash the commit in question into the previous commit. Only the commit message of the previous commit will be used.REBASE_OPERATION_EXEC
: do not cherry-pick a commit. Run a command and continue if the command exits successfully.
id
: theGitHash
of the commit being worked on during this rebase step.exec
: in caseREBASE_OPERATION_EXEC
is used, the command to run during this step (for instance, running the test suite after each commit).
LibGit2.RebaseOptions
Matches the git_rebase_options
struct.
The fields represent:
version
: version of the struct in use, in case this changes later. For now, always1
.quiet
: inform other git clients helping with/working on the rebase that the rebase should be done “quietly”. Used for interoperability. The default is1
.inmemory
: start an in-memory rebase. Callers working on the rebase can go through its steps and commit any changes, but cannot rewind HEAD or update the repository. Theworkdir
will not be modified. Only present on libgit2 versions newer than or equal to 0.24.0.rewrite_notes_ref
: name of the reference to notes to use to rewrite the commit notes as the rebase is finished.merge_opts
: merge options controlling how the trees will be merged at each rebase step. Only present on libgit2 versions newer than or equal to 0.24.0.checkout_opts
: checkout options for writing files when initializing the rebase, stepping through it, and aborting it. SeeCheckoutOptions
for more information.
LibGit2.RemoteCallbacks
Callback settings. Matches the git_remote_callbacks
struct.
LibGit2.SignatureStruct
An action signature (e.g. for committers, taggers, etc). Matches the git_signature
struct.
The fields represent:
name
: The full name of the committer or author of the commit.email
: The email at which the committer/author can be contacted.when
: aTimeStruct
indicating when the commit was authored/committed into the repository.
LibGit2.StatusEntry
Providing the differences between the file as it exists in HEAD and the index, and providing the differences between the index and the working directory. Matches the git_status_entry
struct.
The fields represent:
status
: contains the status flags for the file, indicating if it is current, or has been changed in some way in the index or work tree.head_to_index
: a pointer to aDiffDelta
which encapsulates the difference(s) between the file as it exists in HEAD and in the index.index_to_workdir
: a pointer to aDiffDelta
which encapsulates the difference(s) between the file as it exists in the index and in theworkdir
.
LibGit2.StatusOptions
Options to control how git_status_foreach_ext()
will issue callbacks. Matches the git_status_opt_t
struct.
The fields represent:
version
: version of the struct in use, in case this changes later. For now, always1
.show
: a flag for which files to examine and in which order. The default isConsts.STATUS_SHOW_INDEX_AND_WORKDIR
.flags
: flags for controlling any callbacks used in a status call.pathspec
: an array of paths to use for path-matching. The behavior of the path-matching will vary depending on the values ofshow
andflags
.- The
baseline
is the tree to be used for comparison to the working directory and index; defaults to HEAD.
LibGit2.StrArrayStruct
A LibGit2 representation of an array of strings. Matches the git_strarray
struct.
When fetching data from LibGit2, a typical usage would look like:
sa_ref = Ref(StrArrayStruct())
@check ccall(..., (Ptr{StrArrayStruct},), sa_ref)
res = convert(Vector{String}, sa_ref[])
free(sa_ref)
In particular, note that LibGit2.free
should be called afterward on the Ref
object.
Conversely, when passing a vector of strings to LibGit2, it is generally simplest to rely on implicit conversion:
strs = String[...]
@check ccall(..., (Ptr{StrArrayStruct},), strs)
Note that no call to free
is required as the data is allocated by Julia.
LibGit2.TimeStruct
Time in a signature. Matches the git_time
struct.
add!(repo::GitRepo, files::AbstractString...; flags::Cuint = Consts.INDEX_ADD_DEFAULT)
add!(idx::GitIndex, files::AbstractString...; flags::Cuint = Consts.INDEX_ADD_DEFAULT)
Add all the files with paths specified by files
to the index idx
(or the index of the repo
). If the file already exists, the index entry will be updated. If the file does not exist already, it will be newly added into the index. files
may contain glob patterns which will be expanded and any matching files will be added (unless INDEX_ADD_DISABLE_PATHSPEC_MATCH
is set, see below). If a file has been ignored (in .gitignore
or in the config), it will not be added, unless it is already being tracked in the index, in which case it will be updated. The keyword argument flags
is a set of bit-flags which control the behavior with respect to ignored files:
Consts.INDEX_ADD_DEFAULT
- default, described above.Consts.INDEX_ADD_FORCE
- disregard the existing ignore rules and force addition of the file to the index even if it is already ignored.Consts.INDEX_ADD_CHECK_PATHSPEC
- cannot be used at the same time asINDEX_ADD_FORCE
. Check that each file infiles
which exists on disk is not in the ignore list. If one of the files is ignored, the function will returnEINVALIDSPEC
.Consts.INDEX_ADD_DISABLE_PATHSPEC_MATCH
- turn off glob matching, and only add files to the index which exactly match the paths specified infiles
.
add_fetch!(repo::GitRepo, rmt::GitRemote, fetch_spec::String)
Add a fetch refspec for the specified rmt
. This refspec will contain information about which branch(es) to fetch from.
Examples
julia> LibGit2.add_fetch!(repo, remote, "upstream");
julia> LibGit2.fetch_refspecs(remote)
String["+refs/heads/*:refs/remotes/upstream/*"]
add_push!(repo::GitRepo, rmt::GitRemote, push_spec::String)
Add a push refspec for the specified rmt
. This refspec will contain information about which branch(es) to push to.
Examples
julia> LibGit2.add_push!(repo, remote, "refs/heads/master");
julia> remote = LibGit2.get(LibGit2.GitRemote, repo, branch);
julia> LibGit2.push_refspecs(remote)
String["refs/heads/master"]
You may need to close
and reopen the GitRemote
in question after updating its push refspecs in order for the change to take effect and for calls to push
to work.
LibGit2.addblob!(repo::GitRepo, path::AbstractString)
Read the file at path
and adds it to the object database of repo
as a loose blob. Return the GitHash
of the resulting blob.
Examples
hash_str = string(commit_oid)
blob_file = joinpath(repo_path, ".git", "objects", hash_str[1:2], hash_str[3:end])
id = LibGit2.addblob!(repo, blob_file)
author(c::GitCommit)
Return the Signature
of the author of the commit c
. The author is the person who made changes to the relevant file(s). See also committer
.
authors(repo::GitRepo) -> Vector{Signature}
Return all authors of commits to the repo
repository.
Examples
repo = LibGit2.GitRepo(repo_path)
repo_file = open(joinpath(repo_path, test_file), "a")
println(repo_file, commit_msg)
flush(repo_file)
LibGit2.add!(repo, test_file)
sig = LibGit2.Signature("TEST", "TEST@TEST.COM", round(time(), 0), 0)
commit_oid1 = LibGit2.commit(repo, "commit1"; author=sig, committer=sig)
println(repo_file, randstring(10))
flush(repo_file)
LibGit2.add!(repo, test_file)
commit_oid2 = LibGit2.commit(repo, "commit2"; author=sig, committer=sig)
# will be a Vector of [sig, sig]
auths = LibGit2.authors(repo)
branch(repo::GitRepo)
Equivalent to git branch
. Create a new branch from the current HEAD.
branch!(repo::GitRepo, branch_name::AbstractString, commit::AbstractString=""; kwargs...)
Checkout a new git branch in the repo
repository. commit
is the GitHash
, in string form, which will be the start of the new branch. If commit
is an empty string, the current HEAD will be used.
The keyword arguments are:
track::AbstractString=""
: the name of the remote branch this new branch should track, if any. If empty (the default), no remote branch will be tracked.force::Bool=false
: iftrue
, branch creation will be forced.set_head::Bool=true
: iftrue
, after the branch creation finishes the branch head will be set as the HEAD ofrepo
.
Equivalent to git checkout [-b|-B] <branch_name> [<commit>] [--track <track>]
.
Examples
repo = LibGit2.GitRepo(repo_path)
LibGit2.branch!(repo, "new_branch", set_head=false)
checkout!(repo::GitRepo, commit::AbstractString=""; force::Bool=true)
Equivalent to git checkout [-f] --detach <commit>
. Checkout the git commit commit
(a GitHash
in string form) in repo
. If force
is true
, force the checkout and discard any current changes. Note that this detaches the current HEAD.
Examples
repo = LibGit2.init(repo_path)
open(joinpath(LibGit2.path(repo), "file1"), "w") do f
write(f, "111
")
end
LibGit2.add!(repo, "file1")
commit_oid = LibGit2.commit(repo, "add file1")
open(joinpath(LibGit2.path(repo), "file1"), "w") do f
write(f, "112
")
end
# would fail without the force=true
# since there are modifications to the file
LibGit2.checkout!(repo, string(commit_oid), force=true)
clone(repo_url::AbstractString, repo_path::AbstractString, clone_opts::CloneOptions)
Clone the remote repository at repo_url
(which can be a remote URL or a path on the local filesystem) to repo_path
(which must be a path on the local filesystem). Options for the clone, such as whether to perform a bare clone or not, are set by CloneOptions
.
Examples
repo_url = "https://github.com/JuliaLang/Example.jl"
repo = LibGit2.clone(repo_url, "/home/me/projects/Example")
clone(repo_url::AbstractString, repo_path::AbstractString; kwargs...)
Clone a remote repository located at repo_url
to the local filesystem location repo_path
.
The keyword arguments are:
branch::AbstractString=""
: which branch of the remote to clone, if not the default repository branch (usuallymaster
).isbare::Bool=false
: iftrue
, clone the remote as a bare repository, which will makerepo_path
itself the git directory instead ofrepo_path/.git
. This means that a working tree cannot be checked out. Plays the role of the git CLI argument--bare
.remote_cb::Ptr{Cvoid}=C_NULL
: a callback which will be used to create the remote before it is cloned. IfC_NULL
(the default), no attempt will be made to create the remote - it will be assumed to already exist.credentials::Creds=nothing
: provides credentials and/or settings when authenticating against a private repository.callbacks::Callbacks=Callbacks()
: user provided callbacks and payloads.
Equivalent to git clone [-b <branch>] [--bare] <repo_url> <repo_path>
.
Examples
repo_url = "https://github.com/JuliaLang/Example.jl"
repo1 = LibGit2.clone(repo_url, "test_path")
repo2 = LibGit2.clone(repo_url, "test_path", isbare=true)
julia_url = "https://github.com/JuliaLang/julia"
julia_repo = LibGit2.clone(julia_url, "julia_path", branch="release-0.6")
commit(repo::GitRepo, msg::AbstractString; kwargs...) -> GitHash
Wrapper around git_commit_create
. Create a commit in the repository repo
. msg
is the commit message. Return the OID of the new commit.
The keyword arguments are:
refname::AbstractString=Consts.HEAD_FILE
: if not NULL, the name of the reference to update to point to the new commit. For example,"HEAD"
will update the HEAD of the current branch. If the reference does not yet exist, it will be created.author::Signature = Signature(repo)
is aSignature
containing information about the person who authored the commit.committer::Signature = Signature(repo)
is aSignature
containing information about the person who committed the commit to the repository. Not necessarily the same asauthor
, for instance ifauthor
emailed a patch tocommitter
who committed it.tree_id::GitHash = GitHash()
is a git tree to use to create the commit, showing its ancestry and relationship with any other history.tree
must belong torepo
.parent_ids::Vector{GitHash}=GitHash[]
is a list of commits byGitHash
to use as parent commits for the new one, and may be empty. A commit might have multiple parents if it is a merge commit, for example.
LibGit2.commit(rb::GitRebase, sig::GitSignature)
Commit the current patch to the rebase rb
, using sig
as the committer. Is silent if the commit has already been applied.
committer(c::GitCommit)
Return the Signature
of the committer of the commit c
. The committer is the person who committed the changes originally authored by the author
, but need not be the same as the author
, for example, if the author
emailed a patch to a committer
who committed it.
LibGit2.count(f::Function, walker::GitRevWalker; oid::GitHash=GitHash(), by::Cint=Consts.SORT_NONE, rev::Bool=false)
Using the GitRevWalker
walker
to “walk” over every commit in the repository’s history, find the number of commits which return true
when f
is applied to them. The keyword arguments are: * oid
: The GitHash
of the commit to begin the walk from. The default is to use push_head!
and therefore the HEAD commit and all its ancestors. * by
: The sorting method. The default is not to sort. Other options are to sort by topology (LibGit2.Consts.SORT_TOPOLOGICAL
), to sort forwards in time (LibGit2.Consts.SORT_TIME
, most ancient first) or to sort backwards in time (LibGit2.Consts.SORT_REVERSE
, most recent first). * rev
: Whether to reverse the sorted order (for instance, if topological sorting is used).
Examples
cnt = LibGit2.with(LibGit2.GitRevWalker(repo)) do walker
count((oid, repo)->(oid == commit_oid1), walker, oid=commit_oid1, by=LibGit2.Consts.SORT_TIME)
end
count
finds the number of commits along the walk with a certain GitHash
commit_oid1
, starting the walk from that commit and moving forwards in time from it. Since the GitHash
is unique to a commit, cnt
will be 1
.
counthunks(blame::GitBlame)
Return the number of distinct “hunks” with a file. A hunk may contain multiple lines. A hunk is usually a piece of a file that was added/changed/removed together, for example, a function added to a source file or an inner loop that was optimized out of that function later.
LibGit2.create_branch(repo::GitRepo, bname::AbstractString, commit_obj::GitCommit; force::Bool=false)
Create a new branch in the repository repo
with name bname
, which points to commit commit_obj
(which has to be part of repo
). If force
is true
, overwrite an existing branch named bname
if it exists. If force
is false
and a branch already exists named bname
, this function will throw an error.
credential_callback(...) -> Cint
A LibGit2 credential callback function which provides different credential acquisition functionality w.r.t. a connection protocol. The payload_ptr
is required to contain a LibGit2.CredentialPayload
object which will keep track of state and settings.
The allowed_types
contains a bitmask of LibGit2.Consts.GIT_CREDTYPE
values specifying which authentication methods should be attempted.
Credential authentication is done in the following order (if supported):
- SSH agent
- SSH private/public key pair
- Username/password plain text
If a user is presented with a credential prompt they can abort the prompt by typing ^D
(pressing the control key together with the d
key).
Note: Due to the specifics of the libgit2
authentication procedure, when authentication fails, this function is called again without any indication whether authentication was successful or not. To avoid an infinite loop from repeatedly using the same faulty credentials, we will keep track of state using the payload.
For addition details see the LibGit2 guide on authenticating against a server.
C function pointer for credentials_callback
Return signature object. Free it after use.
LibGit2.delete_branch(branch::GitReference)
Delete the branch pointed to by branch
.
diff_files(repo::GitRepo, branch1::AbstractString, branch2::AbstractString; kwarg...) -> Vector{AbstractString}
Show which files have changed in the git repository repo
between branches branch1
and branch2
.
The keyword argument is:
filter::Set{Consts.DELTA_STATUS}=Set([Consts.DELTA_ADDED, Consts.DELTA_MODIFIED, Consts.DELTA_DELETED]))
, and it sets options for the diff. The default is to show files added, modified, or deleted.
Return only the names of the files which have changed, not their contents.
Examples
LibGit2.branch!(repo, "branch/a")
LibGit2.branch!(repo, "branch/b")
# add a file to repo
open(joinpath(LibGit2.path(repo),"file"),"w") do f
write(f, "hello repo
")
end
LibGit2.add!(repo, "file")
LibGit2.commit(repo, "add file")
# returns ["file"]
filt = Set([LibGit2.Consts.DELTA_ADDED])
files = LibGit2.diff_files(repo, "branch/a", "branch/b", filter=filt)
# returns [] because existing files weren't modified
filt = Set([LibGit2.Consts.DELTA_MODIFIED])
files = LibGit2.diff_files(repo, "branch/a", "branch/b", filter=filt)
Equivalent to git diff --name-only --diff-filter=<filter> <branch1> <branch2>
.
entryid(te::GitTreeEntry)
Return the GitHash
of the object to which te
refers.
entrytype(te::GitTreeEntry)
Return the type of the object to which te
refers. The result will be one of the types which objtype
returns, e.g. a GitTree
or GitBlob
.
fetch(rmt::GitRemote, refspecs; options::FetchOptions=FetchOptions(), msg="")
Fetch from the specified rmt
remote git repository, using refspecs
to determine which remote branch(es) to fetch. The keyword arguments are:
options
: determines the options for the fetch, e.g. whether to prune afterwards. SeeFetchOptions
for more information.msg
: a message to insert into the reflogs.
fetch(repo::GitRepo; kwargs...)
Fetches updates from an upstream of the repository repo
.
The keyword arguments are:
remote::AbstractString="origin"
: which remote, specified by name, ofrepo
to fetch from. If this is empty, the URL will be used to construct an anonymous remote.remoteurl::AbstractString=""
: the URL ofremote
. If not specified, will be assumed based on the given name ofremote
.refspecs=AbstractString[]
: determines properties of the fetch.credentials=nothing
: provides credentials and/or settings when authenticating against a privateremote
.callbacks=Callbacks()
: user provided callbacks and payloads.
Equivalent to git fetch [<remoteurl>|<repo>] [<refspecs>]
.
fetchheads(repo::GitRepo) -> Vector{FetchHead}
Return the list of all the fetch heads for repo
, each represented as a FetchHead
, including their names, URLs, and merge statuses.
Examples
julia> fetch_heads = LibGit2.fetchheads(repo);
julia> fetch_heads[1].name
"refs/heads/master"
julia> fetch_heads[1].ismerge
true
julia> fetch_heads[2].name
"refs/heads/test_branch"
julia> fetch_heads[2].ismerge
false
fetch_refspecs(rmt::GitRemote) -> Vector{String}
Get the fetch refspecs for the specified rmt
. These refspecs contain information about which branch(es) to fetch from.
Examples
julia> remote = LibGit2.get(LibGit2.GitRemote, repo, "upstream");
julia> LibGit2.add_fetch!(repo, remote, "upstream");
julia> LibGit2.fetch_refspecs(remote)
String["+refs/heads/*:refs/remotes/upstream/*"]
C function pointer for fetchhead_foreach_callback
merge_base(repo::GitRepo, one::AbstractString, two::AbstractString) -> GitHash
Find a merge base (a common ancestor) between the commits one
and two
. one
and two
may both be in string form. Return the GitHash
of the merge base.
merge!(repo::GitRepo; kwargs...) -> Bool
Perform a git merge on the repository repo
, merging commits with diverging history into the current branch. Return true
if the merge succeeded, false
if not.
The keyword arguments are:
committish::AbstractString=""
: Merge the named commit(s) incommittish
.branch::AbstractString=""
: Merge the branchbranch
and all its commits since it diverged from the current branch.fastforward::Bool=false
: Iffastforward
istrue
, only merge if the merge is a fast-forward (the current branch head is an ancestor of the commits to be merged), otherwise refuse to merge and returnfalse
. This is equivalent to the git CLI option--ff-only
.merge_opts::MergeOptions=MergeOptions()
:merge_opts
specifies options for the merge, such as merge strategy in case of conflicts.checkout_opts::CheckoutOptions=CheckoutOptions()
:checkout_opts
specifies options for the checkout step.
Equivalent to git merge [--ff-only] [<committish> | <branch>]
.
If you specify a branch
, this must be done in reference format, since the string will be turned into a GitReference
. For example, if you wanted to merge branch branch_a
, you would call merge!(repo, branch="refs/heads/branch_a")
.
merge!(repo::GitRepo, anns::Vector{GitAnnotated}; kwargs...) -> Bool
Merge changes from the annotated commits (captured as GitAnnotated
objects) anns
into the HEAD of the repository repo
. The keyword arguments are:
merge_opts::MergeOptions = MergeOptions()
: options for how to perform the merge, including whether fastforwarding is allowed. SeeMergeOptions
for more information.checkout_opts::CheckoutOptions = CheckoutOptions()
: options for how to perform the checkout. SeeCheckoutOptions
for more information.
anns
may refer to remote or local branch heads. Return true
if the merge is successful, otherwise return false
(for instance, if no merge is possible because the branches have no common ancestor).
Examples
upst_ann = LibGit2.GitAnnotated(repo, "branch/a")
# merge the branch in
LibGit2.merge!(repo, [upst_ann])
merge!(repo::GitRepo, anns::Vector{GitAnnotated}, fastforward::Bool; kwargs...) -> Bool
Merge changes from the annotated commits (captured as GitAnnotated
objects) anns
into the HEAD of the repository repo
. If fastforward
is true
, only a fastforward merge is allowed. In this case, if conflicts occur, the merge will fail. Otherwise, if fastforward
is false
, the merge may produce a conflict file which the user will need to resolve.
The keyword arguments are:
merge_opts::MergeOptions = MergeOptions()
: options for how to perform the merge, including whether fastforwarding is allowed. SeeMergeOptions
for more information.checkout_opts::CheckoutOptions = CheckoutOptions()
: options for how to perform the checkout. SeeCheckoutOptions
for more information.
anns
may refer to remote or local branch heads. Return true
if the merge is successful, otherwise return false
(for instance, if no merge is possible because the branches have no common ancestor).
Examples
upst_ann_1 = LibGit2.GitAnnotated(repo, "branch/a")
# merge the branch in, fastforward
LibGit2.merge!(repo, [upst_ann_1], true)
# merge conflicts!
upst_ann_2 = LibGit2.GitAnnotated(repo, "branch/b")
# merge the branch in, try to fastforward
LibGit2.merge!(repo, [upst_ann_2], true) # will return false
LibGit2.merge!(repo, [upst_ann_2], false) # will return true
ffmerge!(repo::GitRepo, ann::GitAnnotated)
Fastforward merge changes into current HEAD. This is only possible if the commit referred to by ann
is descended from the current HEAD (e.g. if pulling changes from a remote branch which is simply ahead of the local branch tip).
LibGit2.fullname(ref::GitReference)
Return the name of the reference pointed to by the symbolic reference ref
. If ref
is not a symbolic reference, return an empty string.
features()
Return a list of git features the current version of libgit2 supports, such as threading or using HTTPS or SSH.
filename(te::GitTreeEntry)
Return the filename of the object on disk to which te
refers.
filemode(te::GitTreeEntry) -> Cint
Return the UNIX filemode of the object on disk to which te
refers as an integer.
LibGit2.gitdir(repo::GitRepo)
Return the location of the “git” files of repo
:
- for normal repositories, this is the location of the
.git
folder. - for bare repositories, this is the location of the repository itself.
LibGit2.git_url(; kwargs...) -> String
Create a string based upon the URL components provided. When the scheme
keyword is not provided the URL produced will use the alternative scp-like syntax.
Keywords
scheme::AbstractString=""
: the URL scheme which identifies the protocol to be used. For HTTP use “http”, SSH use “ssh”, etc. Whenscheme
is not provided the output format will be “ssh” but using the scp-like syntax.username::AbstractString=""
: the username to use in the output if provided.password::AbstractString=""
: the password to use in the output if provided.host::AbstractString=""
: the hostname to use in the output. A hostname is required to be specified.port::Union{AbstractString,Integer}=""
: the port number to use in the output if provided. Cannot be specified when using the scp-like syntax.path::AbstractString=""
: the path to use in the output if provided.
Avoid using passwords in URLs. Unlike the credential objects, Julia is not able to securely zero or destroy the sensitive data after use and the password may remain in memory; possibly to be exposed by an uninitialized memory.
Examples
julia> LibGit2.git_url(username="git", host="github.com", path="JuliaLang/julia.git")
"git@github.com:JuliaLang/julia.git"
julia> LibGit2.git_url(scheme="https", host="github.com", path="/JuliaLang/julia.git")
"https://github.com/JuliaLang/julia.git"
julia> LibGit2.git_url(scheme="ssh", username="git", host="github.com", port=2222, path="JuliaLang/julia.git")
"ssh://git@github.com:2222/JuliaLang/julia.git"
@githash_str -> AbstractGitHash
Construct a git hash object from the given string, returning a GitShortHash
if the string is shorter than 40 hexadecimal digits, otherwise a GitHash
.
Examples
julia> LibGit2.githash"d114feb74ce633"
GitShortHash("d114feb74ce633")
julia> LibGit2.githash"d114feb74ce63307afe878a5228ad014e0289a85"
GitHash("d114feb74ce63307afe878a5228ad014e0289a85")
LibGit2.head(repo::GitRepo) -> GitReference
Return a GitReference
to the current HEAD of repo
.
head(pkg::AbstractString) -> String
Return current HEAD GitHash
of the pkg
repo as a string.
LibGit2.head!(repo::GitRepo, ref::GitReference) -> GitReference
Set the HEAD of repo
to the object pointed to by ref
.
LibGit2.head_oid(repo::GitRepo) -> GitHash
Lookup the object id of the current HEAD of git repository repo
.
LibGit2.headname(repo::GitRepo)
Lookup the name of the current HEAD of git repository repo
. If repo
is currently detached, return the name of the HEAD it’s detached from.
LibGit2.init(path::AbstractString, bare::Bool=false) -> GitRepo
Open a new git repository at path
. If bare
is false
, the working tree will be created in path/.git
. If bare
is true
, no working directory will be created.
is_ancestor_of(a::AbstractString, b::AbstractString, repo::GitRepo) -> Bool
Return true
if a
, a GitHash
in string form, is an ancestor of b
, a GitHash
in string form.
Examples
julia> repo = LibGit2.GitRepo(repo_path);
julia> LibGit2.add!(repo, test_file1);
julia> commit_oid1 = LibGit2.commit(repo, "commit1");
julia> LibGit2.add!(repo, test_file2);
julia> commit_oid2 = LibGit2.commit(repo, "commit2");
julia> LibGit2.is_ancestor_of(string(commit_oid1), string(commit_oid2), repo)
true
isbinary(blob::GitBlob) -> Bool
Use a heuristic to guess if a file is binary: searching for NULL bytes and looking for a reasonable ratio of printable to non-printable characters among the first 8000 bytes.
iscommit(id::AbstractString, repo::GitRepo) -> Bool
Check if commit id
(which is a GitHash
in string form) is in the repository.
Examples
julia> repo = LibGit2.GitRepo(repo_path);
julia> LibGit2.add!(repo, test_file);
julia> commit_oid = LibGit2.commit(repo, "add test_file");
julia> LibGit2.iscommit(string(commit_oid), repo)
true
LibGit2.isdiff(repo::GitRepo, treeish::AbstractString, pathspecs::AbstractString=""; cached::Bool=false)
Checks if there are any differences between the tree specified by treeish
and the tracked files in the working tree (if cached=false
) or the index (if cached=true
). pathspecs
are the specifications for options for the diff.
Examples
repo = LibGit2.GitRepo(repo_path)
LibGit2.isdiff(repo, "HEAD") # should be false
open(joinpath(repo_path, new_file), "a") do f
println(f, "here's my cool new file")
end
LibGit2.isdiff(repo, "HEAD") # now true
Equivalent to git diff-index <treeish> [-- <pathspecs>]
.
LibGit2.isdirty(repo::GitRepo, pathspecs::AbstractString=""; cached::Bool=false) -> Bool
Check if there have been any changes to tracked files in the working tree (if cached=false
) or the index (if cached=true
). pathspecs
are the specifications for options for the diff.
Examples
repo = LibGit2.GitRepo(repo_path)
LibGit2.isdirty(repo) # should be false
open(joinpath(repo_path, new_file), "a") do f
println(f, "here's my cool new file")
end
LibGit2.isdirty(repo) # now true
LibGit2.isdirty(repo, new_file) # now true
Equivalent to git diff-index HEAD [-- <pathspecs>]
.
LibGit2.isorphan(repo::GitRepo)
Check if the current branch is an “orphan” branch, i.e. has no commits. The first commit to this branch will have no parents.
isset(val::Integer, flag::Integer)
Test whether the bits of val
indexed by flag
are set (1
) or unset (0
).
iszero(id::GitHash) -> Bool
Determine whether all hexadecimal digits of the given GitHash
are zero.
lookup_branch(repo::GitRepo, branch_name::AbstractString, remote::Bool=false) -> Union{GitReference, Nothing}
Determine if the branch specified by branch_name
exists in the repository repo
. If remote
is true
, repo
is assumed to be a remote git repository. Otherwise, it is part of the local filesystem.
Return either a GitReference
to the requested branch if it exists, or nothing
if not.
LibGit2.map(f::Function, walker::GitRevWalker; oid::GitHash=GitHash(), range::AbstractString="", by::Cint=Consts.SORT_NONE, rev::Bool=false)
Using the GitRevWalker
walker
to “walk” over every commit in the repository’s history, apply f
to each commit in the walk. The keyword arguments are: * oid
: The GitHash
of the commit to begin the walk from. The default is to use push_head!
and therefore the HEAD commit and all its ancestors. * range
: A range of GitHash
s in the format oid1..oid2
. f
will be applied to all commits between the two. * by
: The sorting method. The default is not to sort. Other options are to sort by topology (LibGit2.Consts.SORT_TOPOLOGICAL
), to sort forwards in time (LibGit2.Consts.SORT_TIME
, most ancient first) or to sort backwards in time (LibGit2.Consts.SORT_REVERSE
, most recent first). * rev
: Whether to reverse the sorted order (for instance, if topological sorting is used).
Examples
oids = LibGit2.with(LibGit2.GitRevWalker(repo)) do walker
LibGit2.map((oid, repo)->string(oid), walker, by=LibGit2.Consts.SORT_TIME)
end
Here, map
visits each commit using the GitRevWalker
and finds its GitHash
.
Mirror callback function
Function sets +refs/*:refs/*
refspecs and mirror
flag for remote reference.
C function pointer for mirror_callback
message(c::GitCommit, raw::Bool=false)
Return the commit message describing the changes made in commit c
. If raw
is false
, return a slightly “cleaned up” message (which has any leading newlines removed). If raw
is true
, the message is not stripped of any such newlines.
merge_analysis(repo::GitRepo, anns::Vector{GitAnnotated}) -> analysis, preference
Run analysis on the branches pointed to by the annotated branch tips anns
and determine under what circumstances they can be merged. For instance, if anns[1]
is simply an ancestor of ann[2]
, then merge_analysis
will report that a fast-forward merge is possible.
Return two outputs, analysis
and preference
. analysis
has several possible values: * MERGE_ANALYSIS_NONE
: it is not possible to merge the elements of anns
. * MERGE_ANALYSIS_NORMAL
: a regular merge, when HEAD and the commits that the user wishes to merge have all diverged from a common ancestor. In this case the changes have to be resolved and conflicts may occur. * MERGE_ANALYSIS_UP_TO_DATE
: all the input commits the user wishes to merge can be reached from HEAD, so no merge needs to be performed. * MERGE_ANALYSIS_FASTFORWARD
: the input commit is a descendant of HEAD and so no merge needs to be performed - instead, the user can simply checkout the input commit(s). * MERGE_ANALYSIS_UNBORN
: the HEAD of the repository refers to a commit which does not exist. It is not possible to merge, but it may be possible to checkout the input commits. preference
also has several possible values: * MERGE_PREFERENCE_NONE
: the user has no preference. * MERGE_PREFERENCE_NO_FASTFORWARD
: do not allow any fast-forward merges. * MERGE_PREFERENCE_FASTFORWARD_ONLY
: allow only fast-forward merges and no other type (which may introduce conflicts). preference
can be controlled through the repository or global git configuration.
LibGit2.name(ref::GitReference)
Return the full name of ref
.
name(rmt::GitRemote)
Get the name of a remote repository, for instance "origin"
. If the remote is anonymous (see GitRemoteAnon
) the name will be an empty string ""
.
Examples
julia> repo_url = "https://github.com/JuliaLang/Example.jl";
julia> repo = LibGit2.clone(cache_repo, "test_directory");
julia> remote = LibGit2.GitRemote(repo, "origin", repo_url);
julia> name(remote)
"origin"
LibGit2.name(tag::GitTag)
The name of tag
(e.g. "v0.5"
).
need_update(repo::GitRepo)
Equivalent to git update-index
. Return true
if repo
needs updating.
objtype(obj_type::Consts.OBJECT)
Return the type corresponding to the enum value.
LibGit2.path(repo::GitRepo)
Return the base file path of the repository repo
.
- for normal repositories, this will typically be the parent directory of the “.git” directory (note: this may be different than the working directory, see
workdir
for more details). - for bare repositories, this is the location of the “git” files.
peel([T,] ref::GitReference)
Recursively peel ref
until an object of type T
is obtained. If no T
is provided, then ref
will be peeled until an object other than a GitTag
is obtained.
Only annotated tags can be peeled to GitTag
objects. Lightweight tags (the default) are references under refs/tags/
which point directly to GitCommit
objects.
peel([T,] obj::GitObject)
Recursively peel obj
until an object of type T
is obtained. If no T
is provided, then obj
will be peeled until the type changes.
- A
GitTag
will be peeled to the object it references. - A
GitCommit
will be peeled to aGitTree
.
LibGit2.posixpath(path)
Standardise the path string path
to use POSIX separators.
push(rmt::GitRemote, refspecs; force::Bool=false, options::PushOptions=PushOptions())
Push to the specified rmt
remote git repository, using refspecs
to determine which remote branch(es) to push to. The keyword arguments are:
force
: iftrue
, a force-push will occur, disregarding conflicts.options
: determines the options for the push, e.g. which proxy headers to use. SeePushOptions
for more information.
You can add information about the push refspecs in two other ways: by setting an option in the repository’s GitConfig
(with push.default
as the key) or by calling add_push!
. Otherwise you will need to explicitly specify a push refspec in the call to push
for it to have any effect, like so: LibGit2.push(repo, refspecs=["refs/heads/master"])
.
push(repo::GitRepo; kwargs...)
Pushes updates to an upstream of repo
.
The keyword arguments are:
remote::AbstractString="origin"
: the name of the upstream remote to push to.remoteurl::AbstractString=""
: the URL ofremote
.refspecs=AbstractString[]
: determines properties of the push.force::Bool=false
: determines if the push will be a force push, overwriting the remote branch.credentials=nothing
: provides credentials and/or settings when authenticating against a privateremote
.callbacks=Callbacks()
: user provided callbacks and payloads.
Equivalent to git push [<remoteurl>|<repo>] [<refspecs>]
.
LibGit2.push!(w::GitRevWalker, cid::GitHash)
Start the GitRevWalker
walker
at commit cid
. This function can be used to apply a function to all commits since a certain year, by passing the first commit of that year as cid
and then passing the resulting w
to map
.
LibGit2.push_head!(w::GitRevWalker)
Push the HEAD commit and its ancestors onto the GitRevWalker
w
. This ensures that HEAD and all its ancestor commits will be encountered during the walk.
push_refspecs(rmt::GitRemote) -> Vector{String}
Get the push refspecs for the specified rmt
. These refspecs contain information about which branch(es) to push to.
Examples
julia> remote = LibGit2.get(LibGit2.GitRemote, repo, "upstream");
julia> LibGit2.add_push!(repo, remote, "refs/heads/master");
julia> close(remote);
julia> remote = LibGit2.get(LibGit2.GitRemote, repo, "upstream");
julia> LibGit2.push_refspecs(remote)
String["refs/heads/master"]
raw(id::GitHash) -> Vector{UInt8}
Obtain the raw bytes of the GitHash
as a vector of length 20.
LibGit2.read_tree!(idx::GitIndex, tree::GitTree)
LibGit2.read_tree!(idx::GitIndex, treehash::AbstractGitHash)
Read the tree tree
(or the tree pointed to by treehash
in the repository owned by idx
) into the index idx
. The current index contents will be replaced.
LibGit2.rebase!(repo::GitRepo, upstream::AbstractString="", newbase::AbstractString="")
Attempt an automatic merge rebase of the current branch, from upstream
if provided, or otherwise from the upstream tracking branch. newbase
is the branch to rebase onto. By default this is upstream
.
If any conflicts arise which cannot be automatically resolved, the rebase will abort, leaving the repository and working tree in its original state, and the function will throw a GitError
. This is roughly equivalent to the following command line statement:
git rebase --merge [<upstream>]
if [ -d ".git/rebase-merge" ]; then
git rebase --abort
fi
LibGit2.ref_list(repo::GitRepo) -> Vector{String}
Get a list of all reference names in the repo
repository.
LibGit2.reftype(ref::GitReference) -> Cint
Return a Cint
corresponding to the type of ref
:
0
if the reference is invalid1
if the reference is an object id2
if the reference is symbolic
LibGit2.remotes(repo::GitRepo)
Return a vector of the names of the remotes of repo
.
remove!(repo::GitRepo, files::AbstractString...)
remove!(idx::GitIndex, files::AbstractString...)
Remove all the files with paths specified by files
in the index idx
(or the index of the repo
).
reset(val::Integer, flag::Integer)
Unset the bits of val
indexed by flag
, returning them to 0
.
reset!(payload, [config]) -> CredentialPayload
Reset the payload
state back to the initial values so that it can be used again within the credential callback. If a config
is provided the configuration will also be updated.
Updates some entries, determined by the pathspecs
, in the index from the target commit tree.
Sets the current head to the specified commit oid and optionally resets the index and working tree to match.
git reset [
reset!(repo::GitRepo, id::GitHash, mode::Cint=Consts.RESET_MIXED)
Reset the repository repo
to its state at id
, using one of three modes set by mode
:
Consts.RESET_SOFT
- move HEAD toid
.Consts.RESET_MIXED
- default, move HEAD toid
and reset the index toid
.Consts.RESET_HARD
- move HEAD toid
, reset the index toid
, and discard all working changes.
Examples
# fetch changes
LibGit2.fetch(repo)
isfile(joinpath(repo_path, our_file)) # will be false
# fastforward merge the changes
LibGit2.merge!(repo, fastforward=true)
# because there was not any file locally, but there is
# a file remotely, we need to reset the branch
head_oid = LibGit2.head_oid(repo)
new_head = LibGit2.reset!(repo, head_oid, LibGit2.Consts.RESET_HARD)
In this example, the remote which is being fetched from does have a file called our_file
in its index, which is why we must reset.
Equivalent to git reset [--soft | --mixed | --hard] <id>
.
Examples
repo = LibGit2.GitRepo(repo_path)
head_oid = LibGit2.head_oid(repo)
open(joinpath(repo_path, "file1"), "w") do f
write(f, "111
")
end
LibGit2.add!(repo, "file1")
mode = LibGit2.Consts.RESET_HARD
# will discard the changes to file1
# and unstage it
new_head = LibGit2.reset!(repo, head_oid, mode)
restore(s::State, repo::GitRepo)
Return a repository repo
to a previous State
s
, for example the HEAD of a branch before a merge attempt. s
can be generated using the snapshot
function.
LibGit2.revcount(repo::GitRepo, commit1::AbstractString, commit2::AbstractString)
List the number of revisions between commit1
and commit2
(committish OIDs in string form). Since commit1
and commit2
may be on different branches, revcount
performs a “left-right” revision list (and count), returning a tuple of Int
s - the number of left and right commits, respectively. A left (or right) commit refers to which side of a symmetric difference in a tree the commit is reachable from.
Equivalent to git rev-list --left-right --count <commit1> <commit2>
.
Examples
repo = LibGit2.GitRepo(repo_path)
repo_file = open(joinpath(repo_path, test_file), "a")
println(repo_file, "hello world")
flush(repo_file)
LibGit2.add!(repo, test_file)
commit_oid1 = LibGit2.commit(repo, "commit 1")
println(repo_file, "hello world again")
flush(repo_file)
LibGit2.add!(repo, test_file)
commit_oid2 = LibGit2.commit(repo, "commit 2")
LibGit2.revcount(repo, string(commit_oid1), string(commit_oid2))
This will return (-1, 0)
.
set_remote_url(repo::GitRepo, remote_name, url)
set_remote_url(repo::String, remote_name, url)
Set both the fetch and push url
for remote_name
for the GitRepo
or the git repository located at path
. Typically git repos use "origin"
as the remote name.
Examples
repo_path = joinpath(tempdir(), "Example")
repo = LibGit2.init(repo_path)
LibGit2.set_remote_url(repo, "upstream", "https://github.com/JuliaLang/Example.jl")
LibGit2.set_remote_url(repo_path, "upstream2", "https://github.com/JuliaLang/Example2.jl")
LibGit2.shortname(ref::GitReference)
Return a shortened version of the name of ref
that’s “human-readable”.
julia> repo = LibGit2.GitRepo(path_to_repo);
julia> branch_ref = LibGit2.head(repo);
julia> LibGit2.name(branch_ref)
"refs/heads/master"
julia> LibGit2.shortname(branch_ref)
"master"
snapshot(repo::GitRepo) -> State
Take a snapshot of the current state of the repository repo
, storing the current HEAD, index, and any uncommitted work. The output State
can be used later during a call to restore
to return the repository to the snapshotted state.
LibGit2.split_cfg_entry(ce::LibGit2.ConfigEntry) -> Tuple{String,String,String,String}
Break the ConfigEntry
up to the following pieces: section, subsection, name, and value.
Examples
Given the git configuration file containing:
[credential "https://example.com"]
username = me
The ConfigEntry
would look like the following:
julia> entry
ConfigEntry("credential.https://example.com.username", "me")
julia> LibGit2.split_cfg_entry(entry)
("credential", "https://example.com", "username", "me")
Refer to the git config syntax documentation for more details.
LibGit2.status(repo::GitRepo, path::String) -> Union{Cuint, Cvoid}
Lookup the status of the file at path
in the git repository repo
. For instance, this can be used to check if the file at path
has been modified and needs to be staged and committed.
stage(ie::IndexEntry) -> Cint
Get the stage number of ie
. The stage number 0
represents the current state of the working tree, but other numbers can be used in the case of a merge conflict. In such a case, the various stage numbers on an IndexEntry
describe which side(s) of the conflict the current state of the file belongs to. Stage 0
is the state before the attempted merge, stage 1
is the changes which have been made locally, stages 2
and larger are for changes from other branches (for instance, in the case of a multi-branch “octopus” merge, stages 2
, 3
, and 4
might be used).
LibGit2.tag_create(repo::GitRepo, tag::AbstractString, commit; kwargs...)
Create a new git tag tag
(e.g. "v0.5"
) in the repository repo
, at the commit commit
.
The keyword arguments are:
msg::AbstractString=""
: the message for the tag.force::Bool=false
: iftrue
, existing references will be overwritten.sig::Signature=Signature(repo)
: the tagger’s signature.
LibGit2.tag_delete(repo::GitRepo, tag::AbstractString)
Remove the git tag tag
from the repository repo
.
LibGit2.tag_list(repo::GitRepo) -> Vector{String}
Get a list of all tags in the git repository repo
.
LibGit2.target(tag::GitTag)
The GitHash
of the target object of tag
.
toggle(val::Integer, flag::Integer)
Flip the bits of val
indexed by flag
, so that if a bit is 0
it will be 1
after the toggle, and vice-versa.
transact(f::Function, repo::GitRepo)
Apply function f
to the git repository repo
, taking a snapshot
before applying f
. If an error occurs within f
, repo
will be returned to its snapshot state using restore
. The error which occurred will be rethrown, but the state of repo
will not be corrupted.
treewalk(f, tree::GitTree, post::Bool=false)
Traverse the entries in tree
and its subtrees in post or pre order. Preorder means beginning at the root and then traversing the leftmost subtree (and recursively on down through that subtree’s leftmost subtrees) and moving right through the subtrees. Postorder means beginning at the bottom of the leftmost subtree, traversing upwards through it, then traversing the next right subtree (again beginning at the bottom) and finally visiting the tree root last of all.
The function parameter f
should have following signature:
(String, GitTreeEntry) -> Cint
A negative value returned from f
stops the tree walk. A positive value means that the entry will be skipped if post
is false
.
upstream(ref::GitReference) -> Union{GitReference, Nothing}
Determine if the branch containing ref
has a specified upstream branch.
Return either a GitReference
to the upstream branch if it exists, or nothing
if the requested branch does not have an upstream counterpart.
update!(repo::GitRepo, files::AbstractString...)
update!(idx::GitIndex, files::AbstractString...)
Update all the files with paths specified by files
in the index idx
(or the index of the repo
). Match the state of each file in the index with the current state on disk, removing it if it has been removed on disk, or updating its entry in the object database.
url(rmt::GitRemote)
Get the fetch URL of a remote git repository.
Examples
julia> repo_url = "https://github.com/JuliaLang/Example.jl";
julia> repo = LibGit2.init(mktempdir());
julia> remote = LibGit2.GitRemote(repo, "origin", repo_url);
julia> LibGit2.url(remote)
"https://github.com/JuliaLang/Example.jl"
version() -> VersionNumber
Return the version of libgit2 in use, as a VersionNumber
.
with(f::Function, obj)
Resource management helper function. Applies f
to obj
, making sure to call close
on obj
after f
successfully returns or throws an error. Ensures that allocated git resources are finalized as soon as they are no longer needed.
with_warn(f::Function, ::Type{T}, args...)
Resource management helper function. Apply f
to args
, first constructing an instance of type T
from args
. Makes sure to call close
on the resulting object after f
successfully returns or throws an error. Ensures that allocated git resources are finalized as soon as they are no longer needed. If an error is thrown by f
, a warning is shown containing the error.
LibGit2.workdir(repo::GitRepo)
Return the location of the working directory of repo
. This will throw an error for bare repositories.
This will typically be the parent directory of gitdir(repo)
, but can be different in some cases: e.g. if either the core.worktree
configuration variable or the GIT_WORK_TREE
environment variable is set.
(::Type{T})(te::GitTreeEntry) where T<:GitObject
Get the git object to which te
refers and return it as its actual type (the type entrytype
would show), for instance a GitBlob
or GitTag
.
Examples
tree = LibGit2.GitTree(repo, "HEAD^{tree}")
tree_entry = tree[1]
blob = LibGit2.GitBlob(tree_entry)
Credential that support only user
and password
parameters
SSH credential type
isfilled(cred::AbstractCredential) -> Bool
Verifies that a credential is ready for use in authentication.
Caches credential information for re-use
LibGit2.CredentialPayload
Retains the state between multiple calls to the credential callback for the same URL. A CredentialPayload
instance is expected to be reset!
whenever it will be used with a different URL.
approve(payload::CredentialPayload; shred::Bool=true) -> Nothing
Store the payload
credential for re-use in a future authentication. Should only be called when authentication was successful.
The shred
keyword controls whether sensitive information in the payload credential field should be destroyed. Should only be set to false
during testing.
reject(payload::CredentialPayload; shred::Bool=true) -> Nothing
Discard the payload
credential from begin re-used in future authentication. Should only be called when authentication was unsuccessful.
The shred
keyword controls whether sensitive information in the payload credential field should be destroyed. Should only be set to false
during testing.