rugged 0.27.9 → 0.27.10

Sign up to get free protection for your applications and to get access to all the features.
Files changed (420) hide show
  1. checksums.yaml +4 -4
  2. data/lib/rugged/version.rb +1 -1
  3. data/vendor/libgit2/AUTHORS +1 -0
  4. data/vendor/libgit2/CMakeLists.txt +98 -54
  5. data/vendor/libgit2/COPYING +28 -0
  6. data/vendor/libgit2/cmake/Modules/AddCFlagIfSupported.cmake +15 -1
  7. data/vendor/libgit2/cmake/Modules/EnableWarnings.cmake +9 -8
  8. data/vendor/libgit2/cmake/Modules/FindCoreFoundation.cmake +2 -2
  9. data/vendor/libgit2/cmake/Modules/FindGSSAPI.cmake +1 -1
  10. data/vendor/libgit2/cmake/Modules/FindGSSFramework.cmake +28 -0
  11. data/vendor/libgit2/cmake/Modules/FindPCRE.cmake +38 -0
  12. data/vendor/libgit2/cmake/Modules/FindPCRE2.cmake +37 -0
  13. data/vendor/libgit2/cmake/Modules/FindSecurity.cmake +2 -2
  14. data/vendor/libgit2/cmake/Modules/FindStatNsec.cmake +6 -0
  15. data/vendor/libgit2/cmake/Modules/FindmbedTLS.cmake +93 -0
  16. data/vendor/libgit2/cmake/Modules/PkgBuildConfig.cmake +110 -0
  17. data/vendor/libgit2/cmake/Modules/SelectGSSAPI.cmake +53 -0
  18. data/vendor/libgit2/cmake/Modules/SelectHTTPSBackend.cmake +124 -0
  19. data/vendor/libgit2/cmake/Modules/SelectHashes.cmake +66 -0
  20. data/vendor/libgit2/deps/http-parser/CMakeLists.txt +2 -0
  21. data/vendor/libgit2/deps/http-parser/{LICENSE-MIT → COPYING} +0 -0
  22. data/vendor/libgit2/deps/http-parser/http_parser.c +11 -6
  23. data/vendor/libgit2/deps/ntlmclient/CMakeLists.txt +21 -0
  24. data/vendor/libgit2/deps/ntlmclient/compat.h +33 -0
  25. data/vendor/libgit2/deps/ntlmclient/crypt.h +64 -0
  26. data/vendor/libgit2/deps/ntlmclient/crypt_commoncrypto.c +120 -0
  27. data/vendor/libgit2/deps/ntlmclient/crypt_commoncrypto.h +18 -0
  28. data/vendor/libgit2/deps/ntlmclient/crypt_mbedtls.c +145 -0
  29. data/vendor/libgit2/deps/ntlmclient/crypt_mbedtls.h +18 -0
  30. data/vendor/libgit2/deps/ntlmclient/crypt_openssl.c +130 -0
  31. data/vendor/libgit2/deps/ntlmclient/crypt_openssl.h +21 -0
  32. data/vendor/libgit2/deps/ntlmclient/ntlm.c +1420 -0
  33. data/vendor/libgit2/deps/ntlmclient/ntlm.h +174 -0
  34. data/vendor/libgit2/deps/ntlmclient/ntlmclient.h +320 -0
  35. data/vendor/libgit2/deps/ntlmclient/unicode.h +36 -0
  36. data/vendor/libgit2/deps/ntlmclient/unicode_builtin.c +445 -0
  37. data/vendor/libgit2/deps/ntlmclient/unicode_iconv.c +201 -0
  38. data/vendor/libgit2/deps/ntlmclient/utf8.h +1257 -0
  39. data/vendor/libgit2/deps/ntlmclient/util.c +21 -0
  40. data/vendor/libgit2/deps/ntlmclient/util.h +14 -0
  41. data/vendor/libgit2/deps/pcre/CMakeLists.txt +140 -0
  42. data/vendor/libgit2/deps/pcre/COPYING +5 -0
  43. data/vendor/libgit2/deps/pcre/cmake/COPYING-CMAKE-SCRIPTS +22 -0
  44. data/vendor/libgit2/deps/pcre/cmake/FindEditline.cmake +17 -0
  45. data/vendor/libgit2/deps/pcre/cmake/FindPackageHandleStandardArgs.cmake +58 -0
  46. data/vendor/libgit2/deps/pcre/cmake/FindReadline.cmake +29 -0
  47. data/vendor/libgit2/deps/pcre/config.h.in +57 -0
  48. data/vendor/libgit2/deps/pcre/pcre.h +641 -0
  49. data/vendor/libgit2/deps/pcre/pcre_byte_order.c +319 -0
  50. data/vendor/libgit2/deps/pcre/pcre_chartables.c +198 -0
  51. data/vendor/libgit2/deps/pcre/pcre_compile.c +9800 -0
  52. data/vendor/libgit2/deps/pcre/pcre_config.c +190 -0
  53. data/vendor/libgit2/deps/pcre/pcre_dfa_exec.c +3676 -0
  54. data/vendor/libgit2/deps/pcre/pcre_exec.c +7173 -0
  55. data/vendor/libgit2/deps/pcre/pcre_fullinfo.c +245 -0
  56. data/vendor/libgit2/deps/pcre/pcre_get.c +669 -0
  57. data/vendor/libgit2/deps/pcre/pcre_globals.c +86 -0
  58. data/vendor/libgit2/deps/pcre/pcre_internal.h +2787 -0
  59. data/vendor/libgit2/deps/pcre/pcre_jit_compile.c +11913 -0
  60. data/vendor/libgit2/deps/pcre/pcre_maketables.c +156 -0
  61. data/vendor/libgit2/deps/pcre/pcre_newline.c +210 -0
  62. data/vendor/libgit2/deps/pcre/pcre_ord2utf8.c +94 -0
  63. data/vendor/libgit2/deps/pcre/pcre_printint.c +834 -0
  64. data/vendor/libgit2/deps/pcre/pcre_refcount.c +92 -0
  65. data/vendor/libgit2/deps/pcre/pcre_string_utils.c +211 -0
  66. data/vendor/libgit2/deps/pcre/pcre_study.c +1686 -0
  67. data/vendor/libgit2/deps/pcre/pcre_tables.c +727 -0
  68. data/vendor/libgit2/deps/pcre/pcre_ucd.c +3644 -0
  69. data/vendor/libgit2/deps/pcre/pcre_valid_utf8.c +301 -0
  70. data/vendor/libgit2/deps/pcre/pcre_version.c +98 -0
  71. data/vendor/libgit2/deps/pcre/pcre_xclass.c +268 -0
  72. data/vendor/libgit2/deps/pcre/pcreposix.c +421 -0
  73. data/vendor/libgit2/deps/pcre/pcreposix.h +117 -0
  74. data/vendor/libgit2/deps/pcre/ucp.h +224 -0
  75. data/vendor/libgit2/deps/winhttp/COPYING.GPL +993 -0
  76. data/vendor/libgit2/deps/winhttp/COPYING.LGPL +502 -0
  77. data/vendor/libgit2/deps/zlib/CMakeLists.txt +1 -0
  78. data/vendor/libgit2/deps/zlib/COPYING +27 -0
  79. data/vendor/libgit2/deps/zlib/adler32.c +0 -7
  80. data/vendor/libgit2/deps/zlib/crc32.c +0 -7
  81. data/vendor/libgit2/include/git2.h +5 -0
  82. data/vendor/libgit2/include/git2/annotated_commit.h +9 -0
  83. data/vendor/libgit2/include/git2/apply.h +149 -0
  84. data/vendor/libgit2/include/git2/attr.h +38 -20
  85. data/vendor/libgit2/include/git2/blame.h +42 -25
  86. data/vendor/libgit2/include/git2/blob.h +45 -13
  87. data/vendor/libgit2/include/git2/branch.h +1 -1
  88. data/vendor/libgit2/include/git2/buffer.h +22 -16
  89. data/vendor/libgit2/include/git2/cert.h +135 -0
  90. data/vendor/libgit2/include/git2/checkout.h +65 -32
  91. data/vendor/libgit2/include/git2/cherrypick.h +9 -7
  92. data/vendor/libgit2/include/git2/clone.h +12 -10
  93. data/vendor/libgit2/include/git2/commit.h +53 -3
  94. data/vendor/libgit2/include/git2/common.h +60 -8
  95. data/vendor/libgit2/include/git2/config.h +30 -19
  96. data/vendor/libgit2/include/git2/cred.h +308 -0
  97. data/vendor/libgit2/include/git2/deprecated.h +493 -0
  98. data/vendor/libgit2/include/git2/describe.h +32 -9
  99. data/vendor/libgit2/include/git2/diff.h +208 -156
  100. data/vendor/libgit2/include/git2/errors.h +54 -46
  101. data/vendor/libgit2/include/git2/filter.h +8 -0
  102. data/vendor/libgit2/include/git2/ignore.h +2 -2
  103. data/vendor/libgit2/include/git2/index.h +74 -52
  104. data/vendor/libgit2/include/git2/indexer.h +76 -6
  105. data/vendor/libgit2/include/git2/mailmap.h +115 -0
  106. data/vendor/libgit2/include/git2/merge.h +35 -18
  107. data/vendor/libgit2/include/git2/net.h +0 -5
  108. data/vendor/libgit2/include/git2/notes.h +1 -1
  109. data/vendor/libgit2/include/git2/object.h +17 -29
  110. data/vendor/libgit2/include/git2/odb.h +12 -11
  111. data/vendor/libgit2/include/git2/odb_backend.h +10 -9
  112. data/vendor/libgit2/include/git2/oid.h +2 -2
  113. data/vendor/libgit2/include/git2/pack.h +14 -3
  114. data/vendor/libgit2/include/git2/proxy.h +14 -8
  115. data/vendor/libgit2/include/git2/rebase.h +53 -6
  116. data/vendor/libgit2/include/git2/refs.h +33 -15
  117. data/vendor/libgit2/include/git2/refspec.h +17 -0
  118. data/vendor/libgit2/include/git2/remote.h +123 -24
  119. data/vendor/libgit2/include/git2/repository.h +76 -39
  120. data/vendor/libgit2/include/git2/revert.h +6 -4
  121. data/vendor/libgit2/include/git2/revwalk.h +7 -7
  122. data/vendor/libgit2/include/git2/signature.h +2 -2
  123. data/vendor/libgit2/include/git2/stash.h +15 -12
  124. data/vendor/libgit2/include/git2/status.h +33 -20
  125. data/vendor/libgit2/include/git2/submodule.h +30 -12
  126. data/vendor/libgit2/include/git2/sys/alloc.h +101 -0
  127. data/vendor/libgit2/include/git2/sys/commit.h +1 -1
  128. data/vendor/libgit2/include/git2/sys/config.h +13 -13
  129. data/vendor/libgit2/include/git2/sys/cred.h +90 -0
  130. data/vendor/libgit2/include/git2/sys/filter.h +6 -6
  131. data/vendor/libgit2/include/git2/sys/index.h +3 -0
  132. data/vendor/libgit2/include/git2/sys/mempack.h +35 -35
  133. data/vendor/libgit2/include/git2/sys/merge.h +9 -4
  134. data/vendor/libgit2/include/git2/sys/odb_backend.h +66 -22
  135. data/vendor/libgit2/include/git2/sys/path.h +64 -0
  136. data/vendor/libgit2/include/git2/sys/refdb_backend.h +76 -40
  137. data/vendor/libgit2/include/git2/sys/repository.h +5 -1
  138. data/vendor/libgit2/include/git2/sys/stream.h +92 -12
  139. data/vendor/libgit2/include/git2/sys/transport.h +129 -83
  140. data/vendor/libgit2/include/git2/tag.h +13 -4
  141. data/vendor/libgit2/include/git2/trace.h +2 -2
  142. data/vendor/libgit2/include/git2/transaction.h +1 -0
  143. data/vendor/libgit2/include/git2/transport.h +11 -311
  144. data/vendor/libgit2/include/git2/tree.h +4 -4
  145. data/vendor/libgit2/include/git2/types.h +33 -111
  146. data/vendor/libgit2/include/git2/version.h +4 -4
  147. data/vendor/libgit2/include/git2/worktree.h +48 -13
  148. data/vendor/libgit2/src/CMakeLists.txt +96 -164
  149. data/vendor/libgit2/src/alloc.c +43 -0
  150. data/vendor/libgit2/src/alloc.h +40 -0
  151. data/vendor/libgit2/src/allocators/stdalloc.c +119 -0
  152. data/vendor/libgit2/src/{streams/curl.h → allocators/stdalloc.h} +5 -5
  153. data/vendor/libgit2/src/allocators/win32_crtdbg.c +118 -0
  154. data/vendor/libgit2/src/{transports/cred.h → allocators/win32_crtdbg.h} +5 -4
  155. data/vendor/libgit2/src/annotated_commit.c +15 -8
  156. data/vendor/libgit2/src/apply.c +537 -31
  157. data/vendor/libgit2/src/apply.h +3 -1
  158. data/vendor/libgit2/src/array.h +2 -2
  159. data/vendor/libgit2/src/attr.c +81 -75
  160. data/vendor/libgit2/src/attr_file.c +207 -121
  161. data/vendor/libgit2/src/attr_file.h +9 -9
  162. data/vendor/libgit2/src/attrcache.c +51 -53
  163. data/vendor/libgit2/src/attrcache.h +2 -1
  164. data/vendor/libgit2/src/blame.c +47 -20
  165. data/vendor/libgit2/src/blame.h +2 -1
  166. data/vendor/libgit2/src/blame_git.c +37 -20
  167. data/vendor/libgit2/src/blob.c +128 -42
  168. data/vendor/libgit2/src/blob.h +19 -2
  169. data/vendor/libgit2/src/branch.c +67 -43
  170. data/vendor/libgit2/src/buf_text.c +7 -6
  171. data/vendor/libgit2/src/buffer.c +69 -57
  172. data/vendor/libgit2/src/buffer.h +1 -1
  173. data/vendor/libgit2/src/cache.c +38 -45
  174. data/vendor/libgit2/src/cache.h +3 -3
  175. data/vendor/libgit2/src/cc-compat.h +20 -3
  176. data/vendor/libgit2/src/checkout.c +109 -90
  177. data/vendor/libgit2/src/cherrypick.c +15 -9
  178. data/vendor/libgit2/src/clone.c +49 -27
  179. data/vendor/libgit2/src/clone.h +4 -0
  180. data/vendor/libgit2/src/commit.c +117 -49
  181. data/vendor/libgit2/src/commit.h +7 -0
  182. data/vendor/libgit2/src/commit_list.c +30 -78
  183. data/vendor/libgit2/src/commit_list.h +2 -2
  184. data/vendor/libgit2/src/common.h +27 -91
  185. data/vendor/libgit2/src/config.c +194 -176
  186. data/vendor/libgit2/src/config.h +8 -20
  187. data/vendor/libgit2/src/config_backend.h +96 -0
  188. data/vendor/libgit2/src/config_cache.c +41 -35
  189. data/vendor/libgit2/src/config_entries.c +229 -0
  190. data/vendor/libgit2/src/config_entries.h +24 -0
  191. data/vendor/libgit2/src/config_file.c +439 -753
  192. data/vendor/libgit2/src/config_mem.c +220 -0
  193. data/vendor/libgit2/src/config_parse.c +114 -63
  194. data/vendor/libgit2/src/config_parse.h +17 -16
  195. data/vendor/libgit2/src/config_snapshot.c +206 -0
  196. data/vendor/libgit2/src/crlf.c +219 -190
  197. data/vendor/libgit2/src/delta.c +25 -18
  198. data/vendor/libgit2/src/describe.c +42 -41
  199. data/vendor/libgit2/src/diff.c +53 -68
  200. data/vendor/libgit2/src/diff.h +2 -1
  201. data/vendor/libgit2/src/diff_driver.c +47 -49
  202. data/vendor/libgit2/src/diff_file.c +19 -17
  203. data/vendor/libgit2/src/diff_file.h +1 -1
  204. data/vendor/libgit2/src/diff_generate.c +162 -106
  205. data/vendor/libgit2/src/diff_generate.h +3 -3
  206. data/vendor/libgit2/src/diff_parse.c +4 -4
  207. data/vendor/libgit2/src/diff_print.c +42 -30
  208. data/vendor/libgit2/src/diff_stats.c +22 -7
  209. data/vendor/libgit2/src/diff_tform.c +16 -16
  210. data/vendor/libgit2/src/diff_xdiff.c +15 -3
  211. data/vendor/libgit2/src/errors.c +51 -39
  212. data/vendor/libgit2/src/errors.h +81 -0
  213. data/vendor/libgit2/src/features.h.in +11 -3
  214. data/vendor/libgit2/src/fetch.c +10 -5
  215. data/vendor/libgit2/src/fetchhead.c +17 -17
  216. data/vendor/libgit2/src/filebuf.c +32 -36
  217. data/vendor/libgit2/src/filebuf.h +2 -2
  218. data/vendor/libgit2/src/filter.c +46 -38
  219. data/vendor/libgit2/src/filter.h +0 -10
  220. data/vendor/libgit2/src/{fileops.c → futils.c} +80 -73
  221. data/vendor/libgit2/src/{fileops.h → futils.h} +6 -6
  222. data/vendor/libgit2/src/global.c +48 -63
  223. data/vendor/libgit2/src/global.h +0 -2
  224. data/vendor/libgit2/src/hash.c +61 -0
  225. data/vendor/libgit2/src/hash.h +20 -19
  226. data/vendor/libgit2/src/hash/sha1.h +38 -0
  227. data/vendor/libgit2/src/hash/sha1/collisiondetect.c +48 -0
  228. data/vendor/libgit2/src/hash/sha1/collisiondetect.h +19 -0
  229. data/vendor/libgit2/src/hash/{hash_common_crypto.h → sha1/common_crypto.c} +17 -17
  230. data/vendor/libgit2/src/hash/sha1/common_crypto.h +19 -0
  231. data/vendor/libgit2/src/hash/{hash_generic.c → sha1/generic.c} +22 -10
  232. data/vendor/libgit2/src/hash/{hash_generic.h → sha1/generic.h} +4 -10
  233. data/vendor/libgit2/src/hash/sha1/mbedtls.c +46 -0
  234. data/vendor/libgit2/src/hash/sha1/mbedtls.h +19 -0
  235. data/vendor/libgit2/src/hash/sha1/openssl.c +59 -0
  236. data/vendor/libgit2/src/hash/sha1/openssl.h +19 -0
  237. data/vendor/libgit2/src/hash/{sha1dc → sha1/sha1dc}/sha1.c +14 -3
  238. data/vendor/libgit2/src/hash/{sha1dc → sha1/sha1dc}/sha1.h +0 -0
  239. data/vendor/libgit2/src/hash/{sha1dc → sha1/sha1dc}/ubc_check.c +0 -0
  240. data/vendor/libgit2/src/hash/{sha1dc → sha1/sha1dc}/ubc_check.h +0 -0
  241. data/vendor/libgit2/src/hash/{hash_win32.c → sha1/win32.c} +47 -37
  242. data/vendor/libgit2/src/hash/{hash_win32.h → sha1/win32.h} +6 -19
  243. data/vendor/libgit2/src/hashsig.c +5 -5
  244. data/vendor/libgit2/src/idxmap.c +107 -61
  245. data/vendor/libgit2/src/idxmap.h +153 -31
  246. data/vendor/libgit2/src/ignore.c +43 -47
  247. data/vendor/libgit2/src/index.c +337 -232
  248. data/vendor/libgit2/src/index.h +17 -1
  249. data/vendor/libgit2/src/indexer.c +346 -175
  250. data/vendor/libgit2/src/integer.h +71 -26
  251. data/vendor/libgit2/src/iterator.c +142 -70
  252. data/vendor/libgit2/src/iterator.h +15 -0
  253. data/vendor/libgit2/src/khash.h +3 -1
  254. data/vendor/libgit2/src/mailmap.c +485 -0
  255. data/vendor/libgit2/src/mailmap.h +35 -0
  256. data/vendor/libgit2/src/map.h +1 -1
  257. data/vendor/libgit2/src/merge.c +144 -100
  258. data/vendor/libgit2/src/merge_driver.c +11 -11
  259. data/vendor/libgit2/src/merge_file.c +2 -2
  260. data/vendor/libgit2/src/mwindow.c +24 -29
  261. data/vendor/libgit2/src/mwindow.h +4 -4
  262. data/vendor/libgit2/src/net.c +184 -0
  263. data/vendor/libgit2/src/net.h +36 -0
  264. data/vendor/libgit2/src/netops.c +55 -156
  265. data/vendor/libgit2/src/netops.h +3 -23
  266. data/vendor/libgit2/src/notes.c +16 -11
  267. data/vendor/libgit2/src/object.c +120 -69
  268. data/vendor/libgit2/src/object.h +22 -9
  269. data/vendor/libgit2/src/object_api.c +8 -8
  270. data/vendor/libgit2/src/odb.c +116 -93
  271. data/vendor/libgit2/src/odb.h +8 -7
  272. data/vendor/libgit2/src/odb_loose.c +62 -55
  273. data/vendor/libgit2/src/odb_mempack.c +21 -34
  274. data/vendor/libgit2/src/odb_pack.c +18 -14
  275. data/vendor/libgit2/src/offmap.c +53 -35
  276. data/vendor/libgit2/src/offmap.h +108 -21
  277. data/vendor/libgit2/src/oid.c +12 -7
  278. data/vendor/libgit2/src/oidmap.c +49 -47
  279. data/vendor/libgit2/src/oidmap.h +101 -24
  280. data/vendor/libgit2/src/pack-objects.c +88 -87
  281. data/vendor/libgit2/src/pack-objects.h +2 -8
  282. data/vendor/libgit2/src/pack.c +99 -101
  283. data/vendor/libgit2/src/pack.h +17 -19
  284. data/vendor/libgit2/src/parse.c +10 -0
  285. data/vendor/libgit2/src/parse.h +3 -3
  286. data/vendor/libgit2/src/patch.c +4 -4
  287. data/vendor/libgit2/src/patch_generate.c +20 -20
  288. data/vendor/libgit2/src/patch_parse.c +151 -63
  289. data/vendor/libgit2/src/path.c +169 -125
  290. data/vendor/libgit2/src/path.h +3 -71
  291. data/vendor/libgit2/src/pathspec.c +19 -19
  292. data/vendor/libgit2/src/pool.c +26 -22
  293. data/vendor/libgit2/src/pool.h +7 -7
  294. data/vendor/libgit2/src/posix.c +10 -10
  295. data/vendor/libgit2/src/posix.h +12 -1
  296. data/vendor/libgit2/src/proxy.c +8 -3
  297. data/vendor/libgit2/src/push.c +37 -31
  298. data/vendor/libgit2/src/push.h +2 -1
  299. data/vendor/libgit2/src/reader.c +265 -0
  300. data/vendor/libgit2/src/reader.h +107 -0
  301. data/vendor/libgit2/src/rebase.c +115 -59
  302. data/vendor/libgit2/src/refdb.c +15 -3
  303. data/vendor/libgit2/src/refdb_fs.c +381 -254
  304. data/vendor/libgit2/src/reflog.c +13 -15
  305. data/vendor/libgit2/src/refs.c +118 -88
  306. data/vendor/libgit2/src/refs.h +5 -3
  307. data/vendor/libgit2/src/refspec.c +56 -37
  308. data/vendor/libgit2/src/refspec.h +1 -1
  309. data/vendor/libgit2/src/regexp.c +221 -0
  310. data/vendor/libgit2/src/regexp.h +97 -0
  311. data/vendor/libgit2/src/remote.c +266 -215
  312. data/vendor/libgit2/src/remote.h +11 -2
  313. data/vendor/libgit2/src/repository.c +280 -225
  314. data/vendor/libgit2/src/repository.h +52 -40
  315. data/vendor/libgit2/src/reset.c +8 -8
  316. data/vendor/libgit2/src/revert.c +14 -9
  317. data/vendor/libgit2/src/revparse.c +47 -48
  318. data/vendor/libgit2/src/revwalk.c +120 -57
  319. data/vendor/libgit2/src/revwalk.h +22 -1
  320. data/vendor/libgit2/src/settings.c +47 -10
  321. data/vendor/libgit2/src/signature.c +11 -11
  322. data/vendor/libgit2/src/sortedcache.c +22 -36
  323. data/vendor/libgit2/src/sortedcache.h +1 -1
  324. data/vendor/libgit2/src/stash.c +125 -99
  325. data/vendor/libgit2/src/status.c +28 -22
  326. data/vendor/libgit2/src/stream.h +17 -2
  327. data/vendor/libgit2/src/streams/mbedtls.c +483 -0
  328. data/vendor/libgit2/src/streams/mbedtls.h +23 -0
  329. data/vendor/libgit2/src/streams/openssl.c +224 -114
  330. data/vendor/libgit2/src/streams/openssl.h +4 -108
  331. data/vendor/libgit2/src/streams/registry.c +118 -0
  332. data/vendor/libgit2/src/streams/registry.h +19 -0
  333. data/vendor/libgit2/src/streams/socket.c +55 -30
  334. data/vendor/libgit2/src/streams/stransport.c +57 -32
  335. data/vendor/libgit2/src/streams/stransport.h +5 -0
  336. data/vendor/libgit2/src/streams/tls.c +50 -19
  337. data/vendor/libgit2/src/streams/tls.h +12 -4
  338. data/vendor/libgit2/src/strmap.c +47 -74
  339. data/vendor/libgit2/src/strmap.h +108 -33
  340. data/vendor/libgit2/src/submodule.c +272 -216
  341. data/vendor/libgit2/src/submodule.h +1 -1
  342. data/vendor/libgit2/src/sysdir.c +29 -19
  343. data/vendor/libgit2/src/tag.c +41 -28
  344. data/vendor/libgit2/src/tag.h +2 -1
  345. data/vendor/libgit2/src/trace.c +2 -2
  346. data/vendor/libgit2/src/trace.h +3 -3
  347. data/vendor/libgit2/src/trailer.c +52 -38
  348. data/vendor/libgit2/src/transaction.c +30 -29
  349. data/vendor/libgit2/src/transport.c +5 -5
  350. data/vendor/libgit2/src/transports/auth.c +15 -11
  351. data/vendor/libgit2/src/transports/auth.h +10 -3
  352. data/vendor/libgit2/src/transports/auth_negotiate.c +33 -18
  353. data/vendor/libgit2/src/transports/auth_negotiate.h +2 -2
  354. data/vendor/libgit2/src/transports/auth_ntlm.c +223 -0
  355. data/vendor/libgit2/src/transports/auth_ntlm.h +35 -0
  356. data/vendor/libgit2/src/transports/cred.c +24 -24
  357. data/vendor/libgit2/src/transports/git.c +26 -31
  358. data/vendor/libgit2/src/transports/http.c +881 -348
  359. data/vendor/libgit2/src/transports/http.h +2 -0
  360. data/vendor/libgit2/src/transports/local.c +35 -35
  361. data/vendor/libgit2/src/transports/smart.c +70 -47
  362. data/vendor/libgit2/src/transports/smart.h +3 -4
  363. data/vendor/libgit2/src/transports/smart_pkt.c +43 -40
  364. data/vendor/libgit2/src/transports/smart_protocol.c +96 -116
  365. data/vendor/libgit2/src/transports/ssh.c +77 -66
  366. data/vendor/libgit2/src/transports/winhttp.c +318 -314
  367. data/vendor/libgit2/src/tree-cache.c +19 -12
  368. data/vendor/libgit2/src/tree.c +103 -142
  369. data/vendor/libgit2/src/tree.h +1 -12
  370. data/vendor/libgit2/src/unix/map.c +3 -3
  371. data/vendor/libgit2/src/unix/posix.h +1 -11
  372. data/vendor/libgit2/src/userdiff.h +3 -1
  373. data/vendor/libgit2/src/util.c +70 -56
  374. data/vendor/libgit2/src/util.h +28 -156
  375. data/vendor/libgit2/src/vector.c +4 -4
  376. data/vendor/libgit2/src/wildmatch.c +320 -0
  377. data/vendor/libgit2/src/wildmatch.h +23 -0
  378. data/vendor/libgit2/src/win32/dir.c +3 -3
  379. data/vendor/libgit2/src/win32/findfile.c +3 -3
  380. data/vendor/libgit2/src/win32/map.c +9 -11
  381. data/vendor/libgit2/src/win32/msvc-compat.h +6 -0
  382. data/vendor/libgit2/src/win32/path_w32.c +113 -9
  383. data/vendor/libgit2/src/win32/path_w32.h +18 -29
  384. data/vendor/libgit2/src/win32/posix.h +1 -4
  385. data/vendor/libgit2/src/win32/posix_w32.c +70 -45
  386. data/vendor/libgit2/src/win32/precompiled.h +0 -2
  387. data/vendor/libgit2/src/win32/thread.c +5 -10
  388. data/vendor/libgit2/src/win32/w32_buffer.c +9 -5
  389. data/vendor/libgit2/src/win32/w32_common.h +39 -0
  390. data/vendor/libgit2/src/win32/w32_crtdbg_stacktrace.c +3 -2
  391. data/vendor/libgit2/src/win32/w32_crtdbg_stacktrace.h +26 -75
  392. data/vendor/libgit2/src/win32/w32_stack.c +6 -11
  393. data/vendor/libgit2/src/win32/w32_stack.h +3 -3
  394. data/vendor/libgit2/src/win32/w32_util.c +27 -64
  395. data/vendor/libgit2/src/win32/w32_util.h +5 -49
  396. data/vendor/libgit2/src/worktree.c +95 -60
  397. data/vendor/libgit2/src/worktree.h +2 -0
  398. data/vendor/libgit2/src/xdiff/xdiffi.c +7 -5
  399. data/vendor/libgit2/src/xdiff/xhistogram.c +1 -1
  400. data/vendor/libgit2/src/xdiff/xmerge.c +27 -15
  401. data/vendor/libgit2/src/xdiff/xpatience.c +3 -0
  402. data/vendor/libgit2/src/zstream.c +4 -4
  403. metadata +122 -33
  404. data/vendor/libgit2/deps/regex/CMakeLists.txt +0 -2
  405. data/vendor/libgit2/deps/regex/config.h +0 -7
  406. data/vendor/libgit2/deps/regex/regcomp.c +0 -3857
  407. data/vendor/libgit2/deps/regex/regex.c +0 -92
  408. data/vendor/libgit2/deps/regex/regex.h +0 -582
  409. data/vendor/libgit2/deps/regex/regex_internal.c +0 -1744
  410. data/vendor/libgit2/deps/regex/regex_internal.h +0 -819
  411. data/vendor/libgit2/deps/regex/regexec.c +0 -4369
  412. data/vendor/libgit2/include/git2/inttypes.h +0 -309
  413. data/vendor/libgit2/include/git2/sys/time.h +0 -31
  414. data/vendor/libgit2/libgit2.pc.in +0 -13
  415. data/vendor/libgit2/src/config_file.h +0 -73
  416. data/vendor/libgit2/src/fnmatch.c +0 -248
  417. data/vendor/libgit2/src/fnmatch.h +0 -48
  418. data/vendor/libgit2/src/hash/hash_collisiondetect.h +0 -47
  419. data/vendor/libgit2/src/hash/hash_openssl.h +0 -59
  420. data/vendor/libgit2/src/streams/curl.c +0 -385
