rugged 0.27.10.1 → 0.28.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/ext/rugged/extconf.rb +23 -2
- data/ext/rugged/rugged.c +48 -2
- data/ext/rugged/rugged.h +5 -0
- data/ext/rugged/rugged_allocator.c +89 -0
- data/ext/rugged/rugged_blob.c +3 -3
- data/ext/rugged/rugged_branch.c +1 -1
- data/ext/rugged/rugged_commit.c +8 -8
- data/ext/rugged/rugged_config.c +1 -1
- data/ext/rugged/rugged_diff.c +24 -4
- data/ext/rugged/rugged_note.c +1 -1
- data/ext/rugged/rugged_repo.c +10 -10
- data/ext/rugged/rugged_settings.c +1 -1
- data/lib/rugged/version.rb +1 -1
- data/vendor/libgit2/CMakeLists.txt +69 -47
- data/vendor/libgit2/cmake/Modules/AddCFlagIfSupported.cmake +15 -1
- data/vendor/libgit2/cmake/Modules/EnableWarnings.cmake +5 -8
- data/vendor/libgit2/cmake/Modules/FindmbedTLS.cmake +93 -0
- data/vendor/libgit2/deps/http-parser/CMakeLists.txt +2 -0
- data/vendor/libgit2/deps/http-parser/{LICENSE-MIT → COPYING} +0 -0
- data/vendor/libgit2/deps/regex/COPYING +502 -0
- data/vendor/libgit2/deps/winhttp/COPYING.GPL +993 -0
- data/vendor/libgit2/deps/winhttp/COPYING.LGPL +502 -0
- data/vendor/libgit2/deps/zlib/CMakeLists.txt +1 -0
- data/vendor/libgit2/deps/zlib/COPYING +27 -0
- data/vendor/libgit2/include/git2.h +3 -0
- data/vendor/libgit2/include/git2/annotated_commit.h +9 -0
- data/vendor/libgit2/include/git2/apply.h +129 -0
- data/vendor/libgit2/include/git2/attr.h +19 -8
- data/vendor/libgit2/include/git2/blame.h +41 -24
- data/vendor/libgit2/include/git2/blob.h +1 -1
- data/vendor/libgit2/include/git2/branch.h +1 -1
- data/vendor/libgit2/include/git2/buffer.h +2 -2
- data/vendor/libgit2/include/git2/checkout.h +20 -19
- data/vendor/libgit2/include/git2/cherrypick.h +6 -4
- data/vendor/libgit2/include/git2/clone.h +11 -9
- data/vendor/libgit2/include/git2/commit.h +30 -2
- data/vendor/libgit2/include/git2/common.h +54 -4
- data/vendor/libgit2/include/git2/config.h +18 -7
- data/vendor/libgit2/include/git2/deprecated.h +253 -0
- data/vendor/libgit2/include/git2/describe.h +30 -7
- data/vendor/libgit2/include/git2/diff.h +193 -143
- data/vendor/libgit2/include/git2/errors.h +54 -46
- data/vendor/libgit2/include/git2/ignore.h +2 -2
- data/vendor/libgit2/include/git2/index.h +72 -51
- data/vendor/libgit2/include/git2/indexer.h +30 -4
- data/vendor/libgit2/include/git2/mailmap.h +115 -0
- data/vendor/libgit2/include/git2/merge.h +29 -8
- data/vendor/libgit2/include/git2/net.h +1 -1
- data/vendor/libgit2/include/git2/notes.h +1 -1
- data/vendor/libgit2/include/git2/object.h +16 -16
- data/vendor/libgit2/include/git2/odb.h +10 -10
- data/vendor/libgit2/include/git2/odb_backend.h +7 -7
- data/vendor/libgit2/include/git2/oid.h +1 -1
- data/vendor/libgit2/include/git2/pack.h +2 -2
- data/vendor/libgit2/include/git2/proxy.h +9 -5
- data/vendor/libgit2/include/git2/rebase.h +7 -4
- data/vendor/libgit2/include/git2/refs.h +14 -15
- data/vendor/libgit2/include/git2/refspec.h +17 -0
- data/vendor/libgit2/include/git2/remote.h +92 -16
- data/vendor/libgit2/include/git2/repository.h +52 -37
- data/vendor/libgit2/include/git2/revert.h +5 -3
- data/vendor/libgit2/include/git2/revwalk.h +7 -7
- data/vendor/libgit2/include/git2/signature.h +2 -2
- data/vendor/libgit2/include/git2/stash.h +13 -10
- data/vendor/libgit2/include/git2/status.h +8 -4
- data/vendor/libgit2/include/git2/submodule.h +11 -10
- data/vendor/libgit2/include/git2/sys/alloc.h +101 -0
- data/vendor/libgit2/include/git2/sys/commit.h +1 -1
- data/vendor/libgit2/include/git2/sys/config.h +13 -13
- data/vendor/libgit2/include/git2/sys/filter.h +6 -6
- data/vendor/libgit2/include/git2/sys/index.h +3 -0
- data/vendor/libgit2/include/git2/sys/mempack.h +35 -35
- data/vendor/libgit2/include/git2/sys/merge.h +9 -4
- data/vendor/libgit2/include/git2/sys/odb_backend.h +19 -19
- data/vendor/libgit2/include/git2/sys/path.h +64 -0
- data/vendor/libgit2/include/git2/sys/refdb_backend.h +19 -19
- data/vendor/libgit2/include/git2/sys/stream.h +92 -12
- data/vendor/libgit2/include/git2/sys/transport.h +127 -81
- data/vendor/libgit2/include/git2/tag.h +2 -2
- data/vendor/libgit2/include/git2/trace.h +1 -1
- data/vendor/libgit2/include/git2/transaction.h +1 -0
- data/vendor/libgit2/include/git2/transport.h +47 -18
- data/vendor/libgit2/include/git2/tree.h +3 -3
- data/vendor/libgit2/include/git2/types.h +35 -28
- data/vendor/libgit2/include/git2/version.h +4 -4
- data/vendor/libgit2/include/git2/worktree.h +47 -12
- data/vendor/libgit2/src/CMakeLists.txt +87 -26
- data/vendor/libgit2/src/alloc.c +55 -0
- data/vendor/libgit2/src/alloc.h +40 -0
- data/vendor/libgit2/src/annotated_commit.c +15 -8
- data/vendor/libgit2/src/apply.c +490 -14
- data/vendor/libgit2/src/apply.h +3 -1
- data/vendor/libgit2/src/array.h +2 -2
- data/vendor/libgit2/src/attr.c +11 -11
- data/vendor/libgit2/src/attr_file.c +20 -15
- data/vendor/libgit2/src/attrcache.c +11 -11
- data/vendor/libgit2/src/blame.c +30 -15
- data/vendor/libgit2/src/blame.h +1 -0
- data/vendor/libgit2/src/blame_git.c +16 -13
- data/vendor/libgit2/src/blob.c +50 -28
- data/vendor/libgit2/src/blob.h +18 -1
- data/vendor/libgit2/src/branch.c +38 -38
- data/vendor/libgit2/src/buf_text.c +7 -6
- data/vendor/libgit2/src/buffer.c +55 -50
- data/vendor/libgit2/src/buffer.h +1 -1
- data/vendor/libgit2/src/cache.c +16 -16
- data/vendor/libgit2/src/cache.h +2 -2
- data/vendor/libgit2/src/cc-compat.h +15 -3
- data/vendor/libgit2/src/checkout.c +83 -74
- data/vendor/libgit2/src/cherrypick.c +6 -6
- data/vendor/libgit2/src/clone.c +20 -20
- data/vendor/libgit2/src/commit.c +53 -33
- data/vendor/libgit2/src/commit.h +1 -0
- data/vendor/libgit2/src/commit_list.c +6 -10
- data/vendor/libgit2/src/common.h +32 -30
- data/vendor/libgit2/src/config.c +167 -147
- data/vendor/libgit2/src/config.h +1 -14
- data/vendor/libgit2/src/config_backend.h +84 -0
- data/vendor/libgit2/src/config_cache.c +7 -1
- data/vendor/libgit2/src/config_entries.c +259 -0
- data/vendor/libgit2/src/config_entries.h +23 -0
- data/vendor/libgit2/src/config_file.c +167 -439
- data/vendor/libgit2/src/config_mem.c +224 -0
- data/vendor/libgit2/src/config_parse.c +69 -38
- data/vendor/libgit2/src/config_parse.h +4 -4
- data/vendor/libgit2/src/crlf.c +215 -186
- data/vendor/libgit2/src/delta.c +25 -18
- data/vendor/libgit2/src/describe.c +23 -23
- data/vendor/libgit2/src/diff.c +12 -12
- data/vendor/libgit2/src/diff_driver.c +14 -15
- data/vendor/libgit2/src/diff_file.c +10 -10
- data/vendor/libgit2/src/diff_generate.c +29 -23
- data/vendor/libgit2/src/diff_generate.h +1 -1
- data/vendor/libgit2/src/diff_parse.c +3 -3
- data/vendor/libgit2/src/diff_print.c +17 -17
- data/vendor/libgit2/src/diff_stats.c +22 -7
- data/vendor/libgit2/src/diff_tform.c +12 -12
- data/vendor/libgit2/src/diff_xdiff.c +15 -3
- data/vendor/libgit2/src/errors.c +42 -20
- data/vendor/libgit2/src/features.h.in +2 -1
- data/vendor/libgit2/src/fetch.c +3 -3
- data/vendor/libgit2/src/fetchhead.c +16 -16
- data/vendor/libgit2/src/filebuf.c +28 -28
- data/vendor/libgit2/src/fileops.c +54 -54
- data/vendor/libgit2/src/fileops.h +1 -1
- data/vendor/libgit2/src/filter.c +30 -30
- data/vendor/libgit2/src/filter.h +0 -10
- data/vendor/libgit2/src/global.c +36 -23
- data/vendor/libgit2/src/hash.h +4 -1
- data/vendor/libgit2/src/hash/hash_collisiondetect.h +6 -2
- data/vendor/libgit2/src/hash/hash_common_crypto.h +5 -1
- data/vendor/libgit2/src/hash/hash_generic.h +5 -1
- data/vendor/libgit2/src/hash/hash_mbedtls.c +38 -0
- data/vendor/libgit2/src/hash/hash_mbedtls.h +24 -0
- data/vendor/libgit2/src/hash/hash_openssl.h +8 -4
- data/vendor/libgit2/src/hash/hash_win32.c +13 -13
- data/vendor/libgit2/src/hashsig.c +4 -4
- data/vendor/libgit2/src/idxmap.c +25 -5
- data/vendor/libgit2/src/idxmap.h +4 -18
- data/vendor/libgit2/src/ignore.c +9 -9
- data/vendor/libgit2/src/index.c +280 -198
- data/vendor/libgit2/src/index.h +16 -0
- data/vendor/libgit2/src/indexer.c +311 -139
- data/vendor/libgit2/src/integer.h +32 -22
- data/vendor/libgit2/src/iterator.c +116 -49
- data/vendor/libgit2/src/iterator.h +15 -0
- data/vendor/libgit2/src/khash.h +3 -1
- data/vendor/libgit2/src/mailmap.c +485 -0
- data/vendor/libgit2/src/mailmap.h +35 -0
- data/vendor/libgit2/src/merge.c +89 -59
- data/vendor/libgit2/src/merge_driver.c +7 -7
- data/vendor/libgit2/src/merge_file.c +1 -1
- data/vendor/libgit2/src/mwindow.c +8 -8
- data/vendor/libgit2/src/netops.c +22 -13
- data/vendor/libgit2/src/netops.h +2 -0
- data/vendor/libgit2/src/notes.c +15 -10
- data/vendor/libgit2/src/object.c +118 -67
- data/vendor/libgit2/src/object.h +20 -9
- data/vendor/libgit2/src/object_api.c +8 -8
- data/vendor/libgit2/src/odb.c +72 -72
- data/vendor/libgit2/src/odb.h +7 -7
- data/vendor/libgit2/src/odb_loose.c +46 -46
- data/vendor/libgit2/src/odb_mempack.c +14 -14
- data/vendor/libgit2/src/odb_pack.c +14 -10
- data/vendor/libgit2/src/offmap.c +30 -0
- data/vendor/libgit2/src/offmap.h +20 -11
- data/vendor/libgit2/src/oid.c +6 -6
- data/vendor/libgit2/src/oidmap.c +20 -0
- data/vendor/libgit2/src/oidmap.h +9 -12
- data/vendor/libgit2/src/pack-objects.c +71 -63
- data/vendor/libgit2/src/pack-objects.h +1 -7
- data/vendor/libgit2/src/pack.c +58 -58
- data/vendor/libgit2/src/pack.h +6 -6
- data/vendor/libgit2/src/parse.h +1 -1
- data/vendor/libgit2/src/patch.c +3 -3
- data/vendor/libgit2/src/patch_generate.c +18 -18
- data/vendor/libgit2/src/patch_parse.c +13 -13
- data/vendor/libgit2/src/path.c +93 -225
- data/vendor/libgit2/src/path.h +2 -84
- data/vendor/libgit2/src/pathspec.c +6 -6
- data/vendor/libgit2/src/posix.c +3 -3
- data/vendor/libgit2/src/proxy.c +1 -1
- data/vendor/libgit2/src/push.c +27 -26
- data/vendor/libgit2/src/push.h +2 -1
- data/vendor/libgit2/src/reader.c +265 -0
- data/vendor/libgit2/src/reader.h +107 -0
- data/vendor/libgit2/src/rebase.c +49 -52
- data/vendor/libgit2/src/refdb.c +3 -3
- data/vendor/libgit2/src/refdb_fs.c +181 -103
- data/vendor/libgit2/src/reflog.c +3 -3
- data/vendor/libgit2/src/refs.c +98 -74
- data/vendor/libgit2/src/refs.h +5 -3
- data/vendor/libgit2/src/refspec.c +47 -21
- data/vendor/libgit2/src/refspec.h +1 -1
- data/vendor/libgit2/src/remote.c +219 -166
- data/vendor/libgit2/src/remote.h +9 -0
- data/vendor/libgit2/src/repository.c +173 -133
- data/vendor/libgit2/src/repository.h +6 -3
- data/vendor/libgit2/src/reset.c +8 -8
- data/vendor/libgit2/src/revert.c +6 -6
- data/vendor/libgit2/src/revparse.c +30 -30
- data/vendor/libgit2/src/revwalk.c +60 -30
- data/vendor/libgit2/src/revwalk.h +2 -1
- data/vendor/libgit2/src/settings.c +42 -10
- data/vendor/libgit2/src/signature.c +11 -11
- data/vendor/libgit2/src/sortedcache.c +13 -13
- data/vendor/libgit2/src/stash.c +91 -45
- data/vendor/libgit2/src/status.c +13 -13
- data/vendor/libgit2/src/stdalloc.c +120 -0
- data/vendor/libgit2/src/{streams/curl.h → stdalloc.h} +6 -6
- data/vendor/libgit2/src/stream.h +17 -2
- data/vendor/libgit2/src/streams/mbedtls.c +483 -0
- data/vendor/libgit2/src/streams/mbedtls.h +23 -0
- data/vendor/libgit2/src/streams/openssl.c +204 -114
- data/vendor/libgit2/src/streams/openssl.h +4 -108
- data/vendor/libgit2/src/streams/registry.c +118 -0
- data/vendor/libgit2/src/streams/registry.h +19 -0
- data/vendor/libgit2/src/streams/socket.c +54 -29
- data/vendor/libgit2/src/streams/stransport.c +57 -32
- data/vendor/libgit2/src/streams/stransport.h +5 -0
- data/vendor/libgit2/src/streams/tls.c +50 -19
- data/vendor/libgit2/src/streams/tls.h +12 -4
- data/vendor/libgit2/src/strmap.c +22 -2
- data/vendor/libgit2/src/strmap.h +18 -15
- data/vendor/libgit2/src/submodule.c +179 -155
- data/vendor/libgit2/src/sysdir.c +18 -18
- data/vendor/libgit2/src/tag.c +31 -26
- data/vendor/libgit2/src/tag.h +2 -1
- data/vendor/libgit2/src/trace.c +1 -1
- data/vendor/libgit2/src/trace.h +1 -1
- data/vendor/libgit2/src/trailer.c +6 -6
- data/vendor/libgit2/src/transaction.c +23 -23
- data/vendor/libgit2/src/transport.c +5 -5
- data/vendor/libgit2/src/transports/auth.c +7 -4
- data/vendor/libgit2/src/transports/auth.h +1 -1
- data/vendor/libgit2/src/transports/auth_negotiate.c +12 -11
- data/vendor/libgit2/src/transports/cred.c +18 -18
- data/vendor/libgit2/src/transports/git.c +15 -15
- data/vendor/libgit2/src/transports/http.c +606 -216
- data/vendor/libgit2/src/transports/http.h +2 -0
- data/vendor/libgit2/src/transports/local.c +26 -26
- data/vendor/libgit2/src/transports/smart.c +54 -31
- data/vendor/libgit2/src/transports/smart.h +1 -2
- data/vendor/libgit2/src/transports/smart_pkt.c +43 -40
- data/vendor/libgit2/src/transports/smart_protocol.c +61 -57
- data/vendor/libgit2/src/transports/ssh.c +34 -33
- data/vendor/libgit2/src/transports/winhttp.c +99 -119
- data/vendor/libgit2/src/tree-cache.c +5 -5
- data/vendor/libgit2/src/tree.c +96 -121
- data/vendor/libgit2/src/tree.h +1 -12
- data/vendor/libgit2/src/unix/map.c +2 -2
- data/vendor/libgit2/src/util.c +22 -6
- data/vendor/libgit2/src/util.h +12 -135
- data/vendor/libgit2/src/vector.c +4 -4
- data/vendor/libgit2/src/win32/dir.c +3 -3
- data/vendor/libgit2/src/win32/findfile.c +3 -3
- data/vendor/libgit2/src/win32/map.c +6 -6
- data/vendor/libgit2/src/win32/msvc-compat.h +6 -0
- data/vendor/libgit2/src/win32/path_w32.c +101 -7
- data/vendor/libgit2/src/win32/path_w32.h +18 -0
- data/vendor/libgit2/src/win32/posix_w32.c +24 -43
- data/vendor/libgit2/src/win32/w32_buffer.c +2 -2
- data/vendor/libgit2/src/win32/w32_crtdbg_stacktrace.c +96 -2
- data/vendor/libgit2/src/win32/w32_crtdbg_stacktrace.h +28 -75
- data/vendor/libgit2/src/win32/w32_stack.c +2 -2
- data/vendor/libgit2/src/win32/w32_util.c +1 -69
- data/vendor/libgit2/src/win32/w32_util.h +1 -19
- data/vendor/libgit2/src/worktree.c +75 -54
- data/vendor/libgit2/src/worktree.h +2 -0
- data/vendor/libgit2/src/xdiff/xdiffi.c +7 -5
- data/vendor/libgit2/src/xdiff/xhistogram.c +1 -1
- data/vendor/libgit2/src/xdiff/xmerge.c +15 -15
- data/vendor/libgit2/src/zstream.c +4 -4
- metadata +33 -7
- data/vendor/libgit2/src/config_file.h +0 -73
- data/vendor/libgit2/src/streams/curl.c +0 -385
@@ -9,6 +9,8 @@
|
|
9
9
|
|
10
10
|
#include "common.h"
|
11
11
|
#include "types.h"
|
12
|
+
#include "strarray.h"
|
13
|
+
#include "diff.h"
|
12
14
|
|
13
15
|
/**
|
14
16
|
* @file git2/status.h
|
@@ -58,7 +60,7 @@ typedef enum {
|
|
58
60
|
*
|
59
61
|
* `payload` is the value you passed to the foreach function as payload.
|
60
62
|
*/
|
61
|
-
typedef int (
|
63
|
+
typedef int GIT_CALLBACK(git_status_cb)(
|
62
64
|
const char *path, unsigned int status_flags, void *payload);
|
63
65
|
|
64
66
|
/**
|
@@ -189,11 +191,13 @@ typedef struct {
|
|
189
191
|
#define GIT_STATUS_OPTIONS_INIT {GIT_STATUS_OPTIONS_VERSION}
|
190
192
|
|
191
193
|
/**
|
194
|
+
* Initialize git_status_options structure
|
195
|
+
*
|
192
196
|
* Initializes a `git_status_options` with default values. Equivalent to
|
193
|
-
* creating an instance with GIT_STATUS_OPTIONS_INIT
|
197
|
+
* creating an instance with `GIT_STATUS_OPTIONS_INIT`.
|
194
198
|
*
|
195
|
-
* @param opts The `git_status_options`
|
196
|
-
* @param version
|
199
|
+
* @param opts The `git_status_options` struct to initialize.
|
200
|
+
* @param version The struct version; pass `GIT_STATUS_OPTIONS_VERSION`.
|
197
201
|
* @return Zero on success; -1 on failure.
|
198
202
|
*/
|
199
203
|
GIT_EXTERN(int) git_status_init_options(
|
@@ -115,16 +115,15 @@ typedef enum {
|
|
115
115
|
* @param payload value you passed to the foreach function as payload
|
116
116
|
* @return 0 on success or error code
|
117
117
|
*/
|
118
|
-
typedef int (
|
118
|
+
typedef int GIT_CALLBACK(git_submodule_cb)(
|
119
119
|
git_submodule *sm, const char *name, void *payload);
|
120
120
|
|
121
121
|
/**
|
122
122
|
* Submodule update options structure
|
123
123
|
*
|
124
|
-
*
|
125
|
-
*
|
124
|
+
* Initialize with `GIT_SUBMODULE_UPDATE_OPTIONS_INIT`. Alternatively, you can
|
125
|
+
* use `git_submodule_update_init_options`.
|
126
126
|
*
|
127
|
-
* git_submodule_update_options opts = GIT_SUBMODULE_UPDATE_OPTIONS_INIT;
|
128
127
|
*/
|
129
128
|
typedef struct git_submodule_update_options {
|
130
129
|
unsigned int version;
|
@@ -134,7 +133,7 @@ typedef struct git_submodule_update_options {
|
|
134
133
|
* checkout, set the `checkout_strategy` to
|
135
134
|
* `GIT_CHECKOUT_NONE`. Generally you will want the use
|
136
135
|
* GIT_CHECKOUT_SAFE to update files in the working
|
137
|
-
* directory.
|
136
|
+
* directory.
|
138
137
|
*/
|
139
138
|
git_checkout_options checkout_opts;
|
140
139
|
|
@@ -160,11 +159,13 @@ typedef struct git_submodule_update_options {
|
|
160
159
|
GIT_FETCH_OPTIONS_INIT, 1 }
|
161
160
|
|
162
161
|
/**
|
163
|
-
*
|
164
|
-
* Equivalent to creating an instance with GIT_SUBMODULE_UPDATE_OPTIONS_INIT.
|
162
|
+
* Initialize git_submodule_update_options structure
|
165
163
|
*
|
166
|
-
*
|
167
|
-
*
|
164
|
+
* Initializes a `git_submodule_update_options` with default values. Equivalent to
|
165
|
+
* creating an instance with `GIT_SUBMODULE_UPDATE_OPTIONS_INIT`.
|
166
|
+
*
|
167
|
+
* @param opts The `git_submodule_update_options` struct to initialize.
|
168
|
+
* @param version The struct version; pass `GIT_SUBMODULE_UPDATE_OPTIONS_VERSION`.
|
168
169
|
* @return Zero on success; -1 on failure.
|
169
170
|
*/
|
170
171
|
GIT_EXTERN(int) git_submodule_update_init_options(
|
@@ -186,7 +187,7 @@ GIT_EXTERN(int) git_submodule_update_init_options(
|
|
186
187
|
* function works as though GIT_SUBMODULE_UPDATE_OPTIONS_INIT was passed.
|
187
188
|
* @return 0 on success, any non-zero return value from a callback
|
188
189
|
* function, or a negative value to indicate an error (use
|
189
|
-
* `
|
190
|
+
* `git_error_last` for a detailed error message).
|
190
191
|
*/
|
191
192
|
GIT_EXTERN(int) git_submodule_update(git_submodule *submodule, int init, git_submodule_update_options *options);
|
192
193
|
|
@@ -0,0 +1,101 @@
|
|
1
|
+
/*
|
2
|
+
* Copyright (C) the libgit2 contributors. All rights reserved.
|
3
|
+
*
|
4
|
+
* This file is part of libgit2, distributed under the GNU GPL v2 with
|
5
|
+
* a Linking Exception. For full terms see the included COPYING file.
|
6
|
+
*/
|
7
|
+
|
8
|
+
#ifndef INCLUDE_sys_git_alloc_h__
|
9
|
+
#define INCLUDE_sys_git_alloc_h__
|
10
|
+
|
11
|
+
#include "git2/common.h"
|
12
|
+
|
13
|
+
GIT_BEGIN_DECL
|
14
|
+
|
15
|
+
/**
|
16
|
+
* An instance for a custom memory allocator
|
17
|
+
*
|
18
|
+
* Setting the pointers of this structure allows the developer to implement
|
19
|
+
* custom memory allocators. The global memory allocator can be set by using
|
20
|
+
* "GIT_OPT_SET_ALLOCATOR" with the `git_libgit2_opts` function. Keep in mind
|
21
|
+
* that all fields need to be set to a proper function.
|
22
|
+
*/
|
23
|
+
typedef struct {
|
24
|
+
/* Allocate `n` bytes of memory */
|
25
|
+
void * GIT_CALLBACK(gmalloc)(size_t n, const char *file, int line);
|
26
|
+
|
27
|
+
/*
|
28
|
+
* Allocate memory for an array of `nelem` elements, where each element
|
29
|
+
* has a size of `elsize`. Returned memory shall be initialized to
|
30
|
+
* all-zeroes
|
31
|
+
*/
|
32
|
+
void * GIT_CALLBACK(gcalloc)(size_t nelem, size_t elsize, const char *file, int line);
|
33
|
+
|
34
|
+
/* Allocate memory for the string `str` and duplicate its contents. */
|
35
|
+
char * GIT_CALLBACK(gstrdup)(const char *str, const char *file, int line);
|
36
|
+
|
37
|
+
/*
|
38
|
+
* Equivalent to the `gstrdup` function, but only duplicating at most
|
39
|
+
* `n + 1` bytes
|
40
|
+
*/
|
41
|
+
char * GIT_CALLBACK(gstrndup)(const char *str, size_t n, const char *file, int line);
|
42
|
+
|
43
|
+
/*
|
44
|
+
* Equivalent to `gstrndup`, but will always duplicate exactly `n` bytes
|
45
|
+
* of `str`. Thus, out of bounds reads at `str` may happen.
|
46
|
+
*/
|
47
|
+
char * GIT_CALLBACK(gsubstrdup)(const char *str, size_t n, const char *file, int line);
|
48
|
+
|
49
|
+
/*
|
50
|
+
* This function shall deallocate the old object `ptr` and return a
|
51
|
+
* pointer to a new object that has the size specified by `size`. In
|
52
|
+
* case `ptr` is `NULL`, a new array shall be allocated.
|
53
|
+
*/
|
54
|
+
void * GIT_CALLBACK(grealloc)(void *ptr, size_t size, const char *file, int line);
|
55
|
+
|
56
|
+
/*
|
57
|
+
* This function shall be equivalent to `grealloc`, but allocating
|
58
|
+
* `neleme * elsize` bytes.
|
59
|
+
*/
|
60
|
+
void * GIT_CALLBACK(greallocarray)(void *ptr, size_t nelem, size_t elsize, const char *file, int line);
|
61
|
+
|
62
|
+
/*
|
63
|
+
* This function shall allocate a new array of `nelem` elements, where
|
64
|
+
* each element has a size of `elsize` bytes.
|
65
|
+
*/
|
66
|
+
void * GIT_CALLBACK(gmallocarray)(size_t nelem, size_t elsize, const char *file, int line);
|
67
|
+
|
68
|
+
/*
|
69
|
+
* This function shall free the memory pointed to by `ptr`. In case
|
70
|
+
* `ptr` is `NULL`, this shall be a no-op.
|
71
|
+
*/
|
72
|
+
void GIT_CALLBACK(gfree)(void *ptr);
|
73
|
+
} git_allocator;
|
74
|
+
|
75
|
+
/**
|
76
|
+
* Initialize the allocator structure to use the `stdalloc` pointer.
|
77
|
+
*
|
78
|
+
* Set up the structure so that all of its members are using the standard
|
79
|
+
* "stdalloc" allocator functions. The structure can then be used with
|
80
|
+
* `git_allocator_setup`.
|
81
|
+
*
|
82
|
+
* @param allocator The allocator that is to be initialized.
|
83
|
+
* @return An error code or 0.
|
84
|
+
*/
|
85
|
+
int git_stdalloc_init_allocator(git_allocator *allocator);
|
86
|
+
|
87
|
+
/**
|
88
|
+
* Initialize the allocator structure to use the `crtdbg` pointer.
|
89
|
+
*
|
90
|
+
* Set up the structure so that all of its members are using the "crtdbg"
|
91
|
+
* allocator functions. Note that this allocator is only available on Windows
|
92
|
+
* platforms and only if libgit2 is being compiled with "-DMSVC_CRTDBG".
|
93
|
+
*
|
94
|
+
* @param allocator The allocator that is to be initialized.
|
95
|
+
* @return An error code or 0.
|
96
|
+
*/
|
97
|
+
int git_win32_crtdbg_init_allocator(git_allocator *allocator);
|
98
|
+
|
99
|
+
GIT_END_DECL
|
100
|
+
|
101
|
+
#endif
|
@@ -50,7 +50,7 @@ GIT_EXTERN(int) git_commit_create_from_ids(
|
|
50
50
|
* along with the user supplied payload. This should return a git_oid of
|
51
51
|
* the next parent or NULL if all parents have been provided.
|
52
52
|
*/
|
53
|
-
typedef const git_oid *(
|
53
|
+
typedef const git_oid * GIT_CALLBACK(git_commit_parent_callback)(size_t idx, void *payload);
|
54
54
|
|
55
55
|
/**
|
56
56
|
* Create a new commit in the repository with an callback to supply parents.
|
@@ -39,12 +39,12 @@ struct git_config_iterator {
|
|
39
39
|
* Return the current entry and advance the iterator. The
|
40
40
|
* memory belongs to the library.
|
41
41
|
*/
|
42
|
-
int (
|
42
|
+
int GIT_CALLBACK(next)(git_config_entry **entry, git_config_iterator *iter);
|
43
43
|
|
44
44
|
/**
|
45
45
|
* Free the iterator
|
46
46
|
*/
|
47
|
-
void (
|
47
|
+
void GIT_CALLBACK(free)(git_config_iterator *iter);
|
48
48
|
};
|
49
49
|
|
50
50
|
/**
|
@@ -58,15 +58,15 @@ struct git_config_backend {
|
|
58
58
|
struct git_config *cfg;
|
59
59
|
|
60
60
|
/* Open means open the file/database and parse if necessary */
|
61
|
-
int (
|
62
|
-
int (
|
63
|
-
int (
|
64
|
-
int (
|
65
|
-
int (
|
66
|
-
int (
|
67
|
-
int (
|
61
|
+
int GIT_CALLBACK(open)(struct git_config_backend *, git_config_level_t level, const git_repository *repo);
|
62
|
+
int GIT_CALLBACK(get)(struct git_config_backend *, const char *key, git_config_entry **entry);
|
63
|
+
int GIT_CALLBACK(set)(struct git_config_backend *, const char *key, const char *value);
|
64
|
+
int GIT_CALLBACK(set_multivar)(git_config_backend *cfg, const char *name, const char *regexp, const char *value);
|
65
|
+
int GIT_CALLBACK(del)(struct git_config_backend *, const char *key);
|
66
|
+
int GIT_CALLBACK(del_multivar)(struct git_config_backend *, const char *key, const char *regexp);
|
67
|
+
int GIT_CALLBACK(iterator)(git_config_iterator **, struct git_config_backend *);
|
68
68
|
/** Produce a read-only version of this backend */
|
69
|
-
int (
|
69
|
+
int GIT_CALLBACK(snapshot)(struct git_config_backend **, struct git_config_backend *);
|
70
70
|
/**
|
71
71
|
* Lock this backend.
|
72
72
|
*
|
@@ -74,14 +74,14 @@ struct git_config_backend {
|
|
74
74
|
* backend. Any updates must not be visible to any other
|
75
75
|
* readers.
|
76
76
|
*/
|
77
|
-
int (
|
77
|
+
int GIT_CALLBACK(lock)(struct git_config_backend *);
|
78
78
|
/**
|
79
79
|
* Unlock the data store backing this backend. If success is
|
80
80
|
* true, the changes should be committed, otherwise rolled
|
81
81
|
* back.
|
82
82
|
*/
|
83
|
-
int (
|
84
|
-
void (
|
83
|
+
int GIT_CALLBACK(unlock)(struct git_config_backend *, int success);
|
84
|
+
void GIT_CALLBACK(free)(struct git_config_backend *);
|
85
85
|
};
|
86
86
|
#define GIT_CONFIG_BACKEND_VERSION 1
|
87
87
|
#define GIT_CONFIG_BACKEND_INIT {GIT_CONFIG_BACKEND_VERSION}
|
@@ -138,7 +138,7 @@ GIT_EXTERN(uint32_t) git_filter_source_flags(const git_filter_source *src);
|
|
138
138
|
* initialization operations (in case libgit2 is being used in a way that
|
139
139
|
* doesn't need the filter).
|
140
140
|
*/
|
141
|
-
typedef int (
|
141
|
+
typedef int GIT_CALLBACK(git_filter_init_fn)(git_filter *self);
|
142
142
|
|
143
143
|
/**
|
144
144
|
* Shutdown callback on filter
|
@@ -150,7 +150,7 @@ typedef int (*git_filter_init_fn)(git_filter *self);
|
|
150
150
|
*
|
151
151
|
* Typically this function will free the `git_filter` object itself.
|
152
152
|
*/
|
153
|
-
typedef void (
|
153
|
+
typedef void GIT_CALLBACK(git_filter_shutdown_fn)(git_filter *self);
|
154
154
|
|
155
155
|
/**
|
156
156
|
* Callback to decide if a given source needs this filter
|
@@ -172,7 +172,7 @@ typedef void (*git_filter_shutdown_fn)(git_filter *self);
|
|
172
172
|
* callback can use it. If a filter allocates and assigns a value to the
|
173
173
|
* `payload`, it will need a `cleanup` callback to free the payload.
|
174
174
|
*/
|
175
|
-
typedef int (
|
175
|
+
typedef int GIT_CALLBACK(git_filter_check_fn)(
|
176
176
|
git_filter *self,
|
177
177
|
void **payload, /* points to NULL ptr on entry, may be set */
|
178
178
|
const git_filter_source *src,
|
@@ -190,14 +190,14 @@ typedef int (*git_filter_check_fn)(
|
|
190
190
|
* The `payload` value will refer to any payload that was set by the
|
191
191
|
* `check` callback. It may be read from or written to as needed.
|
192
192
|
*/
|
193
|
-
typedef int (
|
193
|
+
typedef int GIT_CALLBACK(git_filter_apply_fn)(
|
194
194
|
git_filter *self,
|
195
195
|
void **payload, /* may be read and/or set */
|
196
196
|
git_buf *to,
|
197
197
|
const git_buf *from,
|
198
198
|
const git_filter_source *src);
|
199
199
|
|
200
|
-
typedef int (
|
200
|
+
typedef int GIT_CALLBACK(git_filter_stream_fn)(
|
201
201
|
git_writestream **out,
|
202
202
|
git_filter *self,
|
203
203
|
void **payload,
|
@@ -212,7 +212,7 @@ typedef int (*git_filter_stream_fn)(
|
|
212
212
|
* allocated a `payload` to keep per-source filter state, use this
|
213
213
|
* callback to free that payload and release resources as required.
|
214
214
|
*/
|
215
|
-
typedef void (
|
215
|
+
typedef void GIT_CALLBACK(git_filter_cleanup_fn)(
|
216
216
|
git_filter *self,
|
217
217
|
void *payload);
|
218
218
|
|
@@ -23,61 +23,61 @@
|
|
23
23
|
GIT_BEGIN_DECL
|
24
24
|
|
25
25
|
/**
|
26
|
-
*
|
26
|
+
* Instantiate a new mempack backend.
|
27
27
|
*
|
28
|
-
*
|
29
|
-
*
|
28
|
+
* The backend must be added to an existing ODB with the highest
|
29
|
+
* priority.
|
30
30
|
*
|
31
|
-
*
|
32
|
-
*
|
33
|
-
*
|
31
|
+
* git_mempack_new(&mempacker);
|
32
|
+
* git_repository_odb(&odb, repository);
|
33
|
+
* git_odb_add_backend(odb, mempacker, 999);
|
34
34
|
*
|
35
|
-
*
|
36
|
-
*
|
37
|
-
*
|
35
|
+
* Once the backend has been loaded, all writes to the ODB will
|
36
|
+
* instead be queued in memory, and can be finalized with
|
37
|
+
* `git_mempack_dump`.
|
38
38
|
*
|
39
|
-
*
|
40
|
-
*
|
39
|
+
* Subsequent reads will also be served from the in-memory store
|
40
|
+
* to ensure consistency, until the memory store is dumped.
|
41
41
|
*
|
42
|
-
*
|
43
|
-
*
|
42
|
+
* @param out Pointer where to store the ODB backend
|
43
|
+
* @return 0 on success; error code otherwise
|
44
44
|
*/
|
45
45
|
GIT_EXTERN(int) git_mempack_new(git_odb_backend **out);
|
46
46
|
|
47
47
|
/**
|
48
|
-
*
|
48
|
+
* Dump all the queued in-memory writes to a packfile.
|
49
49
|
*
|
50
|
-
*
|
51
|
-
*
|
52
|
-
*
|
53
|
-
*
|
54
|
-
*
|
50
|
+
* The contents of the packfile will be stored in the given buffer.
|
51
|
+
* It is the caller's responsibility to ensure that the generated
|
52
|
+
* packfile is available to the repository (e.g. by writing it
|
53
|
+
* to disk, or doing something crazy like distributing it across
|
54
|
+
* several copies of the repository over a network).
|
55
55
|
*
|
56
|
-
*
|
57
|
-
*
|
56
|
+
* Once the generated packfile is available to the repository,
|
57
|
+
* call `git_mempack_reset` to cleanup the memory store.
|
58
58
|
*
|
59
|
-
*
|
60
|
-
*
|
61
|
-
*
|
59
|
+
* Calling `git_mempack_reset` before the packfile has been
|
60
|
+
* written to disk will result in an inconsistent repository
|
61
|
+
* (the objects in the memory store won't be accessible).
|
62
62
|
*
|
63
|
-
*
|
64
|
-
*
|
65
|
-
*
|
66
|
-
*
|
63
|
+
* @param pack Buffer where to store the raw packfile
|
64
|
+
* @param repo The active repository where the backend is loaded
|
65
|
+
* @param backend The mempack backend
|
66
|
+
* @return 0 on success; error code otherwise
|
67
67
|
*/
|
68
68
|
GIT_EXTERN(int) git_mempack_dump(git_buf *pack, git_repository *repo, git_odb_backend *backend);
|
69
69
|
|
70
70
|
/**
|
71
|
-
*
|
71
|
+
* Reset the memory packer by clearing all the queued objects.
|
72
72
|
*
|
73
|
-
*
|
74
|
-
*
|
73
|
+
* This assumes that `git_mempack_dump` has been called before to
|
74
|
+
* store all the queued objects into a single packfile.
|
75
75
|
*
|
76
|
-
*
|
77
|
-
*
|
78
|
-
*
|
76
|
+
* Alternatively, call `reset` without a previous dump to "undo"
|
77
|
+
* all the recently written objects, giving transaction-like
|
78
|
+
* semantics to the Git repository.
|
79
79
|
*
|
80
|
-
*
|
80
|
+
* @param backend The mempack backend
|
81
81
|
*/
|
82
82
|
GIT_EXTERN(void) git_mempack_reset(git_odb_backend *backend);
|
83
83
|
|
@@ -7,10 +7,15 @@
|
|
7
7
|
#ifndef INCLUDE_sys_git_merge_h__
|
8
8
|
#define INCLUDE_sys_git_merge_h__
|
9
9
|
|
10
|
+
#include "git2/common.h"
|
11
|
+
#include "git2/types.h"
|
12
|
+
#include "git2/index.h"
|
13
|
+
#include "git2/merge.h"
|
14
|
+
|
10
15
|
/**
|
11
16
|
* @file git2/sys/merge.h
|
12
17
|
* @brief Git merge driver backend and plugin routines
|
13
|
-
* @defgroup
|
18
|
+
* @defgroup git_merge Git merge driver APIs
|
14
19
|
* @ingroup Git
|
15
20
|
* @{
|
16
21
|
*/
|
@@ -68,7 +73,7 @@ GIT_EXTERN(const git_merge_file_options *) git_merge_driver_source_file_options(
|
|
68
73
|
* initialization operations (in case libgit2 is being used in a way that
|
69
74
|
* doesn't need the merge driver).
|
70
75
|
*/
|
71
|
-
typedef int (
|
76
|
+
typedef int GIT_CALLBACK(git_merge_driver_init_fn)(git_merge_driver *self);
|
72
77
|
|
73
78
|
/**
|
74
79
|
* Shutdown callback on merge driver
|
@@ -80,7 +85,7 @@ typedef int (*git_merge_driver_init_fn)(git_merge_driver *self);
|
|
80
85
|
*
|
81
86
|
* Typically this function will free the `git_merge_driver` object itself.
|
82
87
|
*/
|
83
|
-
typedef void (
|
88
|
+
typedef void GIT_CALLBACK(git_merge_driver_shutdown_fn)(git_merge_driver *self);
|
84
89
|
|
85
90
|
/**
|
86
91
|
* Callback to perform the merge.
|
@@ -100,7 +105,7 @@ typedef void (*git_merge_driver_shutdown_fn)(git_merge_driver *self);
|
|
100
105
|
*
|
101
106
|
* The `src` contains the data about the file to be merged.
|
102
107
|
*/
|
103
|
-
typedef int (
|
108
|
+
typedef int GIT_CALLBACK(git_merge_driver_apply_fn)(
|
104
109
|
git_merge_driver *self,
|
105
110
|
const char **path_out,
|
106
111
|
uint32_t *mode_out,
|