rugged 1.0.0 → 1.2.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/LICENSE +1 -0
- data/README.md +3 -3
- data/ext/rugged/rugged.c +7 -4
- data/ext/rugged/rugged_commit.c +1 -1
- data/ext/rugged/rugged_config.c +1 -1
- data/ext/rugged/rugged_object.c +1 -1
- data/ext/rugged/rugged_remote.c +32 -2
- data/ext/rugged/rugged_repo.c +13 -3
- data/lib/rugged/commit.rb +17 -4
- data/lib/rugged/repository.rb +7 -8
- data/lib/rugged/submodule_collection.rb +4 -4
- data/lib/rugged/version.rb +1 -1
- data/vendor/libgit2/CMakeLists.txt +41 -74
- data/vendor/libgit2/COPYING +109 -1
- data/vendor/libgit2/cmake/{Modules/AddCFlagIfSupported.cmake → AddCFlagIfSupported.cmake} +0 -0
- data/vendor/libgit2/cmake/{Modules/EnableWarnings.cmake → EnableWarnings.cmake} +0 -0
- data/vendor/libgit2/cmake/{Modules/FindCoreFoundation.cmake → FindCoreFoundation.cmake} +0 -0
- data/vendor/libgit2/cmake/{Modules/FindGSSAPI.cmake → FindGSSAPI.cmake} +0 -0
- data/vendor/libgit2/cmake/{Modules/FindGSSFramework.cmake → FindGSSFramework.cmake} +0 -0
- data/vendor/libgit2/cmake/{Modules/FindHTTP_Parser.cmake → FindHTTP_Parser.cmake} +0 -0
- data/vendor/libgit2/cmake/{Modules/FindIconv.cmake → FindIconv.cmake} +0 -0
- data/vendor/libgit2/cmake/{Modules/FindPCRE.cmake → FindPCRE.cmake} +0 -0
- data/vendor/libgit2/cmake/{Modules/FindPCRE2.cmake → FindPCRE2.cmake} +0 -0
- data/vendor/libgit2/cmake/{Modules/FindPkgLibraries.cmake → FindPkgLibraries.cmake} +0 -0
- data/vendor/libgit2/cmake/{Modules/FindSecurity.cmake → FindSecurity.cmake} +0 -0
- data/vendor/libgit2/cmake/{Modules/FindStatNsec.cmake → FindStatNsec.cmake} +0 -0
- data/vendor/libgit2/cmake/Findfutimens.cmake +14 -0
- data/vendor/libgit2/cmake/{Modules/FindmbedTLS.cmake → FindmbedTLS.cmake} +0 -0
- data/vendor/libgit2/cmake/{Modules/IdeSplitSources.cmake → IdeSplitSources.cmake} +0 -0
- data/vendor/libgit2/cmake/{Modules/PkgBuildConfig.cmake → PkgBuildConfig.cmake} +0 -0
- data/vendor/libgit2/cmake/{Modules/SanitizeBool.cmake → SanitizeBool.cmake} +0 -0
- data/vendor/libgit2/cmake/{Modules/SelectGSSAPI.cmake → SelectGSSAPI.cmake} +18 -26
- data/vendor/libgit2/cmake/{Modules/SelectHTTPSBackend.cmake → SelectHTTPSBackend.cmake} +29 -32
- data/vendor/libgit2/cmake/{Modules/SelectHashes.cmake → SelectHashes.cmake} +21 -28
- data/vendor/libgit2/deps/chromium-zlib/CMakeLists.txt +101 -0
- data/vendor/libgit2/deps/http-parser/CMakeLists.txt +4 -3
- data/vendor/libgit2/deps/ntlmclient/CMakeLists.txt +24 -10
- data/vendor/libgit2/deps/ntlmclient/compat.h +0 -27
- data/vendor/libgit2/deps/ntlmclient/crypt.h +14 -9
- data/vendor/libgit2/deps/ntlmclient/crypt_commoncrypto.c +20 -20
- data/vendor/libgit2/deps/ntlmclient/crypt_commoncrypto.h +3 -3
- data/vendor/libgit2/deps/ntlmclient/crypt_mbedtls.c +37 -36
- data/vendor/libgit2/deps/ntlmclient/crypt_mbedtls.h +4 -3
- data/vendor/libgit2/deps/ntlmclient/crypt_openssl.c +178 -51
- data/vendor/libgit2/deps/ntlmclient/crypt_openssl.h +74 -5
- data/vendor/libgit2/deps/ntlmclient/ntlm.c +164 -135
- data/vendor/libgit2/deps/ntlmclient/ntlm.h +13 -9
- data/vendor/libgit2/deps/ntlmclient/ntlmclient.h +16 -3
- data/vendor/libgit2/deps/ntlmclient/unicode.h +10 -4
- data/vendor/libgit2/deps/ntlmclient/unicode_builtin.c +16 -27
- data/vendor/libgit2/deps/ntlmclient/unicode_builtin.h +20 -0
- data/vendor/libgit2/deps/ntlmclient/unicode_iconv.c +28 -52
- data/vendor/libgit2/deps/ntlmclient/unicode_iconv.h +22 -0
- data/vendor/libgit2/deps/ntlmclient/util.c +15 -1
- data/vendor/libgit2/deps/ntlmclient/util.h +2 -1
- data/vendor/libgit2/deps/pcre/LICENCE +93 -0
- data/vendor/libgit2/deps/pcre/pcre.h +2 -2
- data/vendor/libgit2/deps/pcre/pcre_compile.c +29 -17
- data/vendor/libgit2/deps/pcre/pcre_jit_compile.c +4 -4
- data/vendor/libgit2/deps/pcre/pcreposix.c +2 -3
- data/vendor/libgit2/deps/zlib/CMakeLists.txt +6 -5
- data/vendor/libgit2/deps/zlib/deflate.c +1 -0
- data/vendor/libgit2/include/git2/annotated_commit.h +1 -1
- data/vendor/libgit2/include/git2/apply.h +2 -0
- data/vendor/libgit2/include/git2/attr.h +89 -0
- data/vendor/libgit2/include/git2/blame.h +95 -42
- data/vendor/libgit2/include/git2/blob.h +31 -3
- data/vendor/libgit2/include/git2/branch.h +25 -0
- data/vendor/libgit2/include/git2/cert.h +42 -5
- data/vendor/libgit2/include/git2/checkout.h +28 -12
- data/vendor/libgit2/include/git2/commit.h +35 -19
- data/vendor/libgit2/include/git2/common.h +33 -6
- data/vendor/libgit2/include/git2/config.h +1 -1
- data/vendor/libgit2/include/git2/deprecated.h +248 -8
- data/vendor/libgit2/include/git2/diff.h +35 -20
- data/vendor/libgit2/include/git2/errors.h +8 -7
- data/vendor/libgit2/include/git2/filter.h +57 -17
- data/vendor/libgit2/include/git2/graph.h +20 -2
- data/vendor/libgit2/include/git2/index.h +4 -5
- data/vendor/libgit2/include/git2/indexer.h +2 -1
- data/vendor/libgit2/include/git2/odb.h +44 -20
- data/vendor/libgit2/include/git2/pack.h +1 -1
- data/vendor/libgit2/include/git2/patch.h +8 -0
- data/vendor/libgit2/include/git2/rebase.h +25 -1
- data/vendor/libgit2/include/git2/refs.h +9 -5
- data/vendor/libgit2/include/git2/remote.h +59 -6
- data/vendor/libgit2/include/git2/repository.h +95 -52
- data/vendor/libgit2/include/git2/revparse.h +5 -5
- data/vendor/libgit2/include/git2/status.h +115 -59
- data/vendor/libgit2/include/git2/strarray.h +6 -10
- data/vendor/libgit2/include/git2/submodule.h +9 -0
- data/vendor/libgit2/include/git2/sys/commit_graph.h +174 -0
- data/vendor/libgit2/include/git2/sys/filter.h +49 -28
- data/vendor/libgit2/include/git2/sys/midx.h +74 -0
- data/vendor/libgit2/include/git2/sys/odb_backend.h +7 -0
- data/vendor/libgit2/include/git2/sys/transport.h +1 -0
- data/vendor/libgit2/include/git2/tag.h +12 -0
- data/vendor/libgit2/include/git2/transport.h +1 -1
- data/vendor/libgit2/include/git2/tree.h +2 -14
- data/vendor/libgit2/include/git2/types.h +9 -0
- data/vendor/libgit2/include/git2/version.h +3 -3
- data/vendor/libgit2/include/git2/worktree.h +1 -0
- data/vendor/libgit2/src/CMakeLists.txt +77 -44
- data/vendor/libgit2/src/alloc.c +21 -8
- data/vendor/libgit2/src/allocators/failalloc.c +92 -0
- data/vendor/libgit2/src/allocators/failalloc.h +23 -0
- data/vendor/libgit2/src/allocators/stdalloc.c +41 -10
- data/vendor/libgit2/src/allocators/win32_leakcheck.c +118 -0
- data/vendor/libgit2/src/allocators/{win32_crtdbg.h → win32_leakcheck.h} +3 -3
- data/vendor/libgit2/src/annotated_commit.c +21 -9
- data/vendor/libgit2/src/apply.c +21 -8
- data/vendor/libgit2/src/array.h +11 -11
- data/vendor/libgit2/src/assert_safe.h +58 -0
- data/vendor/libgit2/src/attr.c +181 -74
- data/vendor/libgit2/src/attr_file.c +92 -42
- data/vendor/libgit2/src/attr_file.h +32 -11
- data/vendor/libgit2/src/attrcache.c +44 -40
- data/vendor/libgit2/src/attrcache.h +4 -5
- data/vendor/libgit2/src/blame.c +28 -15
- data/vendor/libgit2/src/blame_git.c +6 -3
- data/vendor/libgit2/src/blob.c +46 -24
- data/vendor/libgit2/src/branch.c +87 -37
- data/vendor/libgit2/src/buffer.c +339 -27
- data/vendor/libgit2/src/buffer.h +153 -2
- data/vendor/libgit2/src/cache.c +3 -24
- data/vendor/libgit2/src/cache.h +7 -7
- data/vendor/libgit2/src/cc-compat.h +10 -2
- data/vendor/libgit2/src/checkout.c +97 -98
- data/vendor/libgit2/src/cherrypick.c +8 -2
- data/vendor/libgit2/src/clone.c +104 -29
- data/vendor/libgit2/src/commit.c +41 -28
- data/vendor/libgit2/src/commit_graph.c +1209 -0
- data/vendor/libgit2/src/commit_graph.h +162 -0
- data/vendor/libgit2/src/commit_list.c +46 -0
- data/vendor/libgit2/src/commit_list.h +2 -0
- data/vendor/libgit2/src/common.h +26 -2
- data/vendor/libgit2/src/config.c +40 -22
- data/vendor/libgit2/src/config_cache.c +9 -4
- data/vendor/libgit2/src/config_entries.c +35 -27
- data/vendor/libgit2/src/config_file.c +25 -8
- data/vendor/libgit2/src/config_parse.c +5 -7
- data/vendor/libgit2/src/config_snapshot.c +2 -1
- data/vendor/libgit2/src/crlf.c +16 -6
- data/vendor/libgit2/src/date.c +4 -3
- data/vendor/libgit2/src/delta.c +1 -1
- data/vendor/libgit2/src/describe.c +11 -4
- data/vendor/libgit2/src/diff.c +23 -19
- data/vendor/libgit2/src/diff_driver.c +21 -17
- data/vendor/libgit2/src/diff_file.c +5 -7
- data/vendor/libgit2/src/diff_generate.c +56 -28
- data/vendor/libgit2/src/diff_parse.c +2 -3
- data/vendor/libgit2/src/diff_print.c +81 -65
- data/vendor/libgit2/src/diff_stats.c +19 -16
- data/vendor/libgit2/src/diff_tform.c +13 -13
- data/vendor/libgit2/src/diff_xdiff.c +4 -2
- data/vendor/libgit2/src/diff_xdiff.h +1 -1
- data/vendor/libgit2/src/errors.c +26 -19
- data/vendor/libgit2/src/features.h.in +5 -1
- data/vendor/libgit2/src/fetch.c +7 -2
- data/vendor/libgit2/src/fetchhead.c +8 -4
- data/vendor/libgit2/src/filebuf.c +9 -7
- data/vendor/libgit2/src/filter.c +209 -113
- data/vendor/libgit2/src/filter.h +24 -5
- data/vendor/libgit2/src/futils.c +8 -8
- data/vendor/libgit2/src/futils.h +4 -4
- data/vendor/libgit2/src/graph.c +64 -9
- data/vendor/libgit2/src/hash/sha1/collisiondetect.c +3 -3
- data/vendor/libgit2/src/hash/sha1/common_crypto.c +3 -3
- data/vendor/libgit2/src/hash/sha1/generic.h +1 -1
- data/vendor/libgit2/src/hash/sha1/mbedtls.c +12 -12
- data/vendor/libgit2/src/hash/sha1/openssl.c +3 -3
- data/vendor/libgit2/src/hash/sha1/sha1dc/sha1.c +0 -2
- data/vendor/libgit2/src/hash/sha1/win32.c +15 -11
- data/vendor/libgit2/src/hash.c +16 -13
- data/vendor/libgit2/src/hash.h +1 -1
- data/vendor/libgit2/src/hashsig.c +23 -10
- data/vendor/libgit2/src/ident.c +13 -3
- data/vendor/libgit2/src/idxmap.c +0 -22
- data/vendor/libgit2/src/ignore.c +35 -19
- data/vendor/libgit2/src/index.c +126 -84
- data/vendor/libgit2/src/index.h +1 -1
- data/vendor/libgit2/src/indexer.c +60 -36
- data/vendor/libgit2/src/integer.h +79 -2
- data/vendor/libgit2/src/iterator.c +40 -28
- data/vendor/libgit2/src/iterator.h +1 -1
- data/vendor/libgit2/src/khash.h +2 -11
- data/vendor/libgit2/src/{settings.c → libgit2.c} +125 -49
- data/vendor/libgit2/src/libgit2.h +15 -0
- data/vendor/libgit2/src/mailmap.c +23 -10
- data/vendor/libgit2/src/map.h +3 -3
- data/vendor/libgit2/src/merge.c +108 -46
- data/vendor/libgit2/src/merge.h +2 -1
- data/vendor/libgit2/src/merge_driver.c +19 -13
- data/vendor/libgit2/src/merge_file.c +15 -9
- data/vendor/libgit2/src/message.c +3 -1
- data/vendor/libgit2/src/midx.c +879 -0
- data/vendor/libgit2/src/midx.h +110 -0
- data/vendor/libgit2/src/mwindow.c +214 -95
- data/vendor/libgit2/src/mwindow.h +3 -3
- data/vendor/libgit2/src/net.c +133 -4
- data/vendor/libgit2/src/net.h +16 -2
- data/vendor/libgit2/src/netops.c +6 -4
- data/vendor/libgit2/src/netops.h +2 -2
- data/vendor/libgit2/src/notes.c +10 -10
- data/vendor/libgit2/src/object.c +24 -15
- data/vendor/libgit2/src/odb.c +298 -57
- data/vendor/libgit2/src/odb.h +16 -2
- data/vendor/libgit2/src/odb_loose.c +31 -21
- data/vendor/libgit2/src/odb_mempack.c +3 -1
- data/vendor/libgit2/src/odb_pack.c +391 -114
- data/vendor/libgit2/src/oid.c +7 -4
- data/vendor/libgit2/src/pack-objects.c +83 -69
- data/vendor/libgit2/src/pack.c +383 -150
- data/vendor/libgit2/src/pack.h +44 -9
- data/vendor/libgit2/src/patch.c +14 -7
- data/vendor/libgit2/src/patch_generate.c +3 -5
- data/vendor/libgit2/src/patch_parse.c +6 -3
- data/vendor/libgit2/src/path.c +102 -57
- data/vendor/libgit2/src/path.h +79 -6
- data/vendor/libgit2/src/pathspec.c +12 -11
- data/vendor/libgit2/src/pool.c +34 -22
- data/vendor/libgit2/src/pool.h +9 -1
- data/vendor/libgit2/src/posix.c +43 -12
- data/vendor/libgit2/src/posix.h +9 -0
- data/vendor/libgit2/src/proxy.c +2 -0
- data/vendor/libgit2/src/push.c +2 -0
- data/vendor/libgit2/src/reader.c +10 -6
- data/vendor/libgit2/src/rebase.c +95 -49
- data/vendor/libgit2/src/refdb.c +165 -13
- data/vendor/libgit2/src/refdb.h +69 -0
- data/vendor/libgit2/src/refdb_fs.c +144 -152
- data/vendor/libgit2/src/reflog.c +21 -20
- data/vendor/libgit2/src/refs.c +151 -231
- data/vendor/libgit2/src/refs.h +2 -20
- data/vendor/libgit2/src/refspec.c +80 -44
- data/vendor/libgit2/src/regexp.c +2 -2
- data/vendor/libgit2/src/remote.c +312 -121
- data/vendor/libgit2/src/remote.h +2 -1
- data/vendor/libgit2/src/repository.c +351 -189
- data/vendor/libgit2/src/repository.h +23 -29
- data/vendor/libgit2/src/reset.c +7 -6
- data/vendor/libgit2/src/revert.c +8 -2
- data/vendor/libgit2/src/revparse.c +19 -13
- data/vendor/libgit2/src/revwalk.c +35 -20
- data/vendor/libgit2/src/runtime.c +162 -0
- data/vendor/libgit2/src/runtime.h +62 -0
- data/vendor/libgit2/src/{refdb_fs.h → settings.h} +3 -11
- data/vendor/libgit2/src/signature.c +6 -5
- data/vendor/libgit2/src/sortedcache.c +2 -3
- data/vendor/libgit2/src/sortedcache.h +10 -8
- data/vendor/libgit2/src/stash.c +7 -3
- data/vendor/libgit2/src/status.c +9 -4
- data/vendor/libgit2/src/strarray.c +64 -0
- data/vendor/libgit2/src/streams/mbedtls.c +14 -17
- data/vendor/libgit2/src/streams/mbedtls.h +1 -1
- data/vendor/libgit2/src/streams/openssl.c +113 -207
- data/vendor/libgit2/src/streams/openssl.h +9 -1
- data/vendor/libgit2/src/streams/openssl_dynamic.c +309 -0
- data/vendor/libgit2/src/streams/openssl_dynamic.h +348 -0
- data/vendor/libgit2/src/streams/openssl_legacy.c +203 -0
- data/vendor/libgit2/src/streams/openssl_legacy.h +63 -0
- data/vendor/libgit2/src/streams/registry.c +10 -9
- data/vendor/libgit2/src/streams/socket.c +6 -2
- data/vendor/libgit2/src/streams/stransport.c +6 -3
- data/vendor/libgit2/src/streams/tls.c +5 -3
- data/vendor/libgit2/src/submodule.c +134 -66
- data/vendor/libgit2/src/submodule.h +9 -9
- data/vendor/libgit2/src/sysdir.c +8 -26
- data/vendor/libgit2/src/sysdir.h +0 -11
- data/vendor/libgit2/src/tag.c +49 -11
- data/vendor/libgit2/src/thread.c +140 -0
- data/vendor/libgit2/src/thread.h +479 -0
- data/vendor/libgit2/src/threadstate.c +83 -0
- data/vendor/libgit2/src/threadstate.h +24 -0
- data/vendor/libgit2/src/trace.c +2 -2
- data/vendor/libgit2/src/trace.h +17 -13
- data/vendor/libgit2/src/transaction.c +21 -9
- data/vendor/libgit2/src/transport.c +3 -3
- data/vendor/libgit2/src/transports/auth.c +1 -1
- data/vendor/libgit2/src/transports/auth_negotiate.c +11 -4
- data/vendor/libgit2/src/transports/auth_ntlm.c +10 -6
- data/vendor/libgit2/src/transports/credential.c +17 -7
- data/vendor/libgit2/src/transports/credential_helpers.c +2 -0
- data/vendor/libgit2/src/transports/git.c +1 -3
- data/vendor/libgit2/src/transports/http.c +19 -17
- data/vendor/libgit2/src/transports/http.h +1 -0
- data/vendor/libgit2/src/transports/httpclient.c +84 -42
- data/vendor/libgit2/src/transports/httpclient.h +1 -1
- data/vendor/libgit2/src/transports/local.c +5 -5
- data/vendor/libgit2/src/transports/smart.c +14 -9
- data/vendor/libgit2/src/transports/smart.h +1 -1
- data/vendor/libgit2/src/transports/smart_protocol.c +11 -5
- data/vendor/libgit2/src/transports/ssh.c +51 -17
- data/vendor/libgit2/src/transports/winhttp.c +156 -88
- data/vendor/libgit2/src/tree.c +100 -77
- data/vendor/libgit2/src/tree.h +1 -0
- data/vendor/libgit2/src/tsort.c +0 -2
- data/vendor/libgit2/src/unix/map.c +3 -1
- data/vendor/libgit2/src/unix/posix.h +16 -1
- data/vendor/libgit2/src/unix/pthread.h +2 -1
- data/vendor/libgit2/src/utf8.c +150 -0
- data/vendor/libgit2/src/utf8.h +52 -0
- data/vendor/libgit2/src/util.c +74 -183
- data/vendor/libgit2/src/util.h +33 -39
- data/vendor/libgit2/src/vector.c +23 -19
- data/vendor/libgit2/src/vector.h +4 -2
- data/vendor/libgit2/src/win32/findfile.c +4 -2
- data/vendor/libgit2/src/win32/git2.rc +18 -3
- data/vendor/libgit2/src/win32/map.c +1 -1
- data/vendor/libgit2/src/win32/msvc-compat.h +9 -1
- data/vendor/libgit2/src/win32/path_w32.c +23 -25
- data/vendor/libgit2/src/win32/path_w32.h +0 -1
- data/vendor/libgit2/src/win32/posix_w32.c +77 -1
- data/vendor/libgit2/src/win32/precompiled.h +0 -1
- data/vendor/libgit2/src/win32/reparse.h +4 -4
- data/vendor/libgit2/src/win32/thread.c +24 -15
- data/vendor/libgit2/src/win32/thread.h +1 -1
- data/vendor/libgit2/src/win32/w32_buffer.c +3 -3
- data/vendor/libgit2/src/win32/w32_common.h +18 -9
- data/vendor/libgit2/src/win32/{w32_crtdbg_stacktrace.c → w32_leakcheck.c} +269 -33
- data/vendor/libgit2/src/win32/w32_leakcheck.h +222 -0
- data/vendor/libgit2/src/win32/w32_util.h +6 -6
- data/vendor/libgit2/src/worktree.c +37 -15
- data/vendor/libgit2/src/zstream.c +1 -1
- metadata +56 -38
- data/vendor/libgit2/cmake/Modules/CheckPrototypeDefinition.c.in +0 -29
- data/vendor/libgit2/cmake/Modules/CheckPrototypeDefinition.cmake +0 -96
- data/vendor/libgit2/src/allocators/win32_crtdbg.c +0 -118
- data/vendor/libgit2/src/buf_text.c +0 -316
- data/vendor/libgit2/src/buf_text.h +0 -122
- data/vendor/libgit2/src/global.c +0 -361
- data/vendor/libgit2/src/global.h +0 -41
- data/vendor/libgit2/src/thread-utils.c +0 -58
- data/vendor/libgit2/src/thread-utils.h +0 -246
- data/vendor/libgit2/src/win32/w32_crtdbg_stacktrace.h +0 -127
- data/vendor/libgit2/src/win32/w32_stack.c +0 -188
- data/vendor/libgit2/src/win32/w32_stack.h +0 -140
data/vendor/libgit2/src/global.h
DELETED
|
@@ -1,41 +0,0 @@
|
|
|
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_global_h__
|
|
8
|
-
#define INCLUDE_global_h__
|
|
9
|
-
|
|
10
|
-
#include "common.h"
|
|
11
|
-
|
|
12
|
-
#include "mwindow.h"
|
|
13
|
-
#include "hash.h"
|
|
14
|
-
|
|
15
|
-
typedef struct {
|
|
16
|
-
git_error *last_error;
|
|
17
|
-
git_error error_t;
|
|
18
|
-
git_buf error_buf;
|
|
19
|
-
char oid_fmt[GIT_OID_HEXSZ+1];
|
|
20
|
-
|
|
21
|
-
/* On Windows, this is the current child thread that was started by
|
|
22
|
-
* `git_thread_create`. This is used to set the thread's exit code
|
|
23
|
-
* when terminated by `git_thread_exit`. It is unused on POSIX.
|
|
24
|
-
*/
|
|
25
|
-
git_thread *current_thread;
|
|
26
|
-
} git_global_st;
|
|
27
|
-
|
|
28
|
-
git_global_st *git__global_state(void);
|
|
29
|
-
|
|
30
|
-
extern git_mutex git__mwindow_mutex;
|
|
31
|
-
|
|
32
|
-
#define GIT_GLOBAL (git__global_state())
|
|
33
|
-
|
|
34
|
-
typedef void (*git_global_shutdown_fn)(void);
|
|
35
|
-
|
|
36
|
-
extern void git__on_shutdown(git_global_shutdown_fn callback);
|
|
37
|
-
|
|
38
|
-
extern const char *git_libgit2__user_agent(void);
|
|
39
|
-
extern const char *git_libgit2__ssl_ciphers(void);
|
|
40
|
-
|
|
41
|
-
#endif
|
|
@@ -1,58 +0,0 @@
|
|
|
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 "common.h"
|
|
9
|
-
#include "thread-utils.h"
|
|
10
|
-
|
|
11
|
-
#ifdef _WIN32
|
|
12
|
-
#ifndef WIN32_LEAN_AND_MEAN
|
|
13
|
-
# define WIN32_LEAN_AND_MEAN
|
|
14
|
-
#endif
|
|
15
|
-
# include <windows.h>
|
|
16
|
-
#elif defined(hpux) || defined(__hpux) || defined(_hpux)
|
|
17
|
-
# include <sys/pstat.h>
|
|
18
|
-
#endif
|
|
19
|
-
|
|
20
|
-
/*
|
|
21
|
-
* By doing this in two steps we can at least get
|
|
22
|
-
* the function to be somewhat coherent, even
|
|
23
|
-
* with this disgusting nest of #ifdefs.
|
|
24
|
-
*/
|
|
25
|
-
#ifndef _SC_NPROCESSORS_ONLN
|
|
26
|
-
# ifdef _SC_NPROC_ONLN
|
|
27
|
-
# define _SC_NPROCESSORS_ONLN _SC_NPROC_ONLN
|
|
28
|
-
# elif defined _SC_CRAY_NCPU
|
|
29
|
-
# define _SC_NPROCESSORS_ONLN _SC_CRAY_NCPU
|
|
30
|
-
# endif
|
|
31
|
-
#endif
|
|
32
|
-
|
|
33
|
-
int git_online_cpus(void)
|
|
34
|
-
{
|
|
35
|
-
#ifdef _SC_NPROCESSORS_ONLN
|
|
36
|
-
long ncpus;
|
|
37
|
-
#endif
|
|
38
|
-
|
|
39
|
-
#ifdef _WIN32
|
|
40
|
-
SYSTEM_INFO info;
|
|
41
|
-
GetSystemInfo(&info);
|
|
42
|
-
|
|
43
|
-
if ((int)info.dwNumberOfProcessors > 0)
|
|
44
|
-
return (int)info.dwNumberOfProcessors;
|
|
45
|
-
#elif defined(hpux) || defined(__hpux) || defined(_hpux)
|
|
46
|
-
struct pst_dynamic psd;
|
|
47
|
-
|
|
48
|
-
if (!pstat_getdynamic(&psd, sizeof(psd), (size_t)1, 0))
|
|
49
|
-
return (int)psd.psd_proc_cnt;
|
|
50
|
-
#endif
|
|
51
|
-
|
|
52
|
-
#ifdef _SC_NPROCESSORS_ONLN
|
|
53
|
-
if ((ncpus = (long)sysconf(_SC_NPROCESSORS_ONLN)) > 0)
|
|
54
|
-
return (int)ncpus;
|
|
55
|
-
#endif
|
|
56
|
-
|
|
57
|
-
return 1;
|
|
58
|
-
}
|
|
@@ -1,246 +0,0 @@
|
|
|
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_thread_utils_h__
|
|
8
|
-
#define INCLUDE_thread_utils_h__
|
|
9
|
-
|
|
10
|
-
#if defined(__GNUC__) && defined(GIT_THREADS)
|
|
11
|
-
# if (__GNUC__ < 4 || (__GNUC__ == 4 && __GNUC_MINOR__ < 1))
|
|
12
|
-
# error Atomic primitives do not exist on this version of gcc; configure libgit2 with -DTHREADSAFE=OFF
|
|
13
|
-
# endif
|
|
14
|
-
#endif
|
|
15
|
-
|
|
16
|
-
/* Common operations even if threading has been disabled */
|
|
17
|
-
typedef struct {
|
|
18
|
-
#if defined(GIT_WIN32)
|
|
19
|
-
volatile long val;
|
|
20
|
-
#else
|
|
21
|
-
volatile int val;
|
|
22
|
-
#endif
|
|
23
|
-
} git_atomic;
|
|
24
|
-
|
|
25
|
-
#ifdef GIT_ARCH_64
|
|
26
|
-
|
|
27
|
-
typedef struct {
|
|
28
|
-
#if defined(GIT_WIN32)
|
|
29
|
-
__int64 val;
|
|
30
|
-
#else
|
|
31
|
-
int64_t val;
|
|
32
|
-
#endif
|
|
33
|
-
} git_atomic64;
|
|
34
|
-
|
|
35
|
-
typedef git_atomic64 git_atomic_ssize;
|
|
36
|
-
|
|
37
|
-
#define git_atomic_ssize_add git_atomic64_add
|
|
38
|
-
|
|
39
|
-
#else
|
|
40
|
-
|
|
41
|
-
typedef git_atomic git_atomic_ssize;
|
|
42
|
-
|
|
43
|
-
#define git_atomic_ssize_add git_atomic_add
|
|
44
|
-
|
|
45
|
-
#endif
|
|
46
|
-
|
|
47
|
-
#ifdef GIT_THREADS
|
|
48
|
-
|
|
49
|
-
#ifdef GIT_WIN32
|
|
50
|
-
# include "win32/thread.h"
|
|
51
|
-
#else
|
|
52
|
-
# include "unix/pthread.h"
|
|
53
|
-
#endif
|
|
54
|
-
|
|
55
|
-
GIT_INLINE(void) git_atomic_set(git_atomic *a, int val)
|
|
56
|
-
{
|
|
57
|
-
#if defined(GIT_WIN32)
|
|
58
|
-
InterlockedExchange(&a->val, (LONG)val);
|
|
59
|
-
#elif defined(__GNUC__)
|
|
60
|
-
__sync_lock_test_and_set(&a->val, val);
|
|
61
|
-
#else
|
|
62
|
-
# error "Unsupported architecture for atomic operations"
|
|
63
|
-
#endif
|
|
64
|
-
}
|
|
65
|
-
|
|
66
|
-
GIT_INLINE(int) git_atomic_inc(git_atomic *a)
|
|
67
|
-
{
|
|
68
|
-
#if defined(GIT_WIN32)
|
|
69
|
-
return InterlockedIncrement(&a->val);
|
|
70
|
-
#elif defined(__GNUC__)
|
|
71
|
-
return __sync_add_and_fetch(&a->val, 1);
|
|
72
|
-
#else
|
|
73
|
-
# error "Unsupported architecture for atomic operations"
|
|
74
|
-
#endif
|
|
75
|
-
}
|
|
76
|
-
|
|
77
|
-
GIT_INLINE(int) git_atomic_add(git_atomic *a, int32_t addend)
|
|
78
|
-
{
|
|
79
|
-
#if defined(GIT_WIN32)
|
|
80
|
-
return InterlockedExchangeAdd(&a->val, addend);
|
|
81
|
-
#elif defined(__GNUC__)
|
|
82
|
-
return __sync_add_and_fetch(&a->val, addend);
|
|
83
|
-
#else
|
|
84
|
-
# error "Unsupported architecture for atomic operations"
|
|
85
|
-
#endif
|
|
86
|
-
}
|
|
87
|
-
|
|
88
|
-
GIT_INLINE(int) git_atomic_dec(git_atomic *a)
|
|
89
|
-
{
|
|
90
|
-
#if defined(GIT_WIN32)
|
|
91
|
-
return InterlockedDecrement(&a->val);
|
|
92
|
-
#elif defined(__GNUC__)
|
|
93
|
-
return __sync_sub_and_fetch(&a->val, 1);
|
|
94
|
-
#else
|
|
95
|
-
# error "Unsupported architecture for atomic operations"
|
|
96
|
-
#endif
|
|
97
|
-
}
|
|
98
|
-
|
|
99
|
-
GIT_INLINE(void *) git___compare_and_swap(
|
|
100
|
-
void * volatile *ptr, void *oldval, void *newval)
|
|
101
|
-
{
|
|
102
|
-
volatile void *foundval;
|
|
103
|
-
#if defined(GIT_WIN32)
|
|
104
|
-
foundval = InterlockedCompareExchangePointer((volatile PVOID *)ptr, newval, oldval);
|
|
105
|
-
#elif defined(__GNUC__)
|
|
106
|
-
foundval = __sync_val_compare_and_swap(ptr, oldval, newval);
|
|
107
|
-
#else
|
|
108
|
-
# error "Unsupported architecture for atomic operations"
|
|
109
|
-
#endif
|
|
110
|
-
return (foundval == oldval) ? oldval : newval;
|
|
111
|
-
}
|
|
112
|
-
|
|
113
|
-
GIT_INLINE(volatile void *) git___swap(
|
|
114
|
-
void * volatile *ptr, void *newval)
|
|
115
|
-
{
|
|
116
|
-
#if defined(GIT_WIN32)
|
|
117
|
-
return InterlockedExchangePointer(ptr, newval);
|
|
118
|
-
#else
|
|
119
|
-
return __sync_lock_test_and_set(ptr, newval);
|
|
120
|
-
#endif
|
|
121
|
-
}
|
|
122
|
-
|
|
123
|
-
#ifdef GIT_ARCH_64
|
|
124
|
-
|
|
125
|
-
GIT_INLINE(int64_t) git_atomic64_add(git_atomic64 *a, int64_t addend)
|
|
126
|
-
{
|
|
127
|
-
#if defined(GIT_WIN32)
|
|
128
|
-
return InterlockedExchangeAdd64(&a->val, addend);
|
|
129
|
-
#elif defined(__GNUC__)
|
|
130
|
-
return __sync_add_and_fetch(&a->val, addend);
|
|
131
|
-
#else
|
|
132
|
-
# error "Unsupported architecture for atomic operations"
|
|
133
|
-
#endif
|
|
134
|
-
}
|
|
135
|
-
|
|
136
|
-
#endif
|
|
137
|
-
|
|
138
|
-
#else
|
|
139
|
-
|
|
140
|
-
#define git_thread unsigned int
|
|
141
|
-
#define git_thread_create(thread, start_routine, arg) 0
|
|
142
|
-
#define git_thread_join(id, status) (void)0
|
|
143
|
-
|
|
144
|
-
/* Pthreads Mutex */
|
|
145
|
-
#define git_mutex unsigned int
|
|
146
|
-
GIT_INLINE(int) git_mutex_init(git_mutex *mutex) \
|
|
147
|
-
{ GIT_UNUSED(mutex); return 0; }
|
|
148
|
-
GIT_INLINE(int) git_mutex_lock(git_mutex *mutex) \
|
|
149
|
-
{ GIT_UNUSED(mutex); return 0; }
|
|
150
|
-
#define git_mutex_unlock(a) (void)0
|
|
151
|
-
#define git_mutex_free(a) (void)0
|
|
152
|
-
|
|
153
|
-
/* Pthreads condition vars */
|
|
154
|
-
#define git_cond unsigned int
|
|
155
|
-
#define git_cond_init(c, a) (void)0
|
|
156
|
-
#define git_cond_free(c) (void)0
|
|
157
|
-
#define git_cond_wait(c, l) (void)0
|
|
158
|
-
#define git_cond_signal(c) (void)0
|
|
159
|
-
#define git_cond_broadcast(c) (void)0
|
|
160
|
-
|
|
161
|
-
/* Pthreads rwlock */
|
|
162
|
-
#define git_rwlock unsigned int
|
|
163
|
-
#define git_rwlock_init(a) 0
|
|
164
|
-
#define git_rwlock_rdlock(a) 0
|
|
165
|
-
#define git_rwlock_rdunlock(a) (void)0
|
|
166
|
-
#define git_rwlock_wrlock(a) 0
|
|
167
|
-
#define git_rwlock_wrunlock(a) (void)0
|
|
168
|
-
#define git_rwlock_free(a) (void)0
|
|
169
|
-
#define GIT_RWLOCK_STATIC_INIT 0
|
|
170
|
-
|
|
171
|
-
|
|
172
|
-
GIT_INLINE(void) git_atomic_set(git_atomic *a, int val)
|
|
173
|
-
{
|
|
174
|
-
a->val = val;
|
|
175
|
-
}
|
|
176
|
-
|
|
177
|
-
GIT_INLINE(int) git_atomic_inc(git_atomic *a)
|
|
178
|
-
{
|
|
179
|
-
return ++a->val;
|
|
180
|
-
}
|
|
181
|
-
|
|
182
|
-
GIT_INLINE(int) git_atomic_add(git_atomic *a, int32_t addend)
|
|
183
|
-
{
|
|
184
|
-
a->val += addend;
|
|
185
|
-
return a->val;
|
|
186
|
-
}
|
|
187
|
-
|
|
188
|
-
GIT_INLINE(int) git_atomic_dec(git_atomic *a)
|
|
189
|
-
{
|
|
190
|
-
return --a->val;
|
|
191
|
-
}
|
|
192
|
-
|
|
193
|
-
GIT_INLINE(void *) git___compare_and_swap(
|
|
194
|
-
void * volatile *ptr, void *oldval, void *newval)
|
|
195
|
-
{
|
|
196
|
-
if (*ptr == oldval)
|
|
197
|
-
*ptr = newval;
|
|
198
|
-
else
|
|
199
|
-
oldval = newval;
|
|
200
|
-
return oldval;
|
|
201
|
-
}
|
|
202
|
-
|
|
203
|
-
GIT_INLINE(volatile void *) git___swap(
|
|
204
|
-
void * volatile *ptr, void *newval)
|
|
205
|
-
{
|
|
206
|
-
volatile void *old = *ptr;
|
|
207
|
-
*ptr = newval;
|
|
208
|
-
return old;
|
|
209
|
-
}
|
|
210
|
-
|
|
211
|
-
#ifdef GIT_ARCH_64
|
|
212
|
-
|
|
213
|
-
GIT_INLINE(int64_t) git_atomic64_add(git_atomic64 *a, int64_t addend)
|
|
214
|
-
{
|
|
215
|
-
a->val += addend;
|
|
216
|
-
return a->val;
|
|
217
|
-
}
|
|
218
|
-
|
|
219
|
-
#endif
|
|
220
|
-
|
|
221
|
-
#endif
|
|
222
|
-
|
|
223
|
-
GIT_INLINE(int) git_atomic_get(git_atomic *a)
|
|
224
|
-
{
|
|
225
|
-
return (int)a->val;
|
|
226
|
-
}
|
|
227
|
-
|
|
228
|
-
/* Atomically replace oldval with newval
|
|
229
|
-
* @return oldval if it was replaced or newval if it was not
|
|
230
|
-
*/
|
|
231
|
-
#define git__compare_and_swap(P,O,N) \
|
|
232
|
-
git___compare_and_swap((void * volatile *)P, O, N)
|
|
233
|
-
|
|
234
|
-
#define git__swap(ptr, val) (void *)git___swap((void * volatile *)&ptr, val)
|
|
235
|
-
|
|
236
|
-
extern int git_online_cpus(void);
|
|
237
|
-
|
|
238
|
-
#if defined(GIT_THREADS) && defined(_MSC_VER)
|
|
239
|
-
# define GIT_MEMORY_BARRIER MemoryBarrier()
|
|
240
|
-
#elif defined(GIT_THREADS)
|
|
241
|
-
# define GIT_MEMORY_BARRIER __sync_synchronize()
|
|
242
|
-
#else
|
|
243
|
-
# define GIT_MEMORY_BARRIER /* noop */
|
|
244
|
-
#endif
|
|
245
|
-
|
|
246
|
-
#endif
|
|
@@ -1,127 +0,0 @@
|
|
|
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_win32_w32_crtdbg_stacktrace_h__
|
|
8
|
-
#define INCLUDE_win32_w32_crtdbg_stacktrace_h__
|
|
9
|
-
|
|
10
|
-
#include "common.h"
|
|
11
|
-
|
|
12
|
-
#if defined(GIT_MSVC_CRTDBG)
|
|
13
|
-
|
|
14
|
-
#include <stdlib.h>
|
|
15
|
-
#include <crtdbg.h>
|
|
16
|
-
|
|
17
|
-
#include "git2/errors.h"
|
|
18
|
-
#include "strnlen.h"
|
|
19
|
-
|
|
20
|
-
/* MSVC CRTDBG memory leak reporting.
|
|
21
|
-
*
|
|
22
|
-
* We DO NOT use the "_CRTDBG_MAP_ALLOC" macro described in the MSVC
|
|
23
|
-
* documentation because all allocs/frees in libgit2 already go through
|
|
24
|
-
* the "git__" routines defined in this file. Simply using the normal
|
|
25
|
-
* reporting mechanism causes all leaks to be attributed to a routine
|
|
26
|
-
* here in util.h (ie, the actual call to calloc()) rather than the
|
|
27
|
-
* caller of git__calloc().
|
|
28
|
-
*
|
|
29
|
-
* Therefore, we declare a set of "git__crtdbg__" routines to replace
|
|
30
|
-
* the corresponding "git__" routines and re-define the "git__" symbols
|
|
31
|
-
* as macros. This allows us to get and report the file:line info of
|
|
32
|
-
* the real caller.
|
|
33
|
-
*
|
|
34
|
-
* We DO NOT replace the "git__free" routine because it needs to remain
|
|
35
|
-
* a function pointer because it is used as a function argument when
|
|
36
|
-
* setting up various structure "destructors".
|
|
37
|
-
*
|
|
38
|
-
* We also DO NOT use the "_CRTDBG_MAP_ALLOC" macro because it causes
|
|
39
|
-
* "free" to be remapped to "_free_dbg" and this causes problems for
|
|
40
|
-
* structures which define a field named "free".
|
|
41
|
-
*
|
|
42
|
-
* Finally, CRTDBG must be explicitly enabled and configured at program
|
|
43
|
-
* startup. See tests/main.c for an example.
|
|
44
|
-
*/
|
|
45
|
-
|
|
46
|
-
/**
|
|
47
|
-
* Initialize our memory leak tracking and de-dup data structures.
|
|
48
|
-
* This should ONLY be called by git_libgit2_init().
|
|
49
|
-
*/
|
|
50
|
-
void git_win32__crtdbg_stacktrace_init(void);
|
|
51
|
-
|
|
52
|
-
/**
|
|
53
|
-
* Shutdown our memory leak tracking and dump summary data.
|
|
54
|
-
* This should ONLY be called by git_libgit2_shutdown().
|
|
55
|
-
*
|
|
56
|
-
* We explicitly call _CrtDumpMemoryLeaks() during here so
|
|
57
|
-
* that we can compute summary data for the leaks. We print
|
|
58
|
-
* the stacktrace of each unique leak.
|
|
59
|
-
*
|
|
60
|
-
* This cleanup does not happen if the app calls exit()
|
|
61
|
-
* without calling the libgit2 shutdown code.
|
|
62
|
-
*
|
|
63
|
-
* This info we print here is independent of any automatic
|
|
64
|
-
* reporting during exit() caused by _CRTDBG_LEAK_CHECK_DF.
|
|
65
|
-
* Set it in your app if you also want traditional reporting.
|
|
66
|
-
*/
|
|
67
|
-
void git_win32__crtdbg_stacktrace_cleanup(void);
|
|
68
|
-
|
|
69
|
-
/**
|
|
70
|
-
* Checkpoint options.
|
|
71
|
-
*/
|
|
72
|
-
typedef enum git_win32__crtdbg_stacktrace_options {
|
|
73
|
-
/**
|
|
74
|
-
* Set checkpoint marker.
|
|
75
|
-
*/
|
|
76
|
-
GIT_WIN32__CRTDBG_STACKTRACE__SET_MARK = (1 << 0),
|
|
77
|
-
|
|
78
|
-
/**
|
|
79
|
-
* Dump leaks since last checkpoint marker.
|
|
80
|
-
* May not be combined with __LEAKS_TOTAL.
|
|
81
|
-
*
|
|
82
|
-
* Note that this may generate false positives for global TLS
|
|
83
|
-
* error state and other global caches that aren't cleaned up
|
|
84
|
-
* until the thread/process terminates. So when using this
|
|
85
|
-
* around a region of interest, also check the final (at exit)
|
|
86
|
-
* dump before digging into leaks reported here.
|
|
87
|
-
*/
|
|
88
|
-
GIT_WIN32__CRTDBG_STACKTRACE__LEAKS_SINCE_MARK = (1 << 1),
|
|
89
|
-
|
|
90
|
-
/**
|
|
91
|
-
* Dump leaks since init. May not be combined
|
|
92
|
-
* with __LEAKS_SINCE_MARK.
|
|
93
|
-
*/
|
|
94
|
-
GIT_WIN32__CRTDBG_STACKTRACE__LEAKS_TOTAL = (1 << 2),
|
|
95
|
-
|
|
96
|
-
/**
|
|
97
|
-
* Suppress printing during dumps.
|
|
98
|
-
* Just return leak count.
|
|
99
|
-
*/
|
|
100
|
-
GIT_WIN32__CRTDBG_STACKTRACE__QUIET = (1 << 3),
|
|
101
|
-
|
|
102
|
-
} git_win32__crtdbg_stacktrace_options;
|
|
103
|
-
|
|
104
|
-
/**
|
|
105
|
-
* Checkpoint memory state and/or dump unique stack traces of
|
|
106
|
-
* current memory leaks.
|
|
107
|
-
*
|
|
108
|
-
* @return number of unique leaks (relative to requested starting
|
|
109
|
-
* point) or error.
|
|
110
|
-
*/
|
|
111
|
-
GIT_EXTERN(int) git_win32__crtdbg_stacktrace__dump(
|
|
112
|
-
git_win32__crtdbg_stacktrace_options opt,
|
|
113
|
-
const char *label);
|
|
114
|
-
|
|
115
|
-
/**
|
|
116
|
-
* Construct stacktrace and append it to the global buffer.
|
|
117
|
-
* Return pointer to start of this string. On any error or
|
|
118
|
-
* lack of buffer space, just return the given file buffer
|
|
119
|
-
* so it will behave as usual.
|
|
120
|
-
*
|
|
121
|
-
* This should ONLY be called by our internal memory allocations
|
|
122
|
-
* routines.
|
|
123
|
-
*/
|
|
124
|
-
const char *git_win32__crtdbg_stacktrace(int skip, const char *file);
|
|
125
|
-
|
|
126
|
-
#endif
|
|
127
|
-
#endif
|