@@ -37,14 +37,16 @@ typedef struct {
37
37
  #define GIT_CHERRYPICK_OPTIONS_INIT {GIT_CHERRYPICK_OPTIONS_VERSION, 0, GIT_MERGE_OPTIONS_INIT, GIT_CHECKOUT_OPTIONS_INIT}
38
38
 
39
39
  /**
40
- * Initializes a `git_cherrypick_options` with default values. Equivalent to
41
- * creating an instance with GIT_CHERRYPICK_OPTIONS_INIT.
40
+ * Initialize git_cherrypick_options structure
42
41
  *
43
- * @param opts the `git_cherrypick_options` struct to initialize
44
- * @param version Version of struct; pass `GIT_CHERRYPICK_OPTIONS_VERSION`
42
+ * Initializes a `git_cherrypick_options` with default values. Equivalent to creating
43
+ * an instance with GIT_CHERRYPICK_OPTIONS_INIT.
44
+ *
45
+ * @param opts The `git_cherrypick_options` struct to initialize.
46
+ * @param version The struct version; pass `GIT_CHERRYPICK_OPTIONS_VERSION`.
45
47
  * @return Zero on success; -1 on failure.
46
48
  */
47
- GIT_EXTERN(int) git_cherrypick_init_options(
49
+ GIT_EXTERN(int) git_cherrypick_options_init(
48
50
  git_cherrypick_options *opts,
49
51
  unsigned int version);
50
52
 
@@ -57,8 +59,8 @@ GIT_EXTERN(int) git_cherrypick_init_options(
57
59
  * @param out pointer to store the index result in
58
60
  * @param repo the repository that contains the given commits
59
61
  * @param cherrypick_commit the commit to cherry-pick
60
- * @param our_commit the commit to revert against (eg, HEAD)
61
- * @param mainline the parent of the revert commit, if it is a merge
62
+ * @param our_commit the commit to cherry-pick against (eg, HEAD)
63
+ * @param mainline the parent of the `cherrypick_commit`, if it is a merge
62
64
  * @param merge_options the merge options (or null for defaults)
63
65
  * @return zero on success, -1 on failure.
64
66
  */
@@ -66,7 +66,7 @@ typedef enum {
66
66
  * @param payload an opaque payload
67
67
  * @return 0, GIT_EINVALIDSPEC, GIT_EEXISTS or an error code
68
68
  */
69
- typedef int (*git_remote_create_cb)(
69
+ typedef int GIT_CALLBACK(git_remote_create_cb)(
70
70
  git_remote **out,
71
71
  git_repository *repo,
72
72
  const char *name,
@@ -87,7 +87,7 @@ typedef int (*git_remote_create_cb)(
87
87
  * @param payload payload specified by the options
88
88
  * @return 0, or a negative value to indicate error
89
89
  */
90
- typedef int (*git_repository_create_cb)(
90
+ typedef int GIT_CALLBACK(git_repository_create_cb)(
91
91
  git_repository **out,
92
92
  const char *path,
93
93
  int bare,
@@ -96,9 +96,9 @@ typedef int (*git_repository_create_cb)(
96
96
  /**
97
97
  * Clone options structure
98
98
  *
99
- * Use the GIT_CLONE_OPTIONS_INIT to get the default settings, like this:
99
+ * Initialize with `GIT_CLONE_OPTIONS_INIT`. Alternatively, you can
100
+ * use `git_clone_options_init`.
100
101
  *
101
- * git_clone_options opts = GIT_CLONE_OPTIONS_INIT;
102
102
  */
103
103
  typedef struct git_clone_options {
104
104
  unsigned int version;
@@ -169,14 +169,16 @@ typedef struct git_clone_options {
169
169
  GIT_FETCH_OPTIONS_INIT }
170
170
 
171
171
  /**
172
- * Initializes a `git_clone_options` with default values. Equivalent to
173
- * creating an instance with GIT_CLONE_OPTIONS_INIT.
172
+ * Initialize git_clone_options structure
174
173
  *
175
- * @param opts The `git_clone_options` struct to initialize
176
- * @param version Version of struct; pass `GIT_CLONE_OPTIONS_VERSION`
174
+ * Initializes a `git_clone_options` with default values. Equivalent to creating
175
+ * an instance with GIT_CLONE_OPTIONS_INIT.
176
+ *
177
+ * @param opts The `git_clone_options` struct to initialize.
178
+ * @param version The struct version; pass `GIT_CLONE_OPTIONS_VERSION`.
177
179
  * @return Zero on success; -1 on failure.
178
180
  */
179
- GIT_EXTERN(int) git_clone_init_options(
181
+ GIT_EXTERN(int) git_clone_options_init(
180
182
  git_clone_options *opts,
181
183
  unsigned int version);
182
184
 
@@ -194,7 +196,7 @@ GIT_EXTERN(int) git_clone_init_options(
194
196
  * function works as though GIT_OPTIONS_INIT were passed.
195
197
  * @return 0 on success, any non-zero return value from a callback
196
198
  * function, or a negative value to indicate an error (use
197
- * `giterr_last` for a detailed error message)
199
+ * `git_error_last` for a detailed error message)
198
200
  */
199
201
  GIT_EXTERN(int) git_clone(
200
202
  git_repository **out,
@@ -172,6 +172,34 @@ GIT_EXTERN(const git_signature *) git_commit_committer(const git_commit *commit)
172
172
  */
173
173
  GIT_EXTERN(const git_signature *) git_commit_author(const git_commit *commit);
174
174
 
175
+ /**
176
+ * Get the committer of a commit, using the mailmap to map names and email
177
+ * addresses to canonical real names and email addresses.
178
+ *
179
+ * Call `git_signature_free` to free the signature.
180
+ *
181
+ * @param out a pointer to store the resolved signature.
182
+ * @param commit a previously loaded commit.
183
+ * @param mailmap the mailmap to resolve with. (may be NULL)
184
+ * @return 0 or an error code
185
+ */
186
+ GIT_EXTERN(int) git_commit_committer_with_mailmap(
187
+ git_signature **out, const git_commit *commit, const git_mailmap *mailmap);
188
+
189
+ /**
190
+ * Get the author of a commit, using the mailmap to map names and email
191
+ * addresses to canonical real names and email addresses.
192
+ *
193
+ * Call `git_signature_free` to free the signature.
194
+ *
195
+ * @param out a pointer to store the resolved signature.
196
+ * @param commit a previously loaded commit.
197
+ * @param mailmap the mailmap to resolve with. (may be NULL)
198
+ * @return 0 or an error code
199
+ */
200
+ GIT_EXTERN(int) git_commit_author_with_mailmap(
201
+ git_signature **out, const git_commit *commit, const git_mailmap *mailmap);
202
+
175
203
  /**
176
204
  * Get the full raw text of the commit header.
177
205
  *
@@ -268,8 +296,8 @@ GIT_EXTERN(int) git_commit_header_field(git_buf *out, const git_commit *commit,
268
296
  * Extract the signature from a commit
269
297
  *
270
298
  * If the id is not for a commit, the error class will be
271
- * `GITERR_INVALID`. If the commit does not have a signature, the
272
- * error class will be `GITERR_OBJECT`.
299
+ * `GIT_ERROR_INVALID`. If the commit does not have a signature, the
300
+ * error class will be `GIT_ERROR_OBJECT`.
273
301
  *
274
302
  * @param signature the signature block; existing content will be
275
303
  * overwritten
@@ -452,7 +480,8 @@ GIT_EXTERN(int) git_commit_create_buffer(
452
480
  *
453
481
  * @param out the resulting commit id
454
482
  * @param commit_content the content of the unsigned commit object
455
- * @param signature the signature to add to the commit
483
+ * @param signature the signature to add to the commit. Leave `NULL`
484
+ * to create a commit without adding a signature field.
456
485
  * @param signature_field which header field should contain this
457
486
  * signature. Leave `NULL` for the default of "gpgsig"
458
487
  * @return 0 or an error code
@@ -473,6 +502,27 @@ GIT_EXTERN(int) git_commit_create_with_signature(
473
502
  */
474
503
  GIT_EXTERN(int) git_commit_dup(git_commit **out, git_commit *source);
475
504
 
505
+ /**
506
+ * Commit signing callback.
507
+ *
508
+ * The callback will be called with the commit content, giving a user an
509
+ * opportunity to sign the commit content. The signature_field
510
+ * buf may be left empty to specify the default field "gpgsig".
511
+ *
512
+ * Signatures can take the form of any string, and can be created on an arbitrary
513
+ * header field. Signatures are most commonly used for verifying authorship of a
514
+ * commit using GPG or a similar cryptographically secure signing algorithm.
515
+ * See https://git-scm.com/book/en/v2/Git-Tools-Signing-Your-Work for more
516
+ * details.
517
+ *
518
+ * When the callback:
519
+ * - returns GIT_PASSTHROUGH, no signature will be added to the commit.
520
+ * - returns < 0, commit creation will be aborted.
521
+ * - returns GIT_OK, the signature parameter is expected to be filled.
522
+ */
523
+ typedef int (*git_commit_signing_cb)(
524
+ git_buf *signature, git_buf *signature_field, const char *commit_content, void *payload);
525
+
476
526
  /** @} */
477
527
  GIT_END_DECL
478
528
  #endif
@@ -21,10 +21,7 @@
21
21
  #endif
22
22
 
23
23
  #if defined(_MSC_VER) && _MSC_VER < 1800
24
- GIT_BEGIN_DECL
25
- # include "inttypes.h"
26
- GIT_END_DECL
27
- /** This check is needed for importing this file in an iOS/OS X framework throws an error in Xcode otherwise.*/
24
+ # include <stdint.h>
28
25
  #elif !defined(__CLANG_INTTYPES_H)
29
26
  # include <inttypes.h>
30
27
  #endif
@@ -43,11 +40,30 @@ typedef size_t size_t;
43
40
  __attribute__((visibility("default"))) \
44
41
  type
45
42
  #elif defined(_MSC_VER)
46
- # define GIT_EXTERN(type) __declspec(dllexport) type
43
+ # define GIT_EXTERN(type) __declspec(dllexport) type __cdecl
47
44
  #else
48
45
  # define GIT_EXTERN(type) extern type
49
46
  #endif
50
47
 
48
+ /** Declare a callback function for application use. */
49
+ #if defined(_MSC_VER)
50
+ # define GIT_CALLBACK(name) (__cdecl *name)
51
+ #else
52
+ # define GIT_CALLBACK(name) (*name)
53
+ #endif
54
+
55
+ /** Declare a function as deprecated. */
56
+ #if defined(__GNUC__)
57
+ # define GIT_DEPRECATED(func) \
58
+ __attribute__((deprecated)) \
59
+ __attribute__((used)) \
60
+ func
61
+ #elif defined(_MSC_VER)
62
+ # define GIT_DEPRECATED(func) __declspec(deprecated) func
63
+ #else
64
+ # define GIT_DEPRECATED(func) func
65
+ #endif
66
+
51
67
  /** Declare a function's takes printf style arguments. */
52
68
  #ifdef __GNUC__
53
69
  # define GIT_FORMAT_PRINTF(a,b) __attribute__((format (printf, a, b)))
@@ -183,6 +199,11 @@ typedef enum {
183
199
  GIT_OPT_GET_WINDOWS_SHAREMODE,
184
200
  GIT_OPT_SET_WINDOWS_SHAREMODE,
185
201
  GIT_OPT_ENABLE_STRICT_HASH_VERIFICATION,
202
+ GIT_OPT_SET_ALLOCATOR,
203
+ GIT_OPT_ENABLE_UNSAVED_INDEX_SAFETY,
204
+ GIT_OPT_GET_PACK_MAX_OBJECTS,
205
+ GIT_OPT_SET_PACK_MAX_OBJECTS,
206
+ GIT_OPT_DISABLE_PACK_KEEP_FILE_CHECKS
186
207
  } git_libgit2_opt_t;
187
208
 
188
209
  /**
@@ -228,13 +249,13 @@ typedef enum {
228
249
  * > `GIT_CONFIG_LEVEL_GLOBAL`, `GIT_CONFIG_LEVEL_XDG`, or
229
250
  * > `GIT_CONFIG_LEVEL_PROGRAMDATA`.
230
251
  *
231
- * * opts(GIT_OPT_SET_CACHE_OBJECT_LIMIT, git_otype type, size_t size)
252
+ * * opts(GIT_OPT_SET_CACHE_OBJECT_LIMIT, git_object_t type, size_t size)
232
253
  *
233
254
  * > Set the maximum data size for the given type of object to be
234
255
  * > considered eligible for caching in memory. Setting to value to
235
256
  * > zero means that that type of object will not be cached.
236
- * > Defaults to 0 for GIT_OBJ_BLOB (i.e. won't cache blobs) and 4k
237
- * > for GIT_OBJ_COMMIT, GIT_OBJ_TREE, and GIT_OBJ_TAG.
257
+ * > Defaults to 0 for GIT_OBJECT_BLOB (i.e. won't cache blobs) and 4k
258
+ * > for GIT_OBJECT_COMMIT, GIT_OBJECT_TREE, and GIT_OBJECT_TAG.
238
259
  *
239
260
  * * opts(GIT_OPT_SET_CACHE_MAX_SIZE, ssize_t max_storage_bytes)
240
261
  *
@@ -345,6 +366,37 @@ typedef enum {
345
366
  * > additional checksum calculation on each object. This defaults
346
367
  * > to enabled.
347
368
  *
369
+ * opts(GIT_OPT_SET_ALLOCATOR, git_allocator *allocator)
370
+ *
371
+ * > Set the memory allocator to a different memory allocator. This
372
+ * > allocator will then be used to make all memory allocations for
373
+ * > libgit2 operations. If the given `allocator` is NULL, then the
374
+ * > system default will be restored.
375
+ *
376
+ * opts(GIT_OPT_ENABLE_UNSAVED_INDEX_SAFETY, int enabled)
377
+ *
378
+ * > Ensure that there are no unsaved changes in the index before
379
+ * > beginning any operation that reloads the index from disk (eg,
380
+ * > checkout). If there are unsaved changes, the instruction will
381
+ * > fail. (Using the FORCE flag to checkout will still overwrite
382
+ * > these changes.)
383
+ *
384
+ * opts(GIT_OPT_GET_PACK_MAX_OBJECTS, size_t *out)
385
+ *
386
+ * > Get the maximum number of objects libgit2 will allow in a pack
387
+ * > file when downloading a pack file from a remote. This can be
388
+ * > used to limit maximum memory usage when fetching from an untrusted
389
+ * > remote.
390
+ *
391
+ * opts(GIT_OPT_SET_PACK_MAX_OBJECTS, size_t objects)
392
+ *
393
+ * > Set the maximum number of objects libgit2 will allow in a pack
394
+ * > file when downloading a pack file from a remote.
395
+ *
396
+ * opts(GIT_OPT_DISABLE_PACK_KEEP_FILE_CHECKS, int enabled)
397
+ * > This will cause .keep file existence checks to be skipped when
398
+ * > accessing packfiles, which can help performance with remote filesystems.
399
+ *
348
400
  * @param option Option key
349
401
  * @param ... value to set the option
350
402
  * @return 0 on success, <0 on failure
@@ -64,8 +64,9 @@ typedef enum {
64
64
  typedef struct git_config_entry {
65
65
  const char *name; /**< Name of the entry (normalised) */
66
66
  const char *value; /**< String value of the entry */
67
+ unsigned int include_depth; /**< Depth of includes where this variable was found */
67
68
  git_config_level_t level; /**< Which config file this was found in */
68
- void (*free)(struct git_config_entry *entry); /**< Free function for this entry */
69
+ void GIT_CALLBACK(free)(struct git_config_entry *entry); /**< Free function for this entry */
69
70
  void *payload; /**< Opaque value for the free function. Do not read or write */
70
71
  } git_config_entry;
71
72
 
@@ -74,27 +75,37 @@ typedef struct git_config_entry {
74
75
  */
75
76
  GIT_EXTERN(void) git_config_entry_free(git_config_entry *);
76
77
 
77
- typedef int (*git_config_foreach_cb)(const git_config_entry *, void *);
78
+ /**
79
+ * A config enumeration callback
80
+ *
81
+ * @param entry the entry currently being enumerated
82
+ * @param payload a user-specified pointer
83
+ */
84
+ typedef int GIT_CALLBACK(git_config_foreach_cb)(const git_config_entry *entry, void *payload);
85
+
86
+ /**
87
+ * An opaque structure for a configuration iterator
88
+ */
78
89
  typedef struct git_config_iterator git_config_iterator;
79
90
 
80
91
  /**
81
92
  * Config var type
82
93
  */
83
94
  typedef enum {
84
- GIT_CVAR_FALSE = 0,
85
- GIT_CVAR_TRUE = 1,
86
- GIT_CVAR_INT32,
87
- GIT_CVAR_STRING
88
- } git_cvar_t;
95
+ GIT_CONFIGMAP_FALSE = 0,
96
+ GIT_CONFIGMAP_TRUE = 1,
97
+ GIT_CONFIGMAP_INT32,
98
+ GIT_CONFIGMAP_STRING
99
+ } git_configmap_t;
89
100
 
90
101
  /**
91
102
  * Mapping from config variables to values.
92
103
  */
93
104
  typedef struct {
94
- git_cvar_t cvar_type;
105
+ git_configmap_t type;
95
106
  const char *str_match;
96
107
  int map_value;
97
- } git_cvar_map;
108
+ } git_configmap;
98
109
 
99
110
  /**
100
111
  * Locate the path to the global configuration file
@@ -251,7 +262,7 @@ GIT_EXTERN(int) git_config_open_level(
251
262
  * Open the global/XDG configuration file according to git's rules
252
263
  *
253
264
  * Git allows you to store your global configuration at
254
- * `$HOME/.config` or `$XDG_CONFIG_HOME/git/config`. For backwards
265
+ * `$HOME/.gitconfig` or `$XDG_CONFIG_HOME/git/config`. For backwards
255
266
  * compatability, the XDG file shouldn't be used unless the use has
256
267
  * created it explicitly. With this function you'll open the correct
257
268
  * one to write to.
@@ -580,7 +591,7 @@ GIT_EXTERN(int) git_config_iterator_glob_new(git_config_iterator **out, const gi
580
591
  /**
581
592
  * Perform an operation on each config variable matching a regular expression.
582
593
  *
583
- * This behaviors like `git_config_foreach` with an additional filter of a
594
+ * This behaves like `git_config_foreach` with an additional filter of a
584
595
  * regular expression that filters which config keys are passed to the
585
596
  * callback.
586
597
  *
@@ -612,7 +623,7 @@ GIT_EXTERN(int) git_config_foreach_match(
612
623
  *
613
624
  * A mapping array looks as follows:
614
625
  *
615
- * git_cvar_map autocrlf_mapping[] = {
626
+ * git_configmap autocrlf_mapping[] = {
616
627
  * {GIT_CVAR_FALSE, NULL, GIT_AUTO_CRLF_FALSE},
617
628
  * {GIT_CVAR_TRUE, NULL, GIT_AUTO_CRLF_TRUE},
618
629
  * {GIT_CVAR_STRING, "input", GIT_AUTO_CRLF_INPUT},
@@ -633,7 +644,7 @@ GIT_EXTERN(int) git_config_foreach_match(
633
644
  * @param out place to store the result of the mapping
634
645
  * @param cfg config file to get the variables from
635
646
  * @param name name of the config variable to lookup
636
- * @param maps array of `git_cvar_map` objects specifying the possible mappings
647
+ * @param maps array of `git_configmap` objects specifying the possible mappings
637
648
  * @param map_n number of mapping objects in `maps`
638
649
  * @return 0 on success, error code otherwise
639
650
  */
@@ -641,20 +652,20 @@ GIT_EXTERN(int) git_config_get_mapped(
641
652
  int *out,
642
653
  const git_config *cfg,
643
654
  const char *name,
644
- const git_cvar_map *maps,
655
+ const git_configmap *maps,
645
656
  size_t map_n);
646
657
 
647
658
  /**
648
659
  * Maps a string value to an integer constant
649
660
  *
650
661
  * @param out place to store the result of the parsing
651
- * @param maps array of `git_cvar_map` objects specifying the possible mappings
662
+ * @param maps array of `git_configmap` objects specifying the possible mappings
652
663
  * @param map_n number of mapping objects in `maps`
653
664
  * @param value value to parse
654
665
  */
655
666
  GIT_EXTERN(int) git_config_lookup_map_value(
656
667
  int *out,
657
- const git_cvar_map *maps,
668
+ const git_configmap *maps,
658
669
  size_t map_n,
659
670
  const char *value);
660
671
 
@@ -710,11 +721,11 @@ GIT_EXTERN(int) git_config_parse_int64(int64_t *out, const char *value);
710
721
  GIT_EXTERN(int) git_config_parse_path(git_buf *out, const char *value);
711
722
 
712
723
  /**
713
- * Perform an operation on each config variable in given config backend
724
+ * Perform an operation on each config variable in a given config backend,
714
725
  * matching a regular expression.
715
726
  *
716
- * This behaviors like `git_config_foreach_match` except instead of all config
717
- * entries it just enumerates through the given backend entry.
727
+ * This behaves like `git_config_foreach_match` except that only config
728
+ * entries from the given backend entry are enumerated.
718
729
  *
719
730
  * The regular expression is applied case-sensitively on the normalized form of
720
731
  * the variable name: the section and variable parts are lower-cased. The
@@ -0,0 +1,308 @@
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_git_cred_h__
8
+ #define INCLUDE_git_cred_h__
9
+
10
+ #include "common.h"
11
+
12
+ /**
13
+ * @file git2/cred.h
14
+ * @brief Git authentication & credential management
15
+ * @defgroup git_cred Authentication & credential management
16
+ * @ingroup Git
17
+ * @{
18
+ */
19
+ GIT_BEGIN_DECL
20
+
21
+ /**
22
+ * Supported credential types
23
+ *
24
+ * This represents the various types of authentication methods supported by
25
+ * the library.
26
+ */
27
+ typedef enum {
28
+ /**
29
+ * A vanilla user/password request
30
+ * @see git_cred_userpass_plaintext_new
31
+ */
32
+ GIT_CREDTYPE_USERPASS_PLAINTEXT = (1u << 0),
33
+
34
+ /**
35
+ * An SSH key-based authentication request
36
+ * @see git_cred_ssh_key_new
37
+ */
38
+ GIT_CREDTYPE_SSH_KEY = (1u << 1),
39
+
40
+ /**
41
+ * An SSH key-based authentication request, with a custom signature
42
+ * @see git_cred_ssh_custom_new
43
+ */
44
+ GIT_CREDTYPE_SSH_CUSTOM = (1u << 2),
45
+
46
+ /**
47
+ * An NTLM/Negotiate-based authentication request.
48
+ * @see git_cred_default
49
+ */
50
+ GIT_CREDTYPE_DEFAULT = (1u << 3),
51
+
52
+ /**
53
+ * An SSH interactive authentication request
54
+ * @see git_cred_ssh_interactive_new
55
+ */
56
+ GIT_CREDTYPE_SSH_INTERACTIVE = (1u << 4),
57
+
58
+ /**
59
+ * Username-only authentication request
60
+ *
61
+ * Used as a pre-authentication step if the underlying transport
62
+ * (eg. SSH, with no username in its URL) does not know which username
63
+ * to use.
64
+ *
65
+ * @see git_cred_username_new
66
+ */
67
+ GIT_CREDTYPE_USERNAME = (1u << 5),
68
+
69
+ /**
70
+ * An SSH key-based authentication request
71
+ *
72
+ * Allows credentials to be read from memory instead of files.
73
+ * Note that because of differences in crypto backend support, it might
74
+ * not be functional.
75
+ *
76
+ * @see git_cred_ssh_key_memory_new
77
+ */
78
+ GIT_CREDTYPE_SSH_MEMORY = (1u << 6),
79
+ } git_credtype_t;
80
+
81
+ /**
82
+ * The base structure for all credential types
83
+ */
84
+ typedef struct git_cred git_cred;
85
+
86
+ typedef struct git_cred_userpass_plaintext git_cred_userpass_plaintext;
87
+
88
+ /** Username-only credential information */
89
+ typedef struct git_cred_username git_cred_username;
90
+
91
+ /** A key for NTLM/Kerberos "default" credentials */
92
+ typedef struct git_cred git_cred_default;
93
+
94
+ /**
95
+ * A ssh key from disk
96
+ */
97
+ typedef struct git_cred_ssh_key git_cred_ssh_key;
98
+
99
+ /**
100
+ * Keyboard-interactive based ssh authentication
101
+ */
102
+ typedef struct git_cred_ssh_interactive git_cred_ssh_interactive;
103
+
104
+ /**
105
+ * A key with a custom signature function
106
+ */
107
+ typedef struct git_cred_ssh_custom git_cred_ssh_custom;
108
+
109
+ /**
110
+ * Credential acquisition callback.
111
+ *
112
+ * This callback is usually involved any time another system might need
113
+ * authentication. As such, you are expected to provide a valid git_cred
114
+ * object back, depending on allowed_types (a git_credtype_t bitmask).
115
+ *
116
+ * Note that most authentication details are your responsibility - this
117
+ * callback will be called until the authentication succeeds, or you report
118
+ * an error. As such, it's easy to get in a loop if you fail to stop providing
119
+ * the same incorrect credentials.
120
+ *
121
+ * @param cred The newly created credential object.
122
+ * @param url The resource for which we are demanding a credential.
123
+ * @param username_from_url The username that was embedded in a "user\@host"
124
+ * remote url, or NULL if not included.
125
+ * @param allowed_types A bitmask stating which cred types are OK to return.
126
+ * @param payload The payload provided when specifying this callback.
127
+ * @return 0 for success, < 0 to indicate an error, > 0 to indicate
128
+ * no credential was acquired
129
+ */
130
+ typedef int GIT_CALLBACK(git_cred_acquire_cb)(
131
+ git_cred **cred,
132
+ const char *url,
133
+ const char *username_from_url,
134
+ unsigned int allowed_types,
135
+ void *payload);
136
+
137
+ /**
138
+ * Free a credential.
139
+ *
140
+ * This is only necessary if you own the object; that is, if you are a
141
+ * transport.
142
+ *
143
+ * @param cred the object to free
144
+ */
145
+ GIT_EXTERN(void) git_cred_free(git_cred *cred);
146
+
147
+ /**
148
+ * Check whether a credential object contains username information.
149
+ *
150
+ * @param cred object to check
151
+ * @return 1 if the credential object has non-NULL username, 0 otherwise
152
+ */
153
+ GIT_EXTERN(int) git_cred_has_username(git_cred *cred);
154
+
155
+ /**
156
+ * Return the username associated with a credential object.
157
+ *
158
+ * @param cred object to check
159
+ * @return the credential username, or NULL if not applicable
160
+ */
161
+ GIT_EXTERN(const char *) git_cred_get_username(git_cred *cred);
162
+
163
+ /**
164
+ * Create a new plain-text username and password credential object.
165
+ * The supplied credential parameter will be internally duplicated.
166
+ *
167
+ * @param out The newly created credential object.
168
+ * @param username The username of the credential.
169
+ * @param password The password of the credential.
170
+ * @return 0 for success or an error code for failure
171
+ */
172
+ GIT_EXTERN(int) git_cred_userpass_plaintext_new(
173
+ git_cred **out,
174
+ const char *username,
175
+ const char *password);
176
+
177
+ /**
178
+ * Create a "default" credential usable for Negotiate mechanisms like NTLM
179
+ * or Kerberos authentication.
180
+ *
181
+ * @return 0 for success or an error code for failure
182
+ */
183
+ GIT_EXTERN(int) git_cred_default_new(git_cred **out);
184
+
185
+ /**
186
+ * Create a credential to specify a username.
187
+ *
188
+ * This is used with ssh authentication to query for the username if
189
+ * none is specified in the url.
190
+ */
191
+ GIT_EXTERN(int) git_cred_username_new(git_cred **cred, const char *username);
192
+
193
+ /**
194
+ * Create a new passphrase-protected ssh key credential object.
195
+ * The supplied credential parameter will be internally duplicated.
196
+ *
197
+ * @param out The newly created credential object.
198
+ * @param username username to use to authenticate
199
+ * @param publickey The path to the public key of the credential.
200
+ * @param privatekey The path to the private key of the credential.
201
+ * @param passphrase The passphrase of the credential.
202
+ * @return 0 for success or an error code for failure
203
+ */
204
+ GIT_EXTERN(int) git_cred_ssh_key_new(
205
+ git_cred **out,
206
+ const char *username,
207
+ const char *publickey,
208
+ const char *privatekey,
209
+ const char *passphrase);
210
+
211
+ /**
212
+ * Create a new ssh key credential object reading the keys from memory.
213
+ *
214
+ * @param out The newly created credential object.
215
+ * @param username username to use to authenticate.
216
+ * @param publickey The public key of the credential.
217
+ * @param privatekey The private key of the credential.
218
+ * @param passphrase The passphrase of the credential.
219
+ * @return 0 for success or an error code for failure
220
+ */
221
+ GIT_EXTERN(int) git_cred_ssh_key_memory_new(
222
+ git_cred **out,
223
+ const char *username,
224
+ const char *publickey,
225
+ const char *privatekey,
226
+ const char *passphrase);
227
+
228
+ /*
229
+ * If the user hasn't included libssh2.h before git2.h, we need to
230
+ * define a few types for the callback signatures.
231
+ */
232
+ #ifndef LIBSSH2_VERSION
233
+ typedef struct _LIBSSH2_SESSION LIBSSH2_SESSION;
234
+ typedef struct _LIBSSH2_USERAUTH_KBDINT_PROMPT LIBSSH2_USERAUTH_KBDINT_PROMPT;
235
+ typedef struct _LIBSSH2_USERAUTH_KBDINT_RESPONSE LIBSSH2_USERAUTH_KBDINT_RESPONSE;
236
+ #endif
237
+
238
+ typedef void GIT_CALLBACK(git_cred_ssh_interactive_cb)(
239
+ const char *name,
240
+ int name_len,
241
+ const char *instruction, int instruction_len,
242
+ int num_prompts, const LIBSSH2_USERAUTH_KBDINT_PROMPT *prompts,
243
+ LIBSSH2_USERAUTH_KBDINT_RESPONSE *responses,
244
+ void **abstract);
245
+
246
+
247
+ /**
248
+ * Create a new ssh keyboard-interactive based credential object.
249
+ * The supplied credential parameter will be internally duplicated.
250
+ *
251
+ * @param username Username to use to authenticate.
252
+ * @param prompt_callback The callback method used for prompts.
253
+ * @param payload Additional data to pass to the callback.
254
+ * @return 0 for success or an error code for failure.
255
+ */
256
+ GIT_EXTERN(int) git_cred_ssh_interactive_new(
257
+ git_cred **out,
258
+ const char *username,
259
+ git_cred_ssh_interactive_cb prompt_callback,
260
+ void *payload);
261
+
262
+ /**
263
+ * Create a new ssh key credential object used for querying an ssh-agent.
264
+ * The supplied credential parameter will be internally duplicated.
265
+ *
266
+ * @param out The newly created credential object.
267
+ * @param username username to use to authenticate
268
+ * @return 0 for success or an error code for failure
269
+ */
270
+ GIT_EXTERN(int) git_cred_ssh_key_from_agent(
271
+ git_cred **out,
272
+ const char *username);
273
+
274
+ typedef int GIT_CALLBACK(git_cred_sign_cb)(
275
+ LIBSSH2_SESSION *session,
276
+ unsigned char **sig, size_t *sig_len,
277
+ const unsigned char *data, size_t data_len,
278
+ void **abstract);
279
+
280
+ /**
281
+ * Create an ssh key credential with a custom signing function.
282
+ *
283
+ * This lets you use your own function to sign the challenge.
284
+ *
285
+ * This function and its credential type is provided for completeness
286
+ * and wraps `libssh2_userauth_publickey()`, which is undocumented.
287
+ *
288
+ * The supplied credential parameter will be internally duplicated.
289
+ *
290
+ * @param out The newly created credential object.
291
+ * @param username username to use to authenticate
292
+ * @param publickey The bytes of the public key.
293
+ * @param publickey_len The length of the public key in bytes.
294
+ * @param sign_callback The callback method to sign the data during the challenge.
295
+ * @param payload Additional data to pass to the callback.
296
+ * @return 0 for success or an error code for failure
297
+ */
298
+ GIT_EXTERN(int) git_cred_ssh_custom_new(
299
+ git_cred **out,
300
+ const char *username,
301
+ const char *publickey,
302
+ size_t publickey_len,
303
+ git_cred_sign_cb sign_callback,
304
+ void *payload);
305
+
306
+ /** @} */
307
+ GIT_END_DECL
308
+ #endif