rugged 1.3.1 → 1.9.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +4 -4
- data/README.md +34 -2
- data/ext/rugged/extconf.rb +6 -3
- data/ext/rugged/rugged.c +16 -0
- data/ext/rugged/rugged.h +4 -0
- data/ext/rugged/rugged_allocator.c +0 -54
- data/ext/rugged/rugged_blame.c +2 -0
- data/ext/rugged/rugged_blob.c +3 -0
- data/ext/rugged/rugged_commit.c +1 -0
- data/ext/rugged/rugged_config.c +9 -2
- data/ext/rugged/rugged_diff.c +1 -0
- data/ext/rugged/rugged_index.c +2 -0
- data/ext/rugged/rugged_patch.c +1 -0
- data/ext/rugged/rugged_rebase.c +1 -0
- data/ext/rugged/rugged_reference.c +1 -0
- data/ext/rugged/rugged_remote.c +28 -10
- data/ext/rugged/rugged_repo.c +7 -9
- data/ext/rugged/rugged_revwalk.c +5 -1
- data/ext/rugged/rugged_settings.c +5 -0
- data/ext/rugged/rugged_submodule.c +1 -0
- data/ext/rugged/rugged_tag.c +1 -0
- data/ext/rugged/rugged_tree.c +4 -0
- data/lib/rugged/index.rb +1 -1
- data/lib/rugged/tree.rb +5 -1
- data/lib/rugged/version.rb +1 -1
- data/vendor/libgit2/AUTHORS +1 -0
- data/vendor/libgit2/CMakeLists.txt +141 -289
- data/vendor/libgit2/COPYING +301 -20
- data/vendor/libgit2/cmake/AddCFlagIfSupported.cmake +21 -21
- data/vendor/libgit2/cmake/AddClarTest.cmake +7 -0
- data/vendor/libgit2/cmake/CheckPrototypeDefinitionSafe.cmake +16 -0
- data/vendor/libgit2/cmake/DefaultCFlags.cmake +154 -0
- data/vendor/libgit2/cmake/EnableWarnings.cmake +13 -13
- data/vendor/libgit2/cmake/ExperimentalFeatures.cmake +23 -0
- data/vendor/libgit2/cmake/FindCoreFoundation.cmake +13 -13
- data/vendor/libgit2/cmake/FindGSSAPI.cmake +171 -287
- data/vendor/libgit2/cmake/FindGSSFramework.cmake +13 -13
- data/vendor/libgit2/cmake/FindHTTP_Parser.cmake +17 -17
- data/vendor/libgit2/cmake/FindIntlIconv.cmake +51 -0
- data/vendor/libgit2/cmake/FindLLHTTP.cmake +39 -0
- data/vendor/libgit2/cmake/FindLibSSH2.cmake +5 -5
- data/vendor/libgit2/cmake/FindPCRE.cmake +12 -13
- data/vendor/libgit2/cmake/FindPCRE2.cmake +12 -12
- data/vendor/libgit2/cmake/FindPkgLibraries.cmake +19 -19
- data/vendor/libgit2/cmake/FindSecurity.cmake +14 -14
- data/vendor/libgit2/cmake/FindStatNsec.cmake +12 -18
- data/vendor/libgit2/cmake/Findfutimens.cmake +8 -8
- data/vendor/libgit2/cmake/FindmbedTLS.cmake +63 -70
- data/vendor/libgit2/cmake/IdeSplitSources.cmake +18 -18
- data/vendor/libgit2/cmake/PkgBuildConfig.cmake +60 -60
- data/vendor/libgit2/cmake/SanitizeBool.cmake +20 -20
- data/vendor/libgit2/cmake/SelectGSSAPI.cmake +37 -37
- data/vendor/libgit2/cmake/SelectHTTPParser.cmake +34 -0
- data/vendor/libgit2/cmake/SelectHTTPSBackend.cmake +129 -101
- data/vendor/libgit2/cmake/SelectHashes.cmake +113 -54
- data/vendor/libgit2/cmake/SelectRegex.cmake +56 -0
- data/vendor/libgit2/cmake/SelectSSH.cmake +46 -0
- data/vendor/libgit2/cmake/SelectXdiff.cmake +9 -0
- data/vendor/libgit2/cmake/SelectZlib.cmake +38 -0
- data/vendor/libgit2/deps/chromium-zlib/CMakeLists.txt +6 -6
- data/vendor/libgit2/deps/llhttp/CMakeLists.txt +8 -0
- data/vendor/libgit2/deps/llhttp/LICENSE-MIT +22 -0
- data/vendor/libgit2/deps/llhttp/api.c +510 -0
- data/vendor/libgit2/deps/llhttp/http.c +170 -0
- data/vendor/libgit2/deps/llhttp/llhttp.c +10168 -0
- data/vendor/libgit2/deps/llhttp/llhttp.h +897 -0
- data/vendor/libgit2/deps/ntlmclient/CMakeLists.txt +33 -31
- data/vendor/libgit2/deps/ntlmclient/crypt_builtin_md4.c +311 -0
- data/vendor/libgit2/deps/ntlmclient/crypt_commoncrypto.c +2 -1
- data/vendor/libgit2/deps/ntlmclient/crypt_mbedtls.c +0 -20
- data/vendor/libgit2/deps/ntlmclient/crypt_openssl.c +7 -5
- data/vendor/libgit2/deps/ntlmclient/ntlm.c +25 -25
- data/vendor/libgit2/deps/ntlmclient/ntlm.h +4 -4
- data/vendor/libgit2/deps/ntlmclient/ntlmclient.h +2 -2
- data/vendor/libgit2/deps/ntlmclient/unicode_builtin.c +5 -4
- data/vendor/libgit2/deps/ntlmclient/unicode_iconv.c +2 -1
- data/vendor/libgit2/deps/ntlmclient/utf8.h +1176 -721
- data/vendor/libgit2/deps/ntlmclient/util.h +11 -0
- data/vendor/libgit2/deps/pcre/CMakeLists.txt +89 -88
- data/vendor/libgit2/deps/pcre/LICENCE +5 -5
- data/vendor/libgit2/deps/pcre/pcre.h +2 -2
- data/vendor/libgit2/deps/pcre/pcre_compile.c +6 -3
- data/vendor/libgit2/deps/pcre/pcre_exec.c +2 -2
- data/vendor/libgit2/deps/winhttp/CMakeLists.txt +14 -16
- data/vendor/libgit2/deps/xdiff/CMakeLists.txt +28 -0
- data/vendor/libgit2/deps/xdiff/git-xdiff.h +56 -0
- data/vendor/libgit2/{src → deps}/xdiff/xdiff.h +15 -15
- data/vendor/libgit2/{src → deps}/xdiff/xdiffi.c +152 -125
- data/vendor/libgit2/{src → deps}/xdiff/xdiffi.h +2 -4
- data/vendor/libgit2/{src → deps}/xdiff/xemit.c +26 -10
- data/vendor/libgit2/{src → deps}/xdiff/xhistogram.c +92 -94
- data/vendor/libgit2/{src → deps}/xdiff/xinclude.h +1 -12
- data/vendor/libgit2/{src → deps}/xdiff/xmacros.h +18 -1
- data/vendor/libgit2/{src → deps}/xdiff/xmerge.c +126 -137
- data/vendor/libgit2/{src → deps}/xdiff/xpatience.c +26 -46
- data/vendor/libgit2/{src → deps}/xdiff/xprepare.c +24 -46
- data/vendor/libgit2/{src → deps}/xdiff/xutils.c +36 -8
- data/vendor/libgit2/{src → deps}/xdiff/xutils.h +2 -1
- data/vendor/libgit2/deps/zlib/CMakeLists.txt +6 -1
- data/vendor/libgit2/deps/zlib/LICENSE +22 -0
- data/vendor/libgit2/deps/zlib/adler32.c +7 -22
- data/vendor/libgit2/deps/zlib/crc32.c +931 -317
- data/vendor/libgit2/deps/zlib/crc32.h +9441 -436
- data/vendor/libgit2/deps/zlib/deflate.c +428 -453
- data/vendor/libgit2/deps/zlib/deflate.h +51 -23
- data/vendor/libgit2/deps/zlib/gzguts.h +15 -19
- data/vendor/libgit2/deps/zlib/infback.c +19 -31
- data/vendor/libgit2/deps/zlib/inffast.c +15 -18
- data/vendor/libgit2/deps/zlib/inffast.h +1 -1
- data/vendor/libgit2/deps/zlib/inflate.c +75 -110
- data/vendor/libgit2/deps/zlib/inflate.h +3 -2
- data/vendor/libgit2/deps/zlib/inftrees.c +6 -11
- data/vendor/libgit2/deps/zlib/inftrees.h +6 -6
- data/vendor/libgit2/deps/zlib/trees.c +294 -380
- data/vendor/libgit2/deps/zlib/zconf.h +23 -14
- data/vendor/libgit2/deps/zlib/zlib.h +310 -284
- data/vendor/libgit2/deps/zlib/zutil.c +20 -46
- data/vendor/libgit2/deps/zlib/zutil.h +24 -41
- data/vendor/libgit2/include/git2/annotated_commit.h +12 -5
- data/vendor/libgit2/include/git2/apply.h +43 -8
- data/vendor/libgit2/include/git2/attr.h +28 -6
- data/vendor/libgit2/include/git2/blame.h +137 -29
- data/vendor/libgit2/include/git2/blob.h +85 -29
- data/vendor/libgit2/include/git2/branch.h +25 -16
- data/vendor/libgit2/include/git2/buffer.h +24 -82
- data/vendor/libgit2/include/git2/cert.h +4 -3
- data/vendor/libgit2/include/git2/checkout.h +88 -34
- data/vendor/libgit2/include/git2/cherrypick.h +10 -3
- data/vendor/libgit2/include/git2/clone.h +28 -12
- data/vendor/libgit2/include/git2/commit.h +134 -3
- data/vendor/libgit2/include/git2/common.h +172 -59
- data/vendor/libgit2/include/git2/config.h +118 -32
- data/vendor/libgit2/include/git2/credential.h +32 -3
- data/vendor/libgit2/include/git2/credential_helpers.h +2 -0
- data/vendor/libgit2/include/git2/deprecated.h +141 -3
- data/vendor/libgit2/include/git2/describe.h +20 -3
- data/vendor/libgit2/include/git2/diff.h +95 -19
- data/vendor/libgit2/include/git2/email.h +10 -30
- data/vendor/libgit2/include/git2/errors.h +51 -61
- data/vendor/libgit2/include/git2/experimental.h +20 -0
- data/vendor/libgit2/include/git2/filter.h +21 -9
- data/vendor/libgit2/include/git2/global.h +8 -1
- data/vendor/libgit2/include/git2/graph.h +4 -2
- data/vendor/libgit2/include/git2/ignore.h +11 -1
- data/vendor/libgit2/include/git2/index.h +111 -11
- data/vendor/libgit2/include/git2/indexer.h +67 -2
- data/vendor/libgit2/include/git2/mailmap.h +7 -1
- data/vendor/libgit2/include/git2/merge.h +70 -5
- data/vendor/libgit2/include/git2/message.h +4 -2
- data/vendor/libgit2/include/git2/net.h +3 -1
- data/vendor/libgit2/include/git2/notes.h +9 -6
- data/vendor/libgit2/include/git2/object.h +57 -7
- data/vendor/libgit2/include/git2/odb.h +156 -33
- data/vendor/libgit2/include/git2/odb_backend.h +132 -16
- data/vendor/libgit2/include/git2/oid.h +116 -17
- data/vendor/libgit2/include/git2/oidarray.h +7 -1
- data/vendor/libgit2/include/git2/pack.h +37 -9
- data/vendor/libgit2/include/git2/patch.h +10 -3
- data/vendor/libgit2/include/git2/pathspec.h +10 -1
- data/vendor/libgit2/include/git2/proxy.h +11 -1
- data/vendor/libgit2/include/git2/rebase.h +18 -7
- data/vendor/libgit2/include/git2/refdb.h +5 -2
- data/vendor/libgit2/include/git2/reflog.h +4 -3
- data/vendor/libgit2/include/git2/refs.h +11 -8
- data/vendor/libgit2/include/git2/refspec.h +14 -4
- data/vendor/libgit2/include/git2/remote.h +295 -54
- data/vendor/libgit2/include/git2/repository.h +95 -25
- data/vendor/libgit2/include/git2/reset.h +18 -5
- data/vendor/libgit2/include/git2/revert.h +9 -4
- data/vendor/libgit2/include/git2/revparse.h +4 -4
- data/vendor/libgit2/include/git2/revwalk.h +7 -3
- data/vendor/libgit2/include/git2/signature.h +47 -2
- data/vendor/libgit2/include/git2/stash.h +78 -10
- data/vendor/libgit2/include/git2/status.h +24 -11
- data/vendor/libgit2/include/git2/stdint.h +87 -85
- data/vendor/libgit2/include/git2/strarray.h +2 -16
- data/vendor/libgit2/include/git2/submodule.h +27 -11
- data/vendor/libgit2/include/git2/sys/alloc.h +12 -34
- data/vendor/libgit2/include/git2/sys/commit.h +77 -3
- data/vendor/libgit2/include/git2/sys/commit_graph.h +110 -59
- data/vendor/libgit2/include/git2/sys/config.h +80 -4
- data/vendor/libgit2/include/git2/sys/credential.h +4 -3
- data/vendor/libgit2/include/git2/sys/diff.h +21 -1
- data/vendor/libgit2/include/git2/sys/email.h +7 -0
- data/vendor/libgit2/include/git2/sys/errors.h +76 -0
- data/vendor/libgit2/include/git2/sys/filter.h +66 -3
- data/vendor/libgit2/include/git2/sys/hashsig.h +11 -0
- data/vendor/libgit2/include/git2/sys/index.h +3 -2
- data/vendor/libgit2/include/git2/sys/mempack.h +32 -2
- data/vendor/libgit2/include/git2/sys/merge.h +55 -7
- data/vendor/libgit2/include/git2/sys/midx.h +47 -4
- data/vendor/libgit2/include/git2/sys/odb_backend.h +10 -9
- data/vendor/libgit2/include/git2/sys/openssl.h +8 -1
- data/vendor/libgit2/include/git2/sys/path.h +12 -1
- data/vendor/libgit2/include/git2/sys/refdb_backend.h +40 -36
- data/vendor/libgit2/include/git2/sys/refs.h +3 -2
- data/vendor/libgit2/include/git2/sys/remote.h +53 -0
- data/vendor/libgit2/include/git2/sys/repository.h +63 -3
- data/vendor/libgit2/include/git2/sys/stream.h +26 -3
- data/vendor/libgit2/include/git2/sys/transport.h +87 -41
- data/vendor/libgit2/include/git2/tag.h +4 -1
- data/vendor/libgit2/include/git2/trace.h +9 -3
- data/vendor/libgit2/include/git2/transaction.h +3 -2
- data/vendor/libgit2/include/git2/transport.h +11 -3
- data/vendor/libgit2/include/git2/tree.h +20 -8
- data/vendor/libgit2/include/git2/types.h +26 -10
- data/vendor/libgit2/include/git2/version.h +63 -6
- data/vendor/libgit2/include/git2/worktree.h +30 -8
- data/vendor/libgit2/include/git2.h +1 -0
- data/vendor/libgit2/src/CMakeLists.txt +203 -420
- data/vendor/libgit2/src/README.md +12 -0
- data/vendor/libgit2/src/cli/CMakeLists.txt +56 -0
- data/vendor/libgit2/src/cli/README.md +26 -0
- data/vendor/libgit2/src/{branch.h → cli/cmd.c} +10 -8
- data/vendor/libgit2/src/cli/cmd.h +37 -0
- data/vendor/libgit2/src/cli/cmd_blame.c +287 -0
- data/vendor/libgit2/src/cli/cmd_cat_file.c +202 -0
- data/vendor/libgit2/src/cli/cmd_clone.c +190 -0
- data/vendor/libgit2/src/cli/cmd_config.c +241 -0
- data/vendor/libgit2/src/cli/cmd_hash_object.c +152 -0
- data/vendor/libgit2/src/cli/cmd_help.c +85 -0
- data/vendor/libgit2/src/cli/cmd_index_pack.c +114 -0
- data/vendor/libgit2/src/cli/cmd_init.c +102 -0
- data/vendor/libgit2/src/cli/common.c +168 -0
- data/vendor/libgit2/src/cli/common.h +63 -0
- data/vendor/libgit2/src/cli/error.h +51 -0
- data/vendor/libgit2/src/cli/main.c +134 -0
- data/vendor/libgit2/src/cli/opt.c +695 -0
- data/vendor/libgit2/src/cli/opt.h +367 -0
- data/vendor/libgit2/src/cli/opt_usage.c +263 -0
- data/vendor/libgit2/src/cli/opt_usage.h +40 -0
- data/vendor/libgit2/src/cli/progress.c +395 -0
- data/vendor/libgit2/src/cli/progress.h +129 -0
- data/vendor/libgit2/src/cli/sighandler.h +20 -0
- data/vendor/libgit2/src/cli/unix/sighandler.c +37 -0
- data/vendor/libgit2/src/cli/win32/precompiled.h +3 -0
- data/vendor/libgit2/src/cli/win32/sighandler.c +37 -0
- data/vendor/libgit2/src/libgit2/CMakeLists.txt +140 -0
- data/vendor/libgit2/src/{annotated_commit.c → libgit2/annotated_commit.c} +2 -2
- data/vendor/libgit2/src/{annotated_commit.h → libgit2/annotated_commit.h} +2 -2
- data/vendor/libgit2/src/{apply.c → libgit2/apply.c} +32 -34
- data/vendor/libgit2/src/{apply.h → libgit2/apply.h} +2 -2
- data/vendor/libgit2/src/{attr.c → libgit2/attr.c} +48 -31
- data/vendor/libgit2/src/{attr_file.c → libgit2/attr_file.c} +25 -20
- data/vendor/libgit2/src/{attr_file.h → libgit2/attr_file.h} +6 -4
- data/vendor/libgit2/src/{attrcache.c → libgit2/attrcache.c} +87 -46
- data/vendor/libgit2/src/{attrcache.h → libgit2/attrcache.h} +5 -9
- data/vendor/libgit2/src/{blame.c → libgit2/blame.c} +152 -57
- data/vendor/libgit2/src/{blame.h → libgit2/blame.h} +1 -0
- data/vendor/libgit2/src/{blame_git.c → libgit2/blame_git.c} +1 -2
- data/vendor/libgit2/src/{blob.c → libgit2/blob.c} +38 -29
- data/vendor/libgit2/src/{blob.h → libgit2/blob.h} +3 -3
- data/vendor/libgit2/src/{branch.c → libgit2/branch.c} +164 -118
- data/vendor/libgit2/src/libgit2/branch.h +31 -0
- data/vendor/libgit2/src/libgit2/buf.c +126 -0
- data/vendor/libgit2/src/libgit2/buf.h +50 -0
- data/vendor/libgit2/src/{cache.c → libgit2/cache.c} +22 -17
- data/vendor/libgit2/src/{cache.h → libgit2/cache.h} +7 -9
- data/vendor/libgit2/src/{checkout.c → libgit2/checkout.c} +107 -91
- data/vendor/libgit2/src/{checkout.h → libgit2/checkout.h} +0 -2
- data/vendor/libgit2/src/{cherrypick.c → libgit2/cherrypick.c} +14 -15
- data/vendor/libgit2/src/{clone.c → libgit2/clone.c} +254 -203
- data/vendor/libgit2/src/{clone.h → libgit2/clone.h} +4 -1
- data/vendor/libgit2/src/{commit.c → libgit2/commit.c} +296 -77
- data/vendor/libgit2/src/libgit2/commit.h +87 -0
- data/vendor/libgit2/src/{commit_graph.c → libgit2/commit_graph.c} +246 -135
- data/vendor/libgit2/src/{commit_graph.h → libgit2/commit_graph.h} +33 -8
- data/vendor/libgit2/src/{commit_list.c → libgit2/commit_list.c} +17 -7
- data/vendor/libgit2/src/{commit_list.h → libgit2/commit_list.h} +1 -0
- data/vendor/libgit2/src/libgit2/common.h +55 -0
- data/vendor/libgit2/src/{config.c → libgit2/config.c} +490 -360
- data/vendor/libgit2/src/libgit2/config.cmake.in +3 -0
- data/vendor/libgit2/src/{config.h → libgit2/config.h} +24 -6
- data/vendor/libgit2/src/{config_backend.h → libgit2/config_backend.h} +8 -10
- data/vendor/libgit2/src/{config_cache.c → libgit2/config_cache.c} +4 -5
- data/vendor/libgit2/src/{config_file.c → libgit2/config_file.c} +212 -183
- data/vendor/libgit2/src/libgit2/config_list.c +285 -0
- data/vendor/libgit2/src/libgit2/config_list.h +32 -0
- data/vendor/libgit2/src/libgit2/config_mem.c +374 -0
- data/vendor/libgit2/src/{config_parse.c → libgit2/config_parse.c} +37 -32
- data/vendor/libgit2/src/{config_snapshot.c → libgit2/config_snapshot.c} +24 -31
- data/vendor/libgit2/src/{crlf.c → libgit2/crlf.c} +24 -21
- data/vendor/libgit2/src/{describe.c → libgit2/describe.c} +62 -51
- data/vendor/libgit2/src/{diff.c → libgit2/diff.c} +44 -14
- data/vendor/libgit2/src/{diff.h → libgit2/diff.h} +8 -10
- data/vendor/libgit2/src/{diff_driver.c → libgit2/diff_driver.c} +46 -55
- data/vendor/libgit2/src/{diff_driver.h → libgit2/diff_driver.h} +5 -5
- data/vendor/libgit2/src/{diff_file.c → libgit2/diff_file.c} +45 -27
- data/vendor/libgit2/src/{diff_generate.c → libgit2/diff_generate.c} +70 -20
- data/vendor/libgit2/src/{diff_generate.h → libgit2/diff_generate.h} +5 -3
- data/vendor/libgit2/src/{diff_parse.c → libgit2/diff_parse.c} +22 -6
- data/vendor/libgit2/src/{diff_print.c → libgit2/diff_print.c} +192 -105
- data/vendor/libgit2/src/{diff_stats.c → libgit2/diff_stats.c} +40 -29
- data/vendor/libgit2/src/libgit2/diff_stats.h +18 -0
- data/vendor/libgit2/src/{diff_tform.c → libgit2/diff_tform.c} +49 -16
- data/vendor/libgit2/src/{diff_xdiff.c → libgit2/diff_xdiff.c} +4 -8
- data/vendor/libgit2/src/{diff_xdiff.h → libgit2/diff_xdiff.h} +1 -1
- data/vendor/libgit2/src/{email.c → libgit2/email.c} +58 -40
- data/vendor/libgit2/src/{email.h → libgit2/email.h} +1 -1
- data/vendor/libgit2/src/{transports/ssh.h → libgit2/experimental.h.in} +3 -4
- data/vendor/libgit2/src/{fetch.c → libgit2/fetch.c} +105 -30
- data/vendor/libgit2/src/{fetch.h → libgit2/fetch.h} +1 -3
- data/vendor/libgit2/src/{fetchhead.c → libgit2/fetchhead.c} +30 -28
- data/vendor/libgit2/src/{filter.c → libgit2/filter.c} +132 -58
- data/vendor/libgit2/src/{filter.h → libgit2/filter.h} +26 -5
- data/vendor/libgit2/src/{win32 → libgit2}/git2.rc +3 -3
- data/vendor/libgit2/src/libgit2/grafts.c +270 -0
- data/vendor/libgit2/src/libgit2/grafts.h +35 -0
- data/vendor/libgit2/src/{graph.c → libgit2/graph.c} +1 -1
- data/vendor/libgit2/src/libgit2/hashmap_oid.h +30 -0
- data/vendor/libgit2/src/{ident.c → libgit2/ident.c} +20 -20
- data/vendor/libgit2/src/{ignore.c → libgit2/ignore.c} +44 -39
- data/vendor/libgit2/src/{ignore.h → libgit2/ignore.h} +2 -2
- data/vendor/libgit2/src/{index.c → libgit2/index.c} +460 -276
- data/vendor/libgit2/src/{index.h → libgit2/index.h} +21 -5
- data/vendor/libgit2/src/libgit2/index_map.c +95 -0
- data/vendor/libgit2/src/libgit2/index_map.h +28 -0
- data/vendor/libgit2/src/{indexer.c → libgit2/indexer.c} +208 -124
- data/vendor/libgit2/src/{iterator.c → libgit2/iterator.c} +102 -71
- data/vendor/libgit2/src/{iterator.h → libgit2/iterator.h} +8 -5
- data/vendor/libgit2/src/libgit2/libgit2.c +268 -0
- data/vendor/libgit2/src/{mailmap.c → libgit2/mailmap.c} +39 -37
- data/vendor/libgit2/src/{merge.c → libgit2/merge.c} +83 -73
- data/vendor/libgit2/src/{merge.h → libgit2/merge.h} +1 -14
- data/vendor/libgit2/src/{merge_driver.c → libgit2/merge_driver.c} +4 -4
- data/vendor/libgit2/src/{merge_file.c → libgit2/merge_file.c} +13 -5
- data/vendor/libgit2/src/{message.c → libgit2/message.c} +21 -10
- data/vendor/libgit2/src/{midx.c → libgit2/midx.c} +174 -112
- data/vendor/libgit2/src/{midx.h → libgit2/midx.h} +17 -6
- data/vendor/libgit2/src/{mwindow.c → libgit2/mwindow.c} +53 -57
- data/vendor/libgit2/src/{mwindow.h → libgit2/mwindow.h} +9 -2
- data/vendor/libgit2/src/{notes.c → libgit2/notes.c} +29 -37
- data/vendor/libgit2/src/{object.c → libgit2/object.c} +166 -35
- data/vendor/libgit2/src/{object.h → libgit2/object.h} +17 -2
- data/vendor/libgit2/src/{odb.c → libgit2/odb.c} +261 -88
- data/vendor/libgit2/src/{odb.h → libgit2/odb.h} +44 -5
- data/vendor/libgit2/src/{odb_loose.c → libgit2/odb_loose.c} +192 -134
- data/vendor/libgit2/src/{odb_mempack.c → libgit2/odb_mempack.c} +67 -22
- data/vendor/libgit2/src/{odb_pack.c → libgit2/odb_pack.c} +162 -89
- data/vendor/libgit2/src/{oid.c → libgit2/oid.c} +171 -92
- data/vendor/libgit2/src/libgit2/oid.h +284 -0
- data/vendor/libgit2/src/libgit2/oidarray.c +89 -0
- data/vendor/libgit2/src/{oidarray.h → libgit2/oidarray.h} +5 -1
- data/vendor/libgit2/src/{pack-objects.c → libgit2/pack-objects.c} +126 -66
- data/vendor/libgit2/src/{pack-objects.h → libgit2/pack-objects.h} +28 -12
- data/vendor/libgit2/src/{pack.c → libgit2/pack.c} +146 -111
- data/vendor/libgit2/src/{pack.h → libgit2/pack.h} +45 -25
- data/vendor/libgit2/src/{parse.c → libgit2/parse.c} +8 -4
- data/vendor/libgit2/src/{parse.h → libgit2/parse.h} +1 -1
- data/vendor/libgit2/src/{patch.c → libgit2/patch.c} +3 -3
- data/vendor/libgit2/src/{patch.h → libgit2/patch.h} +8 -1
- data/vendor/libgit2/src/{patch_generate.c → libgit2/patch_generate.c} +51 -16
- data/vendor/libgit2/src/{patch_generate.h → libgit2/patch_generate.h} +5 -5
- data/vendor/libgit2/src/{patch_parse.c → libgit2/patch_parse.c} +42 -34
- data/vendor/libgit2/src/libgit2/path.c +375 -0
- data/vendor/libgit2/src/libgit2/path.h +68 -0
- data/vendor/libgit2/src/{pathspec.c → libgit2/pathspec.c} +7 -7
- data/vendor/libgit2/src/{pathspec.h → libgit2/pathspec.h} +2 -2
- data/vendor/libgit2/src/{proxy.c → libgit2/proxy.c} +4 -1
- data/vendor/libgit2/src/{proxy.h → libgit2/proxy.h} +1 -1
- data/vendor/libgit2/src/{push.c → libgit2/push.c} +116 -60
- data/vendor/libgit2/src/{push.h → libgit2/push.h} +5 -16
- data/vendor/libgit2/src/{reader.c → libgit2/reader.c} +9 -9
- data/vendor/libgit2/src/{reader.h → libgit2/reader.h} +2 -2
- data/vendor/libgit2/src/{rebase.c → libgit2/rebase.c} +147 -147
- data/vendor/libgit2/src/{refdb_fs.c → libgit2/refdb_fs.c} +639 -254
- data/vendor/libgit2/src/{reflog.c → libgit2/reflog.c} +8 -7
- data/vendor/libgit2/src/{reflog.h → libgit2/reflog.h} +3 -2
- data/vendor/libgit2/src/{refs.c → libgit2/refs.c} +67 -39
- data/vendor/libgit2/src/{refs.h → libgit2/refs.h} +8 -3
- data/vendor/libgit2/src/{refspec.c → libgit2/refspec.c} +60 -38
- data/vendor/libgit2/src/{refspec.h → libgit2/refspec.h} +13 -2
- data/vendor/libgit2/src/{remote.c → libgit2/remote.c} +821 -454
- data/vendor/libgit2/src/libgit2/remote.h +101 -0
- data/vendor/libgit2/src/{repository.c → libgit2/repository.c} +1377 -594
- data/vendor/libgit2/src/{repository.h → libgit2/repository.h} +43 -12
- data/vendor/libgit2/src/{reset.c → libgit2/reset.c} +8 -5
- data/vendor/libgit2/src/{revert.c → libgit2/revert.c} +18 -22
- data/vendor/libgit2/src/{revparse.c → libgit2/revparse.c} +76 -44
- data/vendor/libgit2/src/{revwalk.c → libgit2/revwalk.c} +48 -19
- data/vendor/libgit2/src/{revwalk.h → libgit2/revwalk.h} +3 -3
- data/vendor/libgit2/src/{libgit2.c → libgit2/settings.c} +162 -95
- data/vendor/libgit2/src/{settings.h → libgit2/settings.h} +6 -2
- data/vendor/libgit2/src/{signature.c → libgit2/signature.c} +144 -21
- data/vendor/libgit2/src/{signature.h → libgit2/signature.h} +1 -2
- data/vendor/libgit2/src/{stash.c → libgit2/stash.c} +243 -68
- data/vendor/libgit2/src/{status.c → libgit2/status.c} +5 -2
- data/vendor/libgit2/src/{strarray.c → libgit2/strarray.c} +1 -0
- data/vendor/libgit2/src/libgit2/strarray.h +25 -0
- data/vendor/libgit2/src/{streams → libgit2/streams}/mbedtls.c +62 -67
- data/vendor/libgit2/src/{streams → libgit2/streams}/openssl.c +41 -24
- data/vendor/libgit2/src/{streams → libgit2/streams}/openssl.h +2 -0
- data/vendor/libgit2/src/{streams → libgit2/streams}/openssl_dynamic.c +11 -3
- data/vendor/libgit2/src/{streams → libgit2/streams}/openssl_dynamic.h +6 -3
- data/vendor/libgit2/src/libgit2/streams/schannel.c +715 -0
- data/vendor/libgit2/src/libgit2/streams/schannel.h +28 -0
- data/vendor/libgit2/src/libgit2/streams/socket.c +428 -0
- data/vendor/libgit2/src/{streams → libgit2/streams}/socket.h +3 -1
- data/vendor/libgit2/src/{streams → libgit2/streams}/stransport.c +79 -19
- data/vendor/libgit2/src/{streams → libgit2/streams}/tls.c +5 -0
- data/vendor/libgit2/src/{submodule.c → libgit2/submodule.c} +279 -220
- data/vendor/libgit2/src/{submodule.h → libgit2/submodule.h} +10 -11
- data/vendor/libgit2/src/libgit2/sysdir.c +650 -0
- data/vendor/libgit2/src/{sysdir.h → libgit2/sysdir.h} +55 -18
- data/vendor/libgit2/src/{tag.c → libgit2/tag.c} +74 -43
- data/vendor/libgit2/src/{tag.h → libgit2/tag.h} +2 -2
- data/vendor/libgit2/src/{trace.c → libgit2/trace.c} +1 -14
- data/vendor/libgit2/src/{trace.h → libgit2/trace.h} +5 -22
- data/vendor/libgit2/src/{trailer.c → libgit2/trailer.c} +7 -7
- data/vendor/libgit2/src/{transaction.c → libgit2/transaction.c} +27 -21
- data/vendor/libgit2/src/{transaction.h → libgit2/transaction.h} +4 -1
- data/vendor/libgit2/src/{transport.c → libgit2/transport.c} +14 -11
- data/vendor/libgit2/src/{transports → libgit2/transports}/auth.c +7 -9
- data/vendor/libgit2/src/{transports → libgit2/transports}/auth.h +3 -5
- data/vendor/libgit2/src/{transports/auth_negotiate.c → libgit2/transports/auth_gssapi.c} +44 -45
- data/vendor/libgit2/src/{transports → libgit2/transports}/auth_negotiate.h +1 -1
- data/vendor/libgit2/src/{transports → libgit2/transports}/auth_ntlm.h +1 -2
- data/vendor/libgit2/src/{transports/auth_ntlm.c → libgit2/transports/auth_ntlmclient.c} +22 -22
- data/vendor/libgit2/src/libgit2/transports/auth_sspi.c +341 -0
- data/vendor/libgit2/src/{transports → libgit2/transports}/credential.c +1 -1
- data/vendor/libgit2/src/{transports → libgit2/transports}/git.c +16 -19
- data/vendor/libgit2/src/{transports → libgit2/transports}/http.c +49 -24
- data/vendor/libgit2/src/{transports → libgit2/transports}/http.h +0 -11
- data/vendor/libgit2/src/{transports → libgit2/transports}/httpclient.c +188 -134
- data/vendor/libgit2/src/{transports → libgit2/transports}/httpclient.h +10 -0
- data/vendor/libgit2/src/libgit2/transports/httpparser.c +128 -0
- data/vendor/libgit2/src/libgit2/transports/httpparser.h +99 -0
- data/vendor/libgit2/src/{transports → libgit2/transports}/local.c +159 -127
- data/vendor/libgit2/src/{transports → libgit2/transports}/smart.c +142 -165
- data/vendor/libgit2/src/{transports → libgit2/transports}/smart.h +56 -36
- data/vendor/libgit2/src/{transports → libgit2/transports}/smart_pkt.c +307 -74
- data/vendor/libgit2/src/{transports → libgit2/transports}/smart_protocol.c +297 -97
- data/vendor/libgit2/src/libgit2/transports/ssh.c +85 -0
- data/vendor/libgit2/src/libgit2/transports/ssh_exec.c +347 -0
- data/vendor/libgit2/src/libgit2/transports/ssh_exec.h +26 -0
- data/vendor/libgit2/src/{transports/ssh.c → libgit2/transports/ssh_libssh2.c} +414 -268
- data/vendor/libgit2/src/libgit2/transports/ssh_libssh2.h +28 -0
- data/vendor/libgit2/src/{transports → libgit2/transports}/winhttp.c +101 -75
- data/vendor/libgit2/src/{tree-cache.c → libgit2/tree-cache.c} +30 -20
- data/vendor/libgit2/src/{tree-cache.h → libgit2/tree-cache.h} +7 -5
- data/vendor/libgit2/src/{tree.c → libgit2/tree.c} +128 -110
- data/vendor/libgit2/src/{tree.h → libgit2/tree.h} +7 -6
- data/vendor/libgit2/src/{worktree.c → libgit2/worktree.c} +160 -121
- data/vendor/libgit2/src/{worktree.h → libgit2/worktree.h} +1 -1
- data/vendor/libgit2/src/util/CMakeLists.txt +77 -0
- data/vendor/libgit2/src/{alloc.c → util/alloc.c} +69 -7
- data/vendor/libgit2/src/util/alloc.h +65 -0
- data/vendor/libgit2/src/util/allocators/debugalloc.c +73 -0
- data/vendor/libgit2/src/util/allocators/debugalloc.h +17 -0
- data/vendor/libgit2/src/util/allocators/failalloc.c +32 -0
- data/vendor/libgit2/src/util/allocators/failalloc.h +17 -0
- data/vendor/libgit2/src/util/allocators/stdalloc.c +37 -0
- data/vendor/libgit2/src/{allocators → util/allocators}/stdalloc.h +1 -1
- data/vendor/libgit2/src/util/allocators/win32_leakcheck.c +50 -0
- data/vendor/libgit2/src/{allocators → util/allocators}/win32_leakcheck.h +1 -1
- data/vendor/libgit2/src/{array.h → util/array.h} +25 -19
- data/vendor/libgit2/src/{assert_safe.h → util/assert_safe.h} +16 -0
- data/vendor/libgit2/src/{cc-compat.h → util/cc-compat.h} +5 -1
- data/vendor/libgit2/src/util/ctype_compat.h +70 -0
- data/vendor/libgit2/src/{date.c → util/date.c} +35 -33
- data/vendor/libgit2/src/util/date.h +45 -0
- data/vendor/libgit2/src/util/errors.c +401 -0
- data/vendor/libgit2/src/{errors.h → util/errors.h} +22 -19
- data/vendor/libgit2/src/{filebuf.c → util/filebuf.c} +35 -30
- data/vendor/libgit2/src/{filebuf.h → util/filebuf.h} +21 -8
- data/vendor/libgit2/src/{path.c → util/fs_path.c} +591 -615
- data/vendor/libgit2/src/{path.h → util/fs_path.h} +257 -181
- data/vendor/libgit2/src/{futils.c → util/futils.c} +144 -95
- data/vendor/libgit2/src/{futils.h → util/futils.h} +40 -18
- data/vendor/libgit2/src/{features.h.in → util/git2_features.h.in} +33 -2
- data/vendor/libgit2/src/{common.h → util/git2_util.h} +26 -59
- data/vendor/libgit2/src/util/hash/builtin.c +53 -0
- data/vendor/libgit2/src/{hash/sha1/openssl.h → util/hash/builtin.h} +6 -6
- data/vendor/libgit2/src/{hash/sha1 → util/hash}/collisiondetect.c +3 -3
- data/vendor/libgit2/src/{hash/sha1 → util/hash}/collisiondetect.h +3 -3
- data/vendor/libgit2/src/util/hash/common_crypto.c +112 -0
- data/vendor/libgit2/src/{hash/sha1 → util/hash}/common_crypto.h +11 -3
- data/vendor/libgit2/src/util/hash/mbedtls.c +92 -0
- data/vendor/libgit2/src/{hash/sha1 → util/hash}/mbedtls.h +14 -4
- data/vendor/libgit2/src/util/hash/openssl.c +347 -0
- data/vendor/libgit2/src/util/hash/openssl.h +61 -0
- data/vendor/libgit2/src/util/hash/rfc6234/sha.h +243 -0
- data/vendor/libgit2/src/util/hash/rfc6234/sha224-256.c +601 -0
- data/vendor/libgit2/src/util/hash/sha.h +73 -0
- data/vendor/libgit2/src/{hash/sha1 → util/hash}/sha1dc/sha1.c +1 -1
- data/vendor/libgit2/src/util/hash/win32.c +549 -0
- data/vendor/libgit2/src/util/hash/win32.h +60 -0
- data/vendor/libgit2/src/util/hash.c +158 -0
- data/vendor/libgit2/src/util/hash.h +61 -0
- data/vendor/libgit2/src/util/hashmap.h +424 -0
- data/vendor/libgit2/src/util/hashmap_str.h +43 -0
- data/vendor/libgit2/src/{integer.h → util/integer.h} +3 -1
- data/vendor/libgit2/src/{map.h → util/map.h} +1 -1
- data/vendor/libgit2/src/util/net.c +1160 -0
- data/vendor/libgit2/src/{net.h → util/net.h} +45 -4
- data/vendor/libgit2/src/{pool.c → util/pool.c} +1 -1
- data/vendor/libgit2/src/{pool.h → util/pool.h} +6 -1
- data/vendor/libgit2/src/{posix.c → util/posix.c} +57 -3
- data/vendor/libgit2/src/{posix.h → util/posix.h} +26 -1
- data/vendor/libgit2/src/{pqueue.h → util/pqueue.h} +3 -3
- data/vendor/libgit2/src/util/process.h +222 -0
- data/vendor/libgit2/src/util/rand.c +230 -0
- data/vendor/libgit2/src/util/rand.h +37 -0
- data/vendor/libgit2/src/{regexp.c → util/regexp.c} +5 -5
- data/vendor/libgit2/src/{regexp.h → util/regexp.h} +1 -1
- data/vendor/libgit2/src/{runtime.c → util/runtime.c} +1 -1
- data/vendor/libgit2/src/{runtime.h → util/runtime.h} +1 -1
- data/vendor/libgit2/src/{sortedcache.c → util/sortedcache.c} +15 -14
- data/vendor/libgit2/src/{sortedcache.h → util/sortedcache.h} +5 -5
- data/vendor/libgit2/src/util/staticstr.h +66 -0
- data/vendor/libgit2/src/{buffer.c → util/str.c} +159 -153
- data/vendor/libgit2/src/util/str.h +357 -0
- data/vendor/libgit2/src/util/strlist.c +108 -0
- data/vendor/libgit2/src/util/strlist.h +36 -0
- data/vendor/libgit2/src/{thread.c → util/thread.c} +1 -1
- data/vendor/libgit2/src/{thread.h → util/thread.h} +23 -22
- data/vendor/libgit2/src/{tsort.c → util/tsort.c} +1 -1
- data/vendor/libgit2/src/{unix → util/unix}/map.c +1 -3
- data/vendor/libgit2/src/{unix → util/unix}/posix.h +1 -6
- data/vendor/libgit2/src/util/unix/process.c +629 -0
- data/vendor/libgit2/src/{unix → util/unix}/realpath.c +24 -8
- data/vendor/libgit2/src/{utf8.c → util/utf8.c} +1 -1
- data/vendor/libgit2/src/{utf8.h → util/utf8.h} +1 -1
- data/vendor/libgit2/src/{util.c → util/util.c} +24 -19
- data/vendor/libgit2/src/{util.h → util/util.h} +30 -81
- data/vendor/libgit2/src/{varint.h → util/varint.h} +1 -1
- data/vendor/libgit2/src/{vector.c → util/vector.c} +3 -3
- data/vendor/libgit2/src/{vector.h → util/vector.h} +4 -4
- data/vendor/libgit2/src/{wildmatch.h → util/wildmatch.h} +1 -1
- data/vendor/libgit2/src/{win32 → util/win32}/dir.h +1 -1
- data/vendor/libgit2/src/{win32 → util/win32}/error.c +1 -1
- data/vendor/libgit2/src/{win32 → util/win32}/error.h +1 -1
- data/vendor/libgit2/src/{win32 → util/win32}/map.c +1 -1
- data/vendor/libgit2/src/{win32 → util/win32}/path_w32.c +148 -17
- data/vendor/libgit2/src/{win32 → util/win32}/path_w32.h +3 -1
- data/vendor/libgit2/src/{win32 → util/win32}/posix.h +1 -2
- data/vendor/libgit2/src/{win32 → util/win32}/posix_w32.c +42 -35
- data/vendor/libgit2/src/util/win32/precompiled.c +1 -0
- data/vendor/libgit2/src/{win32 → util/win32}/precompiled.h +1 -1
- data/vendor/libgit2/src/util/win32/process.c +506 -0
- data/vendor/libgit2/src/{win32 → util/win32}/thread.h +1 -1
- data/vendor/libgit2/src/util/win32/utf-conv.c +144 -0
- data/vendor/libgit2/src/util/win32/utf-conv.h +127 -0
- data/vendor/libgit2/src/{win32 → util/win32}/w32_buffer.c +2 -3
- data/vendor/libgit2/src/{win32 → util/win32}/w32_buffer.h +3 -4
- data/vendor/libgit2/src/{win32 → util/win32}/w32_leakcheck.c +1 -1
- data/vendor/libgit2/src/{win32 → util/win32}/w32_leakcheck.h +1 -1
- data/vendor/libgit2/src/{win32 → util/win32}/w32_util.c +1 -1
- data/vendor/libgit2/src/{win32 → util/win32}/w32_util.h +1 -1
- data/vendor/libgit2/src/{zstream.c → util/zstream.c} +5 -5
- data/vendor/libgit2/src/{zstream.h → util/zstream.h} +5 -5
- metadata +431 -362
- data/vendor/libgit2/cmake/FindIconv.cmake +0 -45
- data/vendor/libgit2/deps/http-parser/CMakeLists.txt +0 -6
- data/vendor/libgit2/deps/http-parser/COPYING +0 -23
- data/vendor/libgit2/deps/http-parser/http_parser.c +0 -2182
- data/vendor/libgit2/deps/http-parser/http_parser.h +0 -305
- data/vendor/libgit2/deps/zlib/COPYING +0 -27
- data/vendor/libgit2/include/git2/sys/reflog.h +0 -21
- data/vendor/libgit2/src/alloc.h +0 -40
- data/vendor/libgit2/src/allocators/failalloc.c +0 -92
- data/vendor/libgit2/src/allocators/failalloc.h +0 -23
- data/vendor/libgit2/src/allocators/stdalloc.c +0 -150
- data/vendor/libgit2/src/allocators/win32_leakcheck.c +0 -118
- data/vendor/libgit2/src/buffer.h +0 -374
- data/vendor/libgit2/src/commit.h +0 -46
- data/vendor/libgit2/src/config_entries.c +0 -237
- data/vendor/libgit2/src/config_entries.h +0 -24
- data/vendor/libgit2/src/config_mem.c +0 -220
- data/vendor/libgit2/src/errors.c +0 -238
- data/vendor/libgit2/src/hash/sha1/common_crypto.c +0 -57
- data/vendor/libgit2/src/hash/sha1/generic.c +0 -300
- data/vendor/libgit2/src/hash/sha1/generic.h +0 -19
- data/vendor/libgit2/src/hash/sha1/mbedtls.c +0 -46
- data/vendor/libgit2/src/hash/sha1/openssl.c +0 -59
- data/vendor/libgit2/src/hash/sha1/win32.c +0 -333
- data/vendor/libgit2/src/hash/sha1/win32.h +0 -128
- data/vendor/libgit2/src/hash/sha1.h +0 -38
- data/vendor/libgit2/src/hash.c +0 -110
- data/vendor/libgit2/src/hash.h +0 -46
- data/vendor/libgit2/src/idxmap.c +0 -157
- data/vendor/libgit2/src/idxmap.h +0 -177
- data/vendor/libgit2/src/khash.h +0 -615
- data/vendor/libgit2/src/libgit2.h +0 -15
- data/vendor/libgit2/src/message.h +0 -17
- data/vendor/libgit2/src/net.c +0 -540
- data/vendor/libgit2/src/netops.c +0 -125
- data/vendor/libgit2/src/netops.h +0 -68
- data/vendor/libgit2/src/offmap.c +0 -101
- data/vendor/libgit2/src/offmap.h +0 -133
- data/vendor/libgit2/src/oid.h +0 -51
- data/vendor/libgit2/src/oidarray.c +0 -43
- data/vendor/libgit2/src/oidmap.c +0 -107
- data/vendor/libgit2/src/oidmap.h +0 -128
- data/vendor/libgit2/src/remote.h +0 -55
- data/vendor/libgit2/src/streams/socket.c +0 -239
- data/vendor/libgit2/src/strmap.c +0 -100
- data/vendor/libgit2/src/strmap.h +0 -131
- data/vendor/libgit2/src/sysdir.c +0 -347
- data/vendor/libgit2/src/threadstate.c +0 -84
- data/vendor/libgit2/src/threadstate.h +0 -24
- data/vendor/libgit2/src/win32/findfile.c +0 -230
- data/vendor/libgit2/src/win32/findfile.h +0 -19
- data/vendor/libgit2/src/win32/utf-conv.c +0 -146
- data/vendor/libgit2/src/win32/utf-conv.h +0 -60
- /data/vendor/libgit2/{src → deps}/xdiff/xemit.h +0 -0
- /data/vendor/libgit2/{src → deps}/xdiff/xprepare.h +0 -0
- /data/vendor/libgit2/{src → deps}/xdiff/xtypes.h +0 -0
- /data/vendor/libgit2/src/{win32 → cli/win32}/precompiled.c +0 -0
- /data/vendor/libgit2/src/{attr.h → libgit2/attr.h} +0 -0
- /data/vendor/libgit2/src/{blame_git.h → libgit2/blame_git.h} +0 -0
- /data/vendor/libgit2/src/{config_parse.h → libgit2/config_parse.h} +0 -0
- /data/vendor/libgit2/src/{delta.c → libgit2/delta.c} +0 -0
- /data/vendor/libgit2/src/{delta.h → libgit2/delta.h} +0 -0
- /data/vendor/libgit2/src/{diff_file.h → libgit2/diff_file.h} +0 -0
- /data/vendor/libgit2/src/{diff_parse.h → libgit2/diff_parse.h} +0 -0
- /data/vendor/libgit2/src/{diff_tform.h → libgit2/diff_tform.h} +0 -0
- /data/vendor/libgit2/src/{fetchhead.h → libgit2/fetchhead.h} +0 -0
- /data/vendor/libgit2/src/{hashsig.c → libgit2/hashsig.c} +0 -0
- /data/vendor/libgit2/src/{indexer.h → libgit2/indexer.h} +0 -0
- /data/vendor/libgit2/src/{mailmap.h → libgit2/mailmap.h} +0 -0
- /data/vendor/libgit2/src/{merge_driver.h → libgit2/merge_driver.h} +0 -0
- /data/vendor/libgit2/src/{notes.h → libgit2/notes.h} +0 -0
- /data/vendor/libgit2/src/{object_api.c → libgit2/object_api.c} +0 -0
- /data/vendor/libgit2/src/{patch_parse.h → libgit2/patch_parse.h} +0 -0
- /data/vendor/libgit2/src/{refdb.c → libgit2/refdb.c} +0 -0
- /data/vendor/libgit2/src/{refdb.h → libgit2/refdb.h} +0 -0
- /data/vendor/libgit2/src/{repo_template.h → libgit2/repo_template.h} +0 -0
- /data/vendor/libgit2/src/{status.h → libgit2/status.h} +0 -0
- /data/vendor/libgit2/src/{stream.h → libgit2/stream.h} +0 -0
- /data/vendor/libgit2/src/{streams → libgit2/streams}/mbedtls.h +0 -0
- /data/vendor/libgit2/src/{streams → libgit2/streams}/openssl_legacy.c +0 -0
- /data/vendor/libgit2/src/{streams → libgit2/streams}/openssl_legacy.h +0 -0
- /data/vendor/libgit2/src/{streams → libgit2/streams}/registry.c +0 -0
- /data/vendor/libgit2/src/{streams → libgit2/streams}/registry.h +0 -0
- /data/vendor/libgit2/src/{streams → libgit2/streams}/stransport.h +0 -0
- /data/vendor/libgit2/src/{streams → libgit2/streams}/tls.h +0 -0
- /data/vendor/libgit2/src/{transports → libgit2/transports}/credential_helpers.c +0 -0
- /data/vendor/libgit2/src/{userdiff.h → libgit2/userdiff.h} +0 -0
- /data/vendor/libgit2/src/{bitvec.h → util/bitvec.h} +0 -0
- /data/vendor/libgit2/src/{hash/sha1 → util/hash}/sha1dc/sha1.h +0 -0
- /data/vendor/libgit2/src/{hash/sha1 → util/hash}/sha1dc/ubc_check.c +0 -0
- /data/vendor/libgit2/src/{hash/sha1 → util/hash}/sha1dc/ubc_check.h +0 -0
- /data/vendor/libgit2/src/{pqueue.c → util/pqueue.c} +0 -0
- /data/vendor/libgit2/src/{strnlen.h → util/strnlen.h} +0 -0
- /data/vendor/libgit2/src/{unix → util/unix}/pthread.h +0 -0
- /data/vendor/libgit2/src/{varint.c → util/varint.c} +0 -0
- /data/vendor/libgit2/src/{wildmatch.c → util/wildmatch.c} +0 -0
- /data/vendor/libgit2/src/{win32 → util/win32}/dir.c +0 -0
- /data/vendor/libgit2/src/{win32 → util/win32}/mingw-compat.h +0 -0
- /data/vendor/libgit2/src/{win32 → util/win32}/msvc-compat.h +0 -0
- /data/vendor/libgit2/src/{win32 → util/win32}/reparse.h +0 -0
- /data/vendor/libgit2/src/{win32 → util/win32}/thread.c +0 -0
- /data/vendor/libgit2/src/{win32 → util/win32}/version.h +0 -0
- /data/vendor/libgit2/src/{win32 → util/win32}/w32_common.h +0 -0
- /data/vendor/libgit2/src/{win32 → util/win32}/win32-compat.h +0 -0
@@ -0,0 +1,158 @@
|
|
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
|
+
#include "hash.h"
|
9
|
+
|
10
|
+
int git_hash_global_init(void)
|
11
|
+
{
|
12
|
+
if (git_hash_sha1_global_init() < 0 ||
|
13
|
+
git_hash_sha256_global_init() < 0)
|
14
|
+
return -1;
|
15
|
+
|
16
|
+
return 0;
|
17
|
+
}
|
18
|
+
|
19
|
+
int git_hash_ctx_init(git_hash_ctx *ctx, git_hash_algorithm_t algorithm)
|
20
|
+
{
|
21
|
+
int error;
|
22
|
+
|
23
|
+
switch (algorithm) {
|
24
|
+
case GIT_HASH_ALGORITHM_SHA1:
|
25
|
+
error = git_hash_sha1_ctx_init(&ctx->ctx.sha1);
|
26
|
+
break;
|
27
|
+
case GIT_HASH_ALGORITHM_SHA256:
|
28
|
+
error = git_hash_sha256_ctx_init(&ctx->ctx.sha256);
|
29
|
+
break;
|
30
|
+
default:
|
31
|
+
git_error_set(GIT_ERROR_INTERNAL, "unknown hash algorithm");
|
32
|
+
error = -1;
|
33
|
+
}
|
34
|
+
|
35
|
+
ctx->algorithm = algorithm;
|
36
|
+
return error;
|
37
|
+
}
|
38
|
+
|
39
|
+
void git_hash_ctx_cleanup(git_hash_ctx *ctx)
|
40
|
+
{
|
41
|
+
switch (ctx->algorithm) {
|
42
|
+
case GIT_HASH_ALGORITHM_SHA1:
|
43
|
+
git_hash_sha1_ctx_cleanup(&ctx->ctx.sha1);
|
44
|
+
return;
|
45
|
+
case GIT_HASH_ALGORITHM_SHA256:
|
46
|
+
git_hash_sha256_ctx_cleanup(&ctx->ctx.sha256);
|
47
|
+
return;
|
48
|
+
default:
|
49
|
+
/* unreachable */ ;
|
50
|
+
}
|
51
|
+
}
|
52
|
+
|
53
|
+
int git_hash_init(git_hash_ctx *ctx)
|
54
|
+
{
|
55
|
+
switch (ctx->algorithm) {
|
56
|
+
case GIT_HASH_ALGORITHM_SHA1:
|
57
|
+
return git_hash_sha1_init(&ctx->ctx.sha1);
|
58
|
+
case GIT_HASH_ALGORITHM_SHA256:
|
59
|
+
return git_hash_sha256_init(&ctx->ctx.sha256);
|
60
|
+
default:
|
61
|
+
/* unreachable */ ;
|
62
|
+
}
|
63
|
+
|
64
|
+
git_error_set(GIT_ERROR_INTERNAL, "unknown hash algorithm");
|
65
|
+
return -1;
|
66
|
+
}
|
67
|
+
|
68
|
+
int git_hash_update(git_hash_ctx *ctx, const void *data, size_t len)
|
69
|
+
{
|
70
|
+
switch (ctx->algorithm) {
|
71
|
+
case GIT_HASH_ALGORITHM_SHA1:
|
72
|
+
return git_hash_sha1_update(&ctx->ctx.sha1, data, len);
|
73
|
+
case GIT_HASH_ALGORITHM_SHA256:
|
74
|
+
return git_hash_sha256_update(&ctx->ctx.sha256, data, len);
|
75
|
+
default:
|
76
|
+
/* unreachable */ ;
|
77
|
+
}
|
78
|
+
|
79
|
+
git_error_set(GIT_ERROR_INTERNAL, "unknown hash algorithm");
|
80
|
+
return -1;
|
81
|
+
}
|
82
|
+
|
83
|
+
int git_hash_final(unsigned char *out, git_hash_ctx *ctx)
|
84
|
+
{
|
85
|
+
switch (ctx->algorithm) {
|
86
|
+
case GIT_HASH_ALGORITHM_SHA1:
|
87
|
+
return git_hash_sha1_final(out, &ctx->ctx.sha1);
|
88
|
+
case GIT_HASH_ALGORITHM_SHA256:
|
89
|
+
return git_hash_sha256_final(out, &ctx->ctx.sha256);
|
90
|
+
default:
|
91
|
+
/* unreachable */ ;
|
92
|
+
}
|
93
|
+
|
94
|
+
git_error_set(GIT_ERROR_INTERNAL, "unknown hash algorithm");
|
95
|
+
return -1;
|
96
|
+
}
|
97
|
+
|
98
|
+
int git_hash_buf(
|
99
|
+
unsigned char *out,
|
100
|
+
const void *data,
|
101
|
+
size_t len,
|
102
|
+
git_hash_algorithm_t algorithm)
|
103
|
+
{
|
104
|
+
git_hash_ctx ctx;
|
105
|
+
int error = 0;
|
106
|
+
|
107
|
+
if (git_hash_ctx_init(&ctx, algorithm) < 0)
|
108
|
+
return -1;
|
109
|
+
|
110
|
+
if ((error = git_hash_update(&ctx, data, len)) >= 0)
|
111
|
+
error = git_hash_final(out, &ctx);
|
112
|
+
|
113
|
+
git_hash_ctx_cleanup(&ctx);
|
114
|
+
|
115
|
+
return error;
|
116
|
+
}
|
117
|
+
|
118
|
+
int git_hash_vec(
|
119
|
+
unsigned char *out,
|
120
|
+
git_str_vec *vec,
|
121
|
+
size_t n,
|
122
|
+
git_hash_algorithm_t algorithm)
|
123
|
+
{
|
124
|
+
git_hash_ctx ctx;
|
125
|
+
size_t i;
|
126
|
+
int error = 0;
|
127
|
+
|
128
|
+
if (git_hash_ctx_init(&ctx, algorithm) < 0)
|
129
|
+
return -1;
|
130
|
+
|
131
|
+
for (i = 0; i < n; i++) {
|
132
|
+
if ((error = git_hash_update(&ctx, vec[i].data, vec[i].len)) < 0)
|
133
|
+
goto done;
|
134
|
+
}
|
135
|
+
|
136
|
+
error = git_hash_final(out, &ctx);
|
137
|
+
|
138
|
+
done:
|
139
|
+
git_hash_ctx_cleanup(&ctx);
|
140
|
+
|
141
|
+
return error;
|
142
|
+
}
|
143
|
+
|
144
|
+
int git_hash_fmt(char *out, unsigned char *hash, size_t hash_len)
|
145
|
+
{
|
146
|
+
static char hex[] = "0123456789abcdef";
|
147
|
+
char *str = out;
|
148
|
+
size_t i;
|
149
|
+
|
150
|
+
for (i = 0; i < hash_len; i++) {
|
151
|
+
*str++ = hex[hash[i] >> 4];
|
152
|
+
*str++ = hex[hash[i] & 0x0f];
|
153
|
+
}
|
154
|
+
|
155
|
+
*str++ = '\0';
|
156
|
+
|
157
|
+
return 0;
|
158
|
+
}
|
@@ -0,0 +1,61 @@
|
|
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_hash_h__
|
9
|
+
#define INCLUDE_hash_h__
|
10
|
+
|
11
|
+
#include "git2_util.h"
|
12
|
+
|
13
|
+
#include "hash/sha.h"
|
14
|
+
|
15
|
+
typedef struct {
|
16
|
+
void *data;
|
17
|
+
size_t len;
|
18
|
+
} git_str_vec;
|
19
|
+
|
20
|
+
typedef enum {
|
21
|
+
GIT_HASH_ALGORITHM_NONE = 0,
|
22
|
+
GIT_HASH_ALGORITHM_SHA1,
|
23
|
+
GIT_HASH_ALGORITHM_SHA256
|
24
|
+
} git_hash_algorithm_t;
|
25
|
+
|
26
|
+
#define GIT_HASH_MAX_SIZE GIT_HASH_SHA256_SIZE
|
27
|
+
|
28
|
+
typedef struct git_hash_ctx {
|
29
|
+
union {
|
30
|
+
git_hash_sha1_ctx sha1;
|
31
|
+
git_hash_sha256_ctx sha256;
|
32
|
+
} ctx;
|
33
|
+
git_hash_algorithm_t algorithm;
|
34
|
+
} git_hash_ctx;
|
35
|
+
|
36
|
+
int git_hash_global_init(void);
|
37
|
+
|
38
|
+
int git_hash_ctx_init(git_hash_ctx *ctx, git_hash_algorithm_t algorithm);
|
39
|
+
void git_hash_ctx_cleanup(git_hash_ctx *ctx);
|
40
|
+
|
41
|
+
int git_hash_init(git_hash_ctx *c);
|
42
|
+
int git_hash_update(git_hash_ctx *c, const void *data, size_t len);
|
43
|
+
int git_hash_final(unsigned char *out, git_hash_ctx *c);
|
44
|
+
|
45
|
+
int git_hash_buf(unsigned char *out, const void *data, size_t len, git_hash_algorithm_t algorithm);
|
46
|
+
int git_hash_vec(unsigned char *out, git_str_vec *vec, size_t n, git_hash_algorithm_t algorithm);
|
47
|
+
|
48
|
+
int git_hash_fmt(char *out, unsigned char *hash, size_t hash_len);
|
49
|
+
|
50
|
+
GIT_INLINE(size_t) git_hash_size(git_hash_algorithm_t algorithm) {
|
51
|
+
switch (algorithm) {
|
52
|
+
case GIT_HASH_ALGORITHM_SHA1:
|
53
|
+
return GIT_HASH_SHA1_SIZE;
|
54
|
+
case GIT_HASH_ALGORITHM_SHA256:
|
55
|
+
return GIT_HASH_SHA256_SIZE;
|
56
|
+
default:
|
57
|
+
return 0;
|
58
|
+
}
|
59
|
+
}
|
60
|
+
|
61
|
+
#endif
|
@@ -0,0 +1,424 @@
|
|
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
|
+
#ifndef INCLUDE_hashmap_h__
|
8
|
+
#define INCLUDE_hashmap_h__
|
9
|
+
|
10
|
+
/*
|
11
|
+
* This is a variation on khash.h from khlib 2013-05-02 (0.2.8)
|
12
|
+
*
|
13
|
+
* The MIT License
|
14
|
+
*
|
15
|
+
* Copyright (c) 2008, 2009, 2011 by Attractive Chaos <attractor@live.co.uk>
|
16
|
+
*
|
17
|
+
* Permission is hereby granted, free of charge, to any person obtaining
|
18
|
+
* a copy of this software and associated documentation files (the
|
19
|
+
* "Software"), to deal in the Software without restriction, including
|
20
|
+
* without limitation the rights to use, copy, modify, merge, publish,
|
21
|
+
* distribute, sublicense, and/or sell copies of the Software, and to
|
22
|
+
* permit persons to whom the Software is furnished to do so, subject to
|
23
|
+
* the following conditions:
|
24
|
+
*
|
25
|
+
* The above copyright notice and this permission notice shall be
|
26
|
+
* included in all copies or substantial portions of the Software.
|
27
|
+
*
|
28
|
+
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
29
|
+
* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
30
|
+
* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
|
31
|
+
* NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS
|
32
|
+
* BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN
|
33
|
+
* ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
|
34
|
+
* CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
35
|
+
* SOFTWARE.
|
36
|
+
*/
|
37
|
+
|
38
|
+
#include <stdlib.h>
|
39
|
+
#include <string.h>
|
40
|
+
#include <limits.h>
|
41
|
+
|
42
|
+
#define GIT_HASHMAP_INIT {0}
|
43
|
+
#define GIT_HASHSET_INIT {0}
|
44
|
+
|
45
|
+
#define GIT_HASHMAP_EMPTY
|
46
|
+
#define GIT_HASHMAP_INLINE GIT_INLINE(GIT_HASHMAP_EMPTY)
|
47
|
+
|
48
|
+
#define GIT_HASHMAP_IS_EMPTY(flag, i) ((flag[i>>4]>>((i&0xfU)<<1))&2)
|
49
|
+
#define GIT_HASHMAP_IS_DELETE(flag, i) ((flag[i>>4]>>((i&0xfU)<<1))&1)
|
50
|
+
#define GIT_HASHMAP_IS_EITHER(flag, i) ((flag[i>>4]>>((i&0xfU)<<1))&3)
|
51
|
+
#define GIT_HASHMAP_SET_EMPTY_FALSE(flag, i) (flag[i>>4]&=~(2ul<<((i&0xfU)<<1)))
|
52
|
+
#define GIT_HASHMAP_SET_DELETE_TRUE(flag, i) (flag[i>>4]|=1ul<<((i&0xfU)<<1))
|
53
|
+
#define GIT_HASHMAP_SET_DELETE_FALSE(flag, i) (flag[i>>4]&=~(1ul<<((i&0xfU)<<1)))
|
54
|
+
#define GIT_HASHMAP_SET_BOTH_FALSE(flag, i) (flag[i>>4]&=~(3ul<<((i&0xfU)<<1)))
|
55
|
+
|
56
|
+
#define GIT_HASHMAP_FLAGSIZE(m) ((m) < 16? 1 : (m)>>4)
|
57
|
+
#define GIT_HASHMAP_ROUNDUP(x) (--(x), (x)|=(x)>>1, \
|
58
|
+
(x)|=(x)>>2, (x)|=(x)>>4, (x)|=(x)>>8, (x)|=(x)>>16, ++(x))
|
59
|
+
|
60
|
+
#define GIT_HASHSET_VAL_T void *
|
61
|
+
|
62
|
+
typedef uint32_t git_hashmap_iter_t;
|
63
|
+
#define GIT_HASHMAP_ITER_INIT 0
|
64
|
+
|
65
|
+
#define GIT_HASHMAP_STRUCT_MEMBERS(key_t, val_t) \
|
66
|
+
uint32_t n_buckets, \
|
67
|
+
size, \
|
68
|
+
n_occupied, \
|
69
|
+
upper_bound; \
|
70
|
+
uint32_t *flags; \
|
71
|
+
key_t *keys; \
|
72
|
+
val_t *vals;
|
73
|
+
|
74
|
+
#define GIT_HASHMAP_STRUCT(name, key_t, val_t) \
|
75
|
+
typedef struct { \
|
76
|
+
GIT_HASHMAP_STRUCT_MEMBERS(key_t, val_t) \
|
77
|
+
} name;
|
78
|
+
#define GIT_HASHSET_STRUCT(name, key_t) \
|
79
|
+
GIT_HASHMAP_STRUCT(name, key_t, void *)
|
80
|
+
|
81
|
+
|
82
|
+
#define GIT_HASHMAP__COMMON_PROTOTYPES(name, key_t, val_t) \
|
83
|
+
extern uint32_t name##_size(name *h); \
|
84
|
+
extern bool name##_contains(name *h, key_t key); \
|
85
|
+
extern int name##_remove(name *h, key_t key); \
|
86
|
+
extern void name##_clear(name *h); \
|
87
|
+
extern void name##_dispose(name *h);
|
88
|
+
|
89
|
+
#define GIT_HASHMAP_PROTOTYPES(name, key_t, val_t) \
|
90
|
+
GIT_HASHMAP__COMMON_PROTOTYPES(name, key_t, val_t) \
|
91
|
+
extern int name##_get(val_t *out, name *h, key_t key); \
|
92
|
+
extern int name##_put(name *h, key_t key, val_t val); \
|
93
|
+
extern int name##_iterate(git_hashmap_iter_t *iter, key_t *key, val_t *val, name *h); \
|
94
|
+
extern int name##_foreach(name *h, int (*cb)(key_t, val_t));
|
95
|
+
|
96
|
+
#define GIT_HASHSET_PROTOTYPES(name, key_t) \
|
97
|
+
GIT_HASHMAP__COMMON_PROTOTYPES(name, key_t, GIT_HASHSET_VAL_T) \
|
98
|
+
extern int name##_add(name *h, key_t key); \
|
99
|
+
extern int name##_iterate(git_hashmap_iter_t *iter, key_t *key, name *h); \
|
100
|
+
extern int name##_foreach(name *h, int (*cb)(key_t)); \
|
101
|
+
|
102
|
+
|
103
|
+
#define GIT_HASHMAP__COMMON_FUNCTIONS(name, is_map, scope, key_t, val_t, __hash_fn, __equal_fn) \
|
104
|
+
GIT_UNUSED_FUNCTION scope uint32_t name##_size(name *h) \
|
105
|
+
{ \
|
106
|
+
return h->size; \
|
107
|
+
} \
|
108
|
+
GIT_INLINE(int) name##__idx(uint32_t *out, name *h, key_t key) \
|
109
|
+
{ \
|
110
|
+
if (h->n_buckets) { \
|
111
|
+
uint32_t k, i, last, mask, step = 0; \
|
112
|
+
GIT_ASSERT((h)->flags); \
|
113
|
+
mask = h->n_buckets - 1; \
|
114
|
+
k = __hash_fn(key); \
|
115
|
+
i = k & mask; \
|
116
|
+
last = i; \
|
117
|
+
while (!GIT_HASHMAP_IS_EMPTY(h->flags, i) && \
|
118
|
+
(GIT_HASHMAP_IS_DELETE(h->flags, i) || !__equal_fn(h->keys[i], key))) { \
|
119
|
+
i = (i + (++step)) & mask; \
|
120
|
+
if (i == last) \
|
121
|
+
return GIT_ENOTFOUND; \
|
122
|
+
} \
|
123
|
+
if (GIT_HASHMAP_IS_EITHER(h->flags, i)) \
|
124
|
+
return GIT_ENOTFOUND; \
|
125
|
+
*out = i; \
|
126
|
+
return 0; \
|
127
|
+
} \
|
128
|
+
return GIT_ENOTFOUND; \
|
129
|
+
} \
|
130
|
+
GIT_UNUSED_FUNCTION scope bool name##_contains(name *h, key_t key) \
|
131
|
+
{ \
|
132
|
+
uint32_t idx; \
|
133
|
+
return name##__idx(&idx, h, key) == 0; \
|
134
|
+
} \
|
135
|
+
GIT_INLINE(int) name##__remove_at_idx(name *h, uint32_t idx) \
|
136
|
+
{ \
|
137
|
+
if (idx < h->n_buckets && !GIT_HASHMAP_IS_EITHER(h->flags, idx)) { \
|
138
|
+
GIT_HASHMAP_SET_DELETE_TRUE(h->flags, idx); \
|
139
|
+
--h->size; \
|
140
|
+
return 0; \
|
141
|
+
} \
|
142
|
+
return GIT_ENOTFOUND; \
|
143
|
+
} \
|
144
|
+
GIT_UNUSED_FUNCTION scope int name##_remove(name *h, key_t key) \
|
145
|
+
{ \
|
146
|
+
uint32_t idx; \
|
147
|
+
int error; \
|
148
|
+
if ((error = name##__idx(&idx, h, key)) == 0) \
|
149
|
+
error = name##__remove_at_idx(h, idx); \
|
150
|
+
return error; \
|
151
|
+
} \
|
152
|
+
GIT_INLINE(int) name##__resize(name *h, uint32_t new_n_buckets) \
|
153
|
+
{ \
|
154
|
+
/* This function uses 0.25*n_buckets bytes of working \
|
155
|
+
* space instead of [sizeof(key_t+val_t)+.25]*n_buckets. \
|
156
|
+
*/ \
|
157
|
+
double git_hashmap__upper_bound = 0.77; \
|
158
|
+
uint32_t *new_flags = 0; \
|
159
|
+
uint32_t j = 1; \
|
160
|
+
{ \
|
161
|
+
GIT_HASHMAP_ROUNDUP(new_n_buckets); \
|
162
|
+
if (new_n_buckets < 4) \
|
163
|
+
new_n_buckets = 4; \
|
164
|
+
if (h->size >= (uint32_t)(new_n_buckets * git_hashmap__upper_bound + 0.5)) { \
|
165
|
+
/* Requested size is too small */ \
|
166
|
+
j = 0; \
|
167
|
+
} else { \
|
168
|
+
/* Shrink or expand; rehash */ \
|
169
|
+
new_flags = git__reallocarray(NULL, GIT_HASHMAP_FLAGSIZE(new_n_buckets), sizeof(uint32_t)); \
|
170
|
+
if (!new_flags) \
|
171
|
+
return -1; \
|
172
|
+
memset(new_flags, 0xaa, GIT_HASHMAP_FLAGSIZE(new_n_buckets) * sizeof(uint32_t)); \
|
173
|
+
if (h->n_buckets < new_n_buckets) { \
|
174
|
+
/* Expand */ \
|
175
|
+
key_t *new_keys = git__reallocarray(h->keys, new_n_buckets, sizeof(key_t)); \
|
176
|
+
if (!new_keys) { \
|
177
|
+
git__free(new_flags); \
|
178
|
+
return -1; \
|
179
|
+
} \
|
180
|
+
h->keys = new_keys; \
|
181
|
+
if (is_map) { \
|
182
|
+
val_t *new_vals = git__reallocarray(h->vals, new_n_buckets, sizeof(val_t)); \
|
183
|
+
if (!new_vals) { \
|
184
|
+
git__free(new_flags); \
|
185
|
+
return -1; \
|
186
|
+
} \
|
187
|
+
h->vals = new_vals; \
|
188
|
+
} \
|
189
|
+
} \
|
190
|
+
} \
|
191
|
+
} \
|
192
|
+
if (j) { \
|
193
|
+
/* Rehashing is needed */ \
|
194
|
+
for (j = 0; j != h->n_buckets; ++j) { \
|
195
|
+
if (GIT_HASHMAP_IS_EITHER(h->flags, j) == 0) { \
|
196
|
+
key_t key = h->keys[j]; \
|
197
|
+
val_t val; \
|
198
|
+
uint32_t new_mask; \
|
199
|
+
new_mask = new_n_buckets - 1; \
|
200
|
+
if (is_map) \
|
201
|
+
val = h->vals[j]; \
|
202
|
+
GIT_HASHMAP_SET_DELETE_TRUE(h->flags, j); \
|
203
|
+
while (1) { \
|
204
|
+
/* Kick-out process; sort of like in Cuckoo hashing */ \
|
205
|
+
uint32_t k, i, step = 0; \
|
206
|
+
k = __hash_fn(key); \
|
207
|
+
i = k & new_mask; \
|
208
|
+
while (!GIT_HASHMAP_IS_EMPTY(new_flags, i)) \
|
209
|
+
i = (i + (++step)) & new_mask; \
|
210
|
+
GIT_HASHMAP_SET_EMPTY_FALSE(new_flags, i); \
|
211
|
+
if (i < h->n_buckets && GIT_HASHMAP_IS_EITHER(h->flags, i) == 0) { \
|
212
|
+
/* Kick out the existing element */ \
|
213
|
+
{ \
|
214
|
+
key_t tmp = h->keys[i]; \
|
215
|
+
h->keys[i] = key; \
|
216
|
+
key = tmp; \
|
217
|
+
} \
|
218
|
+
if (is_map) { \
|
219
|
+
val_t tmp = h->vals[i]; \
|
220
|
+
h->vals[i] = val; \
|
221
|
+
val = tmp; \
|
222
|
+
} \
|
223
|
+
/* Mark it as deleted in the old hash table */ \
|
224
|
+
GIT_HASHMAP_SET_DELETE_TRUE(h->flags, i); \
|
225
|
+
} else { \
|
226
|
+
/* Write the element and jump out of the loop */ \
|
227
|
+
h->keys[i] = key; \
|
228
|
+
if (is_map) \
|
229
|
+
h->vals[i] = val; \
|
230
|
+
break; \
|
231
|
+
} \
|
232
|
+
} \
|
233
|
+
} \
|
234
|
+
} \
|
235
|
+
if (h->n_buckets > new_n_buckets) { \
|
236
|
+
/* Shrink the hash table */ \
|
237
|
+
h->keys = git__reallocarray(h->keys, new_n_buckets, sizeof(key_t)); \
|
238
|
+
if (is_map) \
|
239
|
+
h->vals = git__reallocarray(h->vals, new_n_buckets, sizeof(val_t)); \
|
240
|
+
} \
|
241
|
+
/* free the working space */ \
|
242
|
+
git__free(h->flags); \
|
243
|
+
h->flags = new_flags; \
|
244
|
+
h->n_buckets = new_n_buckets; \
|
245
|
+
h->n_occupied = h->size; \
|
246
|
+
h->upper_bound = (uint32_t)(h->n_buckets * git_hashmap__upper_bound + 0.5); \
|
247
|
+
} \
|
248
|
+
return 0; \
|
249
|
+
} \
|
250
|
+
GIT_INLINE(int) name##__put_idx(uint32_t *idx, bool *key_exists, name *h, key_t key) \
|
251
|
+
{ \
|
252
|
+
uint32_t x; \
|
253
|
+
if (h->n_occupied >= h->upper_bound) { \
|
254
|
+
/* Update the hash table */ \
|
255
|
+
if (h->n_buckets > (h->size<<1)) { \
|
256
|
+
/* Clear "deleted" elements */ \
|
257
|
+
if (name##__resize(h, h->n_buckets - 1) < 0) \
|
258
|
+
return -1; \
|
259
|
+
} else if (name##__resize(h, h->n_buckets + 1) < 0) { \
|
260
|
+
return -1; \
|
261
|
+
} \
|
262
|
+
} \
|
263
|
+
GIT_ASSERT((h)->flags); \
|
264
|
+
GIT_ASSERT((h)->keys); \
|
265
|
+
/* TODO: to implement automatically shrinking; resize() already support shrinking */ \
|
266
|
+
{ \
|
267
|
+
uint32_t k, i, site, last, mask = h->n_buckets - 1, step = 0; \
|
268
|
+
x = site = h->n_buckets; \
|
269
|
+
k = __hash_fn(key); \
|
270
|
+
i = k & mask; \
|
271
|
+
if (GIT_HASHMAP_IS_EMPTY(h->flags, i)) { \
|
272
|
+
/* for speed up */ \
|
273
|
+
x = i; \
|
274
|
+
} else { \
|
275
|
+
last = i; \
|
276
|
+
while (!GIT_HASHMAP_IS_EMPTY(h->flags, i) && (GIT_HASHMAP_IS_DELETE(h->flags, i) || !__equal_fn(h->keys[i], key))) { \
|
277
|
+
if (GIT_HASHMAP_IS_DELETE(h->flags, i)) \
|
278
|
+
site = i; \
|
279
|
+
i = (i + (++step)) & mask; \
|
280
|
+
if (i == last) { \
|
281
|
+
x = site; \
|
282
|
+
break; \
|
283
|
+
} \
|
284
|
+
} \
|
285
|
+
if (x == h->n_buckets) { \
|
286
|
+
if (GIT_HASHMAP_IS_EMPTY(h->flags, i) && site != h->n_buckets) \
|
287
|
+
x = site; \
|
288
|
+
else \
|
289
|
+
x = i; \
|
290
|
+
} \
|
291
|
+
} \
|
292
|
+
} \
|
293
|
+
if (GIT_HASHMAP_IS_EMPTY(h->flags, x)) { \
|
294
|
+
/* not present at all */ \
|
295
|
+
h->keys[x] = key; \
|
296
|
+
GIT_HASHMAP_SET_BOTH_FALSE(h->flags, x); \
|
297
|
+
++h->size; \
|
298
|
+
++h->n_occupied; \
|
299
|
+
*key_exists = 1; \
|
300
|
+
} else if (GIT_HASHMAP_IS_DELETE(h->flags, x)) { \
|
301
|
+
/* deleted */ \
|
302
|
+
h->keys[x] = key; \
|
303
|
+
GIT_HASHMAP_SET_BOTH_FALSE(h->flags, x); \
|
304
|
+
++h->size; \
|
305
|
+
*key_exists = 1; \
|
306
|
+
} else { \
|
307
|
+
/* Don't touch h->keys[x] if present and not deleted */ \
|
308
|
+
*key_exists = 0; \
|
309
|
+
} \
|
310
|
+
*idx = x; \
|
311
|
+
return 0; \
|
312
|
+
} \
|
313
|
+
GIT_UNUSED_FUNCTION scope void name##_clear(name *h) \
|
314
|
+
{ \
|
315
|
+
if (h && h->flags) { \
|
316
|
+
memset(h->flags, 0xaa, GIT_HASHMAP_FLAGSIZE(h->n_buckets) * sizeof(uint32_t)); \
|
317
|
+
h->size = h->n_occupied = 0; \
|
318
|
+
} \
|
319
|
+
} \
|
320
|
+
GIT_UNUSED_FUNCTION scope void name##_dispose(name *h) \
|
321
|
+
{ \
|
322
|
+
git__free(h->flags); \
|
323
|
+
git__free(h->keys); \
|
324
|
+
git__free(h->vals); \
|
325
|
+
memset(h, 0, sizeof(name)); \
|
326
|
+
}
|
327
|
+
|
328
|
+
#define GIT_HASHMAP_FUNCTIONS(name, scope, key_t, val_t, __hash_fn, __equal_fn) \
|
329
|
+
GIT_HASHMAP__COMMON_FUNCTIONS(name, true, scope, key_t, val_t, __hash_fn, __equal_fn) \
|
330
|
+
\
|
331
|
+
GIT_UNUSED_FUNCTION scope int name##_get(val_t *out, name *h, key_t key) \
|
332
|
+
{ \
|
333
|
+
uint32_t idx; \
|
334
|
+
int error; \
|
335
|
+
if ((error = name##__idx(&idx, h, key)) == 0) \
|
336
|
+
*out = (h)->vals[idx]; \
|
337
|
+
return error; \
|
338
|
+
} \
|
339
|
+
GIT_UNUSED_FUNCTION scope int name##_put(name *h, key_t key, val_t val) \
|
340
|
+
{ \
|
341
|
+
uint32_t idx; \
|
342
|
+
bool key_exists; \
|
343
|
+
int error = name##__put_idx(&idx, &key_exists, h, key); \
|
344
|
+
if (error) \
|
345
|
+
return error; \
|
346
|
+
GIT_ASSERT((h)->vals); \
|
347
|
+
if (!key_exists) \
|
348
|
+
(h)->keys[idx] = key; \
|
349
|
+
(h)->vals[idx] = val; \
|
350
|
+
return 0; \
|
351
|
+
} \
|
352
|
+
GIT_UNUSED_FUNCTION scope int name##_iterate(git_hashmap_iter_t *iter, key_t *key, val_t *val, name *h) \
|
353
|
+
{ \
|
354
|
+
for (; *iter < h->n_buckets; (*iter)++) { \
|
355
|
+
if (GIT_HASHMAP_IS_EITHER(h->flags, *iter)) \
|
356
|
+
continue; \
|
357
|
+
if (key) \
|
358
|
+
*key = h->keys[*iter]; \
|
359
|
+
if (val) \
|
360
|
+
*val = h->vals[*iter]; \
|
361
|
+
(*iter)++; \
|
362
|
+
return 0; \
|
363
|
+
} \
|
364
|
+
return GIT_ITEROVER; \
|
365
|
+
} \
|
366
|
+
GIT_UNUSED_FUNCTION scope int name##_foreach(name *h, int (*cb)(key_t, val_t)) \
|
367
|
+
{ \
|
368
|
+
uint32_t idx = 0; \
|
369
|
+
key_t key; \
|
370
|
+
val_t val; \
|
371
|
+
int ret; \
|
372
|
+
while ((ret = name##_iterate(&idx, &key, &val, h)) == 0) { \
|
373
|
+
if ((ret = cb(key, val)) != 0) \
|
374
|
+
return ret; \
|
375
|
+
} \
|
376
|
+
return ret == GIT_ITEROVER ? 0 : ret; \
|
377
|
+
}
|
378
|
+
|
379
|
+
#define GIT_HASHSET_FUNCTIONS(name, scope, key_t, __hash_fn, __equal_fn) \
|
380
|
+
GIT_HASHMAP__COMMON_FUNCTIONS(name, false, scope, key_t, void *, __hash_fn, __equal_fn) \
|
381
|
+
\
|
382
|
+
GIT_UNUSED_FUNCTION scope int name##_add(name *h, key_t key) \
|
383
|
+
{ \
|
384
|
+
uint32_t idx; \
|
385
|
+
bool key_exists; \
|
386
|
+
int error = name##__put_idx(&idx, &key_exists, h, key); \
|
387
|
+
if (error) \
|
388
|
+
return error; \
|
389
|
+
if (!key_exists) { \
|
390
|
+
(h)->keys[idx] = key; \
|
391
|
+
} \
|
392
|
+
return 0; \
|
393
|
+
} \
|
394
|
+
GIT_UNUSED_FUNCTION scope int name##_iterate(git_hashmap_iter_t *iter, key_t *key, name *h) \
|
395
|
+
{ \
|
396
|
+
for (; *iter < h->n_buckets; (*iter)++) { \
|
397
|
+
if (GIT_HASHMAP_IS_EITHER(h->flags, *iter)) \
|
398
|
+
continue; \
|
399
|
+
*key = h->keys[*iter]; \
|
400
|
+
return 0; \
|
401
|
+
} \
|
402
|
+
return GIT_ITEROVER; \
|
403
|
+
} \
|
404
|
+
GIT_UNUSED_FUNCTION scope int name##_foreach(name *h, int (*cb)(key_t)) \
|
405
|
+
{ \
|
406
|
+
git_hashmap_iter_t iter = 0; \
|
407
|
+
key_t key; \
|
408
|
+
int ret; \
|
409
|
+
while ((ret = name##_iterate(&iter, &key, h)) == 0) { \
|
410
|
+
if ((ret = cb(key)) != 0) \
|
411
|
+
return ret; \
|
412
|
+
} \
|
413
|
+
return ret == GIT_ITEROVER ? 0 : ret; \
|
414
|
+
}
|
415
|
+
|
416
|
+
|
417
|
+
#define GIT_HASHSET_SETUP(name, key_t, __hash_fn, __equal_fn) \
|
418
|
+
GIT_HASHSET_STRUCT(name, key_t) \
|
419
|
+
GIT_HASHSET_FUNCTIONS(name, GIT_HASHMAP_INLINE, key_t, __hash_fn, __equal_fn)
|
420
|
+
#define GIT_HASHMAP_SETUP(name, key_t, val_t, __hash_fn, __equal_fn) \
|
421
|
+
GIT_HASHMAP_STRUCT(name, key_t, val_t) \
|
422
|
+
GIT_HASHMAP_FUNCTIONS(name, GIT_HASHMAP_INLINE, key_t, val_t, __hash_fn, __equal_fn)
|
423
|
+
|
424
|
+
#endif
|
@@ -0,0 +1,43 @@
|
|
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
|
+
#ifndef INCLUDE_hashmap_str_h__
|
8
|
+
#define INCLUDE_hashmap_str_h__
|
9
|
+
|
10
|
+
#include "hashmap.h"
|
11
|
+
|
12
|
+
GIT_INLINE(uint32_t) git_hashmap_str_hash(const char *s)
|
13
|
+
{
|
14
|
+
uint32_t h = (uint32_t)*s;
|
15
|
+
|
16
|
+
if (h) {
|
17
|
+
for (++s; *s; ++s)
|
18
|
+
h = (h << 5) - h + (uint32_t)*s;
|
19
|
+
}
|
20
|
+
|
21
|
+
return h;
|
22
|
+
}
|
23
|
+
|
24
|
+
GIT_INLINE(bool) git_hashmap_str_equal(const char *one, const char *two)
|
25
|
+
{
|
26
|
+
return strcmp(one, two) == 0;
|
27
|
+
}
|
28
|
+
|
29
|
+
#define GIT_HASHMAP_STR_STRUCT(name, val_t) \
|
30
|
+
GIT_HASHMAP_STRUCT(name, const char *, val_t)
|
31
|
+
#define GIT_HASHMAP_STR_PROTOTYPES(name, val_t) \
|
32
|
+
GIT_HASHMAP_PROTOTYPES(name, const char *, val_t)
|
33
|
+
#define GIT_HASHMAP_STR_FUNCTIONS(name, scope, val_t) \
|
34
|
+
GIT_HASHMAP_FUNCTIONS(name, scope, const char *, val_t, git_hashmap_str_hash, git_hashmap_str_equal)
|
35
|
+
|
36
|
+
#define GIT_HASHMAP_STR_SETUP(name, val_t) \
|
37
|
+
GIT_HASHMAP_STR_STRUCT(name, val_t) \
|
38
|
+
GIT_HASHMAP_STR_FUNCTIONS(name, GIT_HASHMAP_INLINE, val_t)
|
39
|
+
|
40
|
+
GIT_HASHSET_SETUP(git_hashset_str, const char *, git_hashmap_str_hash, git_hashmap_str_equal);
|
41
|
+
GIT_HASHMAP_SETUP(git_hashmap_str, const char *, void *, git_hashmap_str_hash, git_hashmap_str_equal);
|
42
|
+
|
43
|
+
#endif
|
@@ -89,7 +89,9 @@ GIT_INLINE(int) git__is_int(int64_t p)
|
|
89
89
|
/* Use Microsoft's safe integer handling functions where available */
|
90
90
|
#elif defined(_MSC_VER)
|
91
91
|
|
92
|
-
#
|
92
|
+
# if !defined(ENABLE_INTSAFE_SIGNED_FUNCTIONS)
|
93
|
+
# define ENABLE_INTSAFE_SIGNED_FUNCTIONS
|
94
|
+
# endif
|
93
95
|
# include <intsafe.h>
|
94
96
|
|
95
97
|
# define git__add_sizet_overflow(out, one, two) \
|