summaryrefslogtreecommitdiff
path: root/include/git2
Commit message (Collapse)AuthorAgeFilesLines
...
* | Merge pull request #4115 from gsaralms/users/gsaral/optionalOfsDeltaEdward Thomson2017-02-131-0/+11
|\ \ | |/ |/| Changes to provide option to turn off/on ofs_delta
| * Changes to provide option to turn off/on ofs_deltaGaurav Saral2017-02-101-0/+11
| | | | | | | | This change provides an option in git_libgit2_opt_t which can be used in git_libgit2_opts to turn off/on ofs_delta capability in libGit2
* | worktree: extract git_worktree_is_prunablePatrick Steinhardt2017-02-131-0/+18
| |
* | branch: implement `git_branch_is_checked_out`Patrick Steinhardt2017-02-131-0/+12
| | | | | | | | | | | | | | | | Implement a new function that is able to determine if a branch is checked out in any repository connected to the current repository. In particular, this is required to check if for a given repository and branch, there exists any working tree connected to that repository that is referencing this branch.
* | worktree: implement functions reading HEADPatrick Steinhardt2017-02-132-1/+26
| | | | | | | | | | | | Implement `git_repository_head_for_worktree` and `git_repository_head_detached_for_worktree` for directly accessing a worktree's HEAD without opening it as a `git_repository` first.
* | worktree: implement `git_worktree_prune`Patrick Steinhardt2017-02-131-0/+26
| | | | | | | | | | | | | | Implement the `git_worktree_prune` function. This function can be used to delete working trees from a repository. According to the flags passed to it, it can either delete the working tree's gitdir only or both gitdir and the working directory.
* | worktree: implement locking mechanismsPatrick Steinhardt2017-02-131-0/+36
| | | | | | | | | | | | Working trees support locking by creating a file `locked` inside the tree's gitdir with an optional reason inside. Support this feature by adding functions to get and set the locking status.
* | worktree: implement `git_worktree_add`Patrick Steinhardt2017-02-131-0/+15
| | | | | | | | | | Implement the `git_worktree_add` function which can be used to create new working trees for a given repository.
* | worktree: implement `git_worktree_validate`Patrick Steinhardt2017-02-132-0/+13
| | | | | | | | | | | | Add a new function that checks wether a given `struct git_worktree` is valid. The validation includes checking if the gitdir, parent directory and common directory are present.
* | worktree: implement `git_repository_open_from_worktree`Patrick Steinhardt2017-02-131-0/+11
| | | | | | | | | | Add function `git_repository_open_from_worktree`, which allows to open a `git_worktree` as repository.
* | worktree: introduce `struct git_worktree`Patrick Steinhardt2017-02-132-0/+20
| | | | | | | | | | | | | | Introduce a new `struct git_worktree`, which holds information about a possible working tree connected to a repository. Introduce functions to allow opening working trees for a repository.
* | worktree: implement `git_worktree_list`Patrick Steinhardt2017-02-131-0/+37
| | | | | | | | | | | | Add new module for working trees with the `git_worktree_list` function. The function lists names for all working trees of a certain repository.
* | repository: introduce is_worktree variablePatrick Steinhardt2017-02-131-0/+8
| |
* | repository: add function to retrieve paths for repo itemsPatrick Steinhardt2017-02-131-0/+36
| |
* | repository: introduce commondir variablePatrick Steinhardt2017-02-131-0/+11
| | | | | | | | | | | | | | | | | | The commondir variable stores the path to the common directory. The common directory is used to store objects and references shared across multiple repositories. A current use case is the newly introduced `git worktree` feature, which sets up a separate working copy, where the backing git object store and references are pointed to by the common directory.
* | Flag optional parameters for apply and popRemy Suen2017-02-091-2/+2
|/ | | | The options parameter in both git_stash_apply and git_stash_pop can be NULL. They should be flagged as such in the documentation.
* Flag checkout_opts in git_reset as optionalRemy Suen2017-02-051-1/+1
| | | | The check_outs argument can be NULL and should be flagged accordingly in the header file.
* Flag given_opts in git_revert as optionalRemy Suen2017-02-041-1/+1
| | | | The given_opts argument can actually be NULL and thus should be flagged accordingly in the header file.
* Update docs for git_oid_fromstrn and pMatthew Plough2017-01-271-5/+4
|
* parameter 'id' not found in the function declarationEtienne Samson2017-01-231-1/+1
|
* Merge branch 'pr/3912'Edward Thomson2017-01-211-0/+10
|\
| * symbolic ref target validation: fixupsEdward Thomson2017-01-211-10/+8
| | | | | | | | Fixups requested in #3912.
| * Make symbolic ref target validation optionalRichard Ipsum2016-08-271-0/+13
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Introduce GIT_OPT_ENABLE_SYMBOLIC_REF_TARGET_VALIDATION option. Setting this option to 0 allows validation of a symbolic ref's target to be bypassed. This option is enabled by default. This mechanism is added primarily to address a discrepancy between git behaviour and libgit2 behaviour, whereby the former allows the symbolic ref target to carry an arbitrary string and the latter does not, so: $ git symbolic-ref refs/heads/foo bar $ cat .git/refs/heads/foo ref: bar where as attempting the same via libgit2 raises an error: The given reference name 'bar' is not valid this mechanism also allows those that might want to make use of git's more lenient treatment of symbolic ref targets to do so.
* | Merge pull request #3892 from mitesch/shared_bufferEdward Thomson2017-01-211-0/+13
|\ \ | | | | | | Use a shared buffer in calls of git_treebuilder_write to avoid heap contention
| * | write_tree: use shared buffer for writing treesMichael Tesch2016-12-121-0/+13
| | | | | | | | | | | | | | | | | | | | | | | | | | | The function to write trees allocates a new buffer for each tree. This causes problems with performance when performing a lot of actions involving writing trees, e.g. when doing many merges. Fix the issue by instead handing in a shared buffer, which is then re-used across the calls without having to re-allocate between calls.
* | | Merge branch 'master' into pr/3938Edward Thomson2017-01-219-12/+72
|\ \ \
| * | | Allow for caching of submodules.Brock Peabody2017-01-201-0/+29
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Added `git_repository_submodule_cache_all` to initialze a cache of submodules on the repository so that operations looking up N submodules are O(N) and not O(N^2). Added a `git_repository_submodule_cache_clear` function to remove the cache. Also optimized the function that loads all submodules as it was itself O(N^2) w.r.t the number of submodules, having to loop through the `.gitmodules` file once per submodule. I changed it to process the `.gitmodules` file once, into a map. Signed-off-by: David Turner <dturner@twosigma.com>
| * | | merge: set default rename thresholdEdward Thomson2017-01-011-1/+2
| | | | | | | | | | | | | | | | | | | | When `GIT_MERGE_FIND_RENAMES` is set, provide a default for `rename_threshold` when it is unset.
| * | | Merge pull request #3980 from tiennou/doc-fixesv0.25.0-rc2v0.25.0Carlos Martín Nieto2016-12-203-5/+17
| |\ \ \ | | | | | | | | | | Documentation fixes
| | * | | transaction: fix documentationEtienne Samson2016-11-011-0/+9
| | | | |
| | * | | remote: fix documentation and indentEtienne Samson2016-11-011-1/+3
| | | | |
| | * | | remote: unused function typedefEtienne Samson2016-11-011-2/+0
| | | | |
| | * | | describe: fix documentationEtienne Samson2016-11-011-2/+5
| | | | |
| * | | | settings: clarify what each value meanscmn/https-cap-no-hardcodeCarlos Martín Nieto2016-12-171-0/+18
| | | | | | | | | | | | | | | | | | | | Most importantly, clarify what it means for HTTPS and SSH to be supported.
| * | | | remote: fix typo in git_fetch_init_options docsJosh Bleecher Snyder2016-12-021-1/+1
| | | | |
| * | | | Bump version number to v0.25cmn/bump-v25Carlos Martín Nieto2016-11-151-3/+3
| | | | |
| * | | | proxy: fix typo in documentationPatrick Steinhardt2016-11-011-1/+1
| |/ / /
| * | | patch: minor documentation fix.Davide Coppola2016-10-161-1/+1
| | | | | | | | | | | | | | | | Fix @return description of git_patch_num_lines_in_hunk.
* | | | Update submodule update opts init as per code reviewJosh Leeb-du Toit2016-10-101-1/+1
| | | | | | | | | | | | | | | | | | | | | | | | Update the `GIT_SUBMODULE_UPDATE_OPTIONS_INIT` definition with the correct values after removing `clone_checkout_strategy` in `git_submodule_update_options`.
* | | | Remove `clone_checkout_strategy` in submodule update optsJosh Leeb-du Toit2016-10-101-11/+2
|/ / / | | | | | | | | | | | | Remove `clone_checkout_strategy` in `git_submodule_update_options` as per issue #3784.
* | | docs: GIT_OPT_ENABLE_STRICT_OBJECT_CREATION is enabledethomson/settings_docsEdward Thomson2016-10-091-1/+2
| | | | | | | | | | | | | | | We changed the defaults on strict object creation - it is enabled by default. Update the documentation to reflect that.
* | | revwalk: update the description for the default sortingCarlos Martín Nieto2016-10-061-6/+4
| | | | | | | | | | | | | | | | | | It changed from implementation-defined to git's default sorting, as there are systems (e.g. rebase) which depend on this order. Also specify more explicitly how you can get git's "date-order".
* | | time: Export `git_time_monotonic`vmg/timeVicent Marti2016-09-131-0/+31
| | |
* | | diff: treat binary patches with no data specialethomson/diff-read-empty-binaryEdward Thomson2016-09-051-0/+8
| |/ |/| | | | | | | | | When creating and printing diffs, deal with binary deltas that have binary data specially, versus diffs that have a binary file but lack the actual binary data.
* | index: support index v4David Turner2016-08-101-0/+25
|/ | | | | | | Support reading and writing index v4. Index v4 uses a very simple compression scheme for pathnames, but is otherwise similar to index v3. Signed-off-by: David Turner <dturner@twitter.com>
* diff: document `git_diff_from_buffer`ethomson/doc_diff_from_bufferEdward Thomson2016-08-051-0/+19
|
* odb: freshen existing objects when writingEdward Thomson2016-08-041-0/+11
| | | | | | When writing an object, we calculate its OID and see if it exists in the object database. If it does, we need to freshen the file that contains it.
* git_diff_file: move `id_abbrev`ethomson/diff_fileEdward Thomson2016-08-031-6/+6
| | | | | Move `id_abbrev` to a more reasonable place where it packs more nicely (before anybody starts using it).
* packbuilder: `size_t` all the thingsEdward Thomson2016-07-241-4/+4
| | | | | | | | After 1cd65991, we were passing a pointer to an `unsigned long` to a function that now expected a pointer to a `size_t`. These types differ on 64-bit Windows, which means that we trash the stack. Use `size_t`s in the packbuilder to avoid this.
* Add get user agent functionality.Andrius Bentkus2016-07-051-0/+1
|