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
@@ -94,40 +94,53 @@ GIT_EXTERN(int) git_repository_discover(
94
94
 
95
95
  /**
96
96
  * Option flags for `git_repository_open_ext`.
97
- *
98
- * * GIT_REPOSITORY_OPEN_NO_SEARCH - Only open the repository if it can be
99
- * immediately found in the start_path. Do not walk up from the
100
- * start_path looking at parent directories.
101
- * * GIT_REPOSITORY_OPEN_CROSS_FS - Unless this flag is set, open will not
102
- * continue searching across filesystem boundaries (i.e. when `st_dev`
103
- * changes from the `stat` system call). (E.g. Searching in a user's home
104
- * directory "/home/user/source/" will not return "/.git/" as the found
105
- * repo if "/" is a different filesystem than "/home".)
106
- * * GIT_REPOSITORY_OPEN_BARE - Open repository as a bare repo regardless
107
- * of core.bare config, and defer loading config file for faster setup.
108
- * Unlike `git_repository_open_bare`, this can follow gitlinks.
109
- * * GIT_REPOSITORY_OPEN_NO_DOTGIT - Do not check for a repository by
110
- * appending /.git to the start_path; only open the repository if
111
- * start_path itself points to the git directory.
112
- * * GIT_REPOSITORY_OPEN_FROM_ENV - Find and open a git repository,
113
- * respecting the environment variables used by the git command-line
114
- * tools. If set, `git_repository_open_ext` will ignore the other
115
- * flags and the `ceiling_dirs` argument, and will allow a NULL `path`
116
- * to use `GIT_DIR` or search from the current directory. The search
117
- * for a repository will respect $GIT_CEILING_DIRECTORIES and
118
- * $GIT_DISCOVERY_ACROSS_FILESYSTEM. The opened repository will
119
- * respect $GIT_INDEX_FILE, $GIT_NAMESPACE, $GIT_OBJECT_DIRECTORY, and
120
- * $GIT_ALTERNATE_OBJECT_DIRECTORIES. In the future, this flag will
121
- * also cause `git_repository_open_ext` to respect $GIT_WORK_TREE and
122
- * $GIT_COMMON_DIR; currently, `git_repository_open_ext` with this
123
- * flag will error out if either $GIT_WORK_TREE or $GIT_COMMON_DIR is
124
- * set.
125
97
  */
126
98
  typedef enum {
99
+ /**
100
+ * Only open the repository if it can be immediately found in the
101
+ * start_path. Do not walk up from the start_path looking at parent
102
+ * directories.
103
+ */
127
104
  GIT_REPOSITORY_OPEN_NO_SEARCH = (1 << 0),
105
+
106
+ /**
107
+ * Unless this flag is set, open will not continue searching across
108
+ * filesystem boundaries (i.e. when `st_dev` changes from the `stat`
109
+ * system call). For example, searching in a user's home directory at
110
+ * "/home/user/source/" will not return "/.git/" as the found repo if
111
+ * "/" is a different filesystem than "/home".
112
+ */
128
113
  GIT_REPOSITORY_OPEN_CROSS_FS = (1 << 1),
114
+
115
+ /**
116
+ * Open repository as a bare repo regardless of core.bare config, and
117
+ * defer loading config file for faster setup.
118
+ * Unlike `git_repository_open_bare`, this can follow gitlinks.
119
+ */
129
120
  GIT_REPOSITORY_OPEN_BARE = (1 << 2),
121
+
122
+ /**
123
+ * Do not check for a repository by appending /.git to the start_path;
124
+ * only open the repository if start_path itself points to the git
125
+ * directory.
126
+ */
130
127
  GIT_REPOSITORY_OPEN_NO_DOTGIT = (1 << 3),
128
+
129
+ /**
130
+ * Find and open a git repository, respecting the environment variables
131
+ * used by the git command-line tools.
132
+ * If set, `git_repository_open_ext` will ignore the other flags and
133
+ * the `ceiling_dirs` argument, and will allow a NULL `path` to use
134
+ * `GIT_DIR` or search from the current directory.
135
+ * The search for a repository will respect $GIT_CEILING_DIRECTORIES and
136
+ * $GIT_DISCOVERY_ACROSS_FILESYSTEM. The opened repository will
137
+ * respect $GIT_INDEX_FILE, $GIT_NAMESPACE, $GIT_OBJECT_DIRECTORY, and
138
+ * $GIT_ALTERNATE_OBJECT_DIRECTORIES.
139
+ * In the future, this flag will also cause `git_repository_open_ext`
140
+ * to respect $GIT_WORK_TREE and $GIT_COMMON_DIR; currently,
141
+ * `git_repository_open_ext` with this flag will error out if either
142
+ * $GIT_WORK_TREE or $GIT_COMMON_DIR is set.
143
+ */
131
144
  GIT_REPOSITORY_OPEN_FROM_ENV = (1 << 4),
132
145
  } git_repository_open_flag_t;
133
146
 
@@ -301,14 +314,16 @@ typedef struct {
301
314
  #define GIT_REPOSITORY_INIT_OPTIONS_INIT {GIT_REPOSITORY_INIT_OPTIONS_VERSION}
302
315
 
303
316
  /**
304
- * Initializes a `git_repository_init_options` with default values. Equivalent
305
- * to creating an instance with GIT_REPOSITORY_INIT_OPTIONS_INIT.
317
+ * Initialize git_repository_init_options structure
318
+ *
319
+ * Initializes a `git_repository_init_options` with default values. Equivalent to
320
+ * creating an instance with `GIT_REPOSITORY_INIT_OPTIONS_INIT`.
306
321
  *
307
- * @param opts the `git_repository_init_options` struct to initialize
308
- * @param version Version of struct; pass `GIT_REPOSITORY_INIT_OPTIONS_VERSION`
322
+ * @param opts The `git_repository_init_options` struct to initialize.
323
+ * @param version The struct version; pass `GIT_REPOSITORY_INIT_OPTIONS_VERSION`.
309
324
  * @return Zero on success; -1 on failure.
310
325
  */
311
- GIT_EXTERN(int) git_repository_init_init_options(
326
+ GIT_EXTERN(int) git_repository_init_options_init(
312
327
  git_repository_init_options *opts,
313
328
  unsigned int version);
314
329
 
@@ -368,7 +383,7 @@ GIT_EXTERN(int) git_repository_head_for_worktree(git_reference **out, git_reposi
368
383
  */
369
384
  GIT_EXTERN(int) git_repository_head_detached(git_repository *repo);
370
385
 
371
- /*
386
+ /**
372
387
  * Check if a worktree's HEAD is detached
373
388
  *
374
389
  * A worktree's HEAD is detached when it points directly to a
@@ -423,7 +438,8 @@ typedef enum {
423
438
  GIT_REPOSITORY_ITEM_HOOKS,
424
439
  GIT_REPOSITORY_ITEM_LOGS,
425
440
  GIT_REPOSITORY_ITEM_MODULES,
426
- GIT_REPOSITORY_ITEM_WORKTREES
441
+ GIT_REPOSITORY_ITEM_WORKTREES,
442
+ GIT_REPOSITORY_ITEM__LAST
427
443
  } git_repository_item_t;
428
444
 
429
445
  /**
@@ -625,7 +641,19 @@ GIT_EXTERN(int) git_repository_message_remove(git_repository *repo);
625
641
  */
626
642
  GIT_EXTERN(int) git_repository_state_cleanup(git_repository *repo);
627
643
 
628
- typedef int (*git_repository_fetchhead_foreach_cb)(const char *ref_name,
644
+ /**
645
+ * Callback used to iterate over each FETCH_HEAD entry
646
+ *
647
+ * @see git_repository_fetchhead_foreach
648
+ *
649
+ * @param ref_name The reference name
650
+ * @param remote_url The remote URL
651
+ * @param oid The reference target OID
652
+ * @param is_merge Was the reference the result of a merge
653
+ * @param payload Payload passed to git_repository_fetchhead_foreach
654
+ * @return non-zero to terminate the iteration
655
+ */
656
+ typedef int GIT_CALLBACK(git_repository_fetchhead_foreach_cb)(const char *ref_name,
629
657
  const char *remote_url,
630
658
  const git_oid *oid,
631
659
  unsigned int is_merge,
@@ -647,7 +675,16 @@ GIT_EXTERN(int) git_repository_fetchhead_foreach(
647
675
  git_repository_fetchhead_foreach_cb callback,
648
676
  void *payload);
649
677
 
650
- typedef int (*git_repository_mergehead_foreach_cb)(const git_oid *oid,
678
+ /**
679
+ * Callback used to iterate over each MERGE_HEAD entry
680
+ *
681
+ * @see git_repository_mergehead_foreach
682
+ *
683
+ * @param oid The merge OID
684
+ * @param payload Payload passed to git_repository_mergehead_foreach
685
+ * @return non-zero to terminate the iteration
686
+ */
687
+ typedef int GIT_CALLBACK(git_repository_mergehead_foreach_cb)(const git_oid *oid,
651
688
  void *payload);
652
689
 
653
690
  /**
@@ -683,7 +720,7 @@ GIT_EXTERN(int) git_repository_mergehead_foreach(
683
720
  * @param repo Repository pointer
684
721
  * @param path Path to file on disk whose contents should be hashed. If the
685
722
  * repository is not NULL, this can be a relative path.
686
- * @param type The object type to hash as (e.g. GIT_OBJ_BLOB)
723
+ * @param type The object type to hash as (e.g. GIT_OBJECT_BLOB)
687
724
  * @param as_path The path to use to look up filtering rules. If this is
688
725
  * NULL, then the `path` parameter will be used instead. If
689
726
  * this is passed as the empty string, then no filters will be
@@ -694,7 +731,7 @@ GIT_EXTERN(int) git_repository_hashfile(
694
731
  git_oid *out,
695
732
  git_repository *repo,
696
733
  const char *path,
697
- git_otype type,
734
+ git_object_t type,
698
735
  const char *as_path);
699
736
 
700
737
  /**
@@ -37,14 +37,16 @@ typedef struct {
37
37
  #define GIT_REVERT_OPTIONS_INIT {GIT_REVERT_OPTIONS_VERSION, 0, GIT_MERGE_OPTIONS_INIT, GIT_CHECKOUT_OPTIONS_INIT}
38
38
 
39
39
  /**
40
+ * Initialize git_revert_options structure
41
+ *
40
42
  * Initializes a `git_revert_options` with default values. Equivalent to
41
- * creating an instance with GIT_REVERT_OPTIONS_INIT.
43
+ * creating an instance with `GIT_REVERT_OPTIONS_INIT`.
42
44
  *
43
- * @param opts the `git_revert_options` struct to initialize
44
- * @param version Version of struct; pass `GIT_REVERT_OPTIONS_VERSION`
45
+ * @param opts The `git_revert_options` struct to initialize.
46
+ * @param version The struct version; pass `GIT_REVERT_OPTIONS_VERSION`.
45
47
  * @return Zero on success; -1 on failure.
46
48
  */
47
- GIT_EXTERN(int) git_revert_init_options(
49
+ GIT_EXTERN(int) git_revert_options_init(
48
50
  git_revert_options *opts,
49
51
  unsigned int version);
50
52
 
@@ -25,15 +25,15 @@ GIT_BEGIN_DECL
25
25
  */
26
26
  typedef enum {
27
27
  /**
28
- * Sort the output with the same default time-order method from git.
29
- * This is the default sorting for new walkers.
28
+ * Sort the output with the same default method from `git`: reverse
29
+ * chronological order. This is the default sorting for new walkers.
30
30
  */
31
31
  GIT_SORT_NONE = 0,
32
32
 
33
33
  /**
34
- * Sort the repository contents in topological order (parents before
35
- * children); this sorting mode can be combined with time sorting to
36
- * produce git's "time-order".
34
+ * Sort the repository contents in topological order (no parents before
35
+ * all of its children are shown); this sorting mode can be combined
36
+ * with time sorting to produce `git`'s `--date-order``.
37
37
  */
38
38
  GIT_SORT_TOPOLOGICAL = 1 << 0,
39
39
 
@@ -274,12 +274,12 @@ GIT_EXTERN(git_repository *) git_revwalk_repository(git_revwalk *walk);
274
274
  * @param commit_id oid of Commit
275
275
  * @param payload User-specified pointer to data to be passed as data payload
276
276
  */
277
- typedef int(*git_revwalk_hide_cb)(
277
+ typedef int GIT_CALLBACK(git_revwalk_hide_cb)(
278
278
  const git_oid *commit_id,
279
279
  void *payload);
280
280
 
281
281
  /**
282
- * Adds a callback function to hide a commit and its parents
282
+ * Adds, changes or removes a callback function to hide a commit and its parents
283
283
  *
284
284
  * @param walk the revision walker
285
285
  * @param hide_cb callback function to hide a commit and its parents
@@ -30,8 +30,8 @@ GIT_BEGIN_DECL
30
30
  * @param out new signature, in case of error NULL
31
31
  * @param name name of the person
32
32
  * @param email email of the person
33
- * @param time time when the action happened
34
- * @param offset timezone offset in minutes for the time
33
+ * @param time time (in seconds from epoch) when the action happened
34
+ * @param offset timezone offset (in minutes) for the time
35
35
  * @return 0 or an error code
36
36
  */
37
37
  GIT_EXTERN(int) git_signature_new(git_signature **out, const char *name, const char *email, git_time_t time, int offset);
@@ -9,6 +9,7 @@
9
9
 
10
10
  #include "common.h"
11
11
  #include "types.h"
12
+ #include "checkout.h"
12
13
 
13
14
  /**
14
15
  * @file git2/stash.h
@@ -80,6 +81,7 @@ typedef enum {
80
81
  GIT_STASH_APPLY_REINSTATE_INDEX = (1 << 0),
81
82
  } git_stash_apply_flags;
82
83
 
84
+ /** Stash apply progression states */
83
85
  typedef enum {
84
86
  GIT_STASH_APPLY_PROGRESS_NONE = 0,
85
87
 
@@ -110,22 +112,22 @@ typedef enum {
110
112
  * Return 0 to continue processing, or a negative value to
111
113
  * abort the stash application.
112
114
  */
113
- typedef int (*git_stash_apply_progress_cb)(
115
+ typedef int GIT_CALLBACK(git_stash_apply_progress_cb)(
114
116
  git_stash_apply_progress_t progress,
115
117
  void *payload);
116
118
 
117
- /** Stash application options structure.
119
+ /**
120
+ * Stash application options structure
118
121
  *
119
- * Initialize with the `GIT_STASH_APPLY_OPTIONS_INIT` macro to set
120
- * sensible defaults; for example:
122
+ * Initialize with `GIT_STASH_APPLY_OPTIONS_INIT`. Alternatively, you can
123
+ * use `git_stash_apply_options_init`.
121
124
  *
122
- * git_stash_apply_options opts = GIT_STASH_APPLY_OPTIONS_INIT;
123
125
  */
124
126
  typedef struct git_stash_apply_options {
125
127
  unsigned int version;
126
128
 
127
129
  /** See `git_stash_apply_flags_t`, above. */
128
- git_stash_apply_flags flags;
130
+ uint32_t flags;
129
131
 
130
132
  /** Options to use when writing files to the working directory. */
131
133
  git_checkout_options checkout_options;
@@ -142,15 +144,16 @@ typedef struct git_stash_apply_options {
142
144
  GIT_CHECKOUT_OPTIONS_INIT }
143
145
 
144
146
  /**
147
+ * Initialize git_stash_apply_options structure
148
+ *
145
149
  * Initializes a `git_stash_apply_options` with default values. Equivalent to
146
- * creating an instance with GIT_STASH_APPLY_OPTIONS_INIT.
150
+ * creating an instance with `GIT_STASH_APPLY_OPTIONS_INIT`.
147
151
  *
148
- * @param opts the `git_stash_apply_options` instance to initialize.
149
- * @param version the version of the struct; you should pass
150
- * `GIT_STASH_APPLY_OPTIONS_INIT` here.
152
+ * @param opts The `git_stash_apply_options` struct to initialize.
153
+ * @param version The struct version; pass `GIT_STASH_APPLY_OPTIONS_VERSION`.
151
154
  * @return Zero on success; -1 on failure.
152
155
  */
153
- GIT_EXTERN(int) git_stash_apply_init_options(
156
+ GIT_EXTERN(int) git_stash_apply_options_init(
154
157
  git_stash_apply_options *opts, unsigned int version);
155
158
 
156
159
  /**
@@ -195,7 +198,7 @@ GIT_EXTERN(int) git_stash_apply(
195
198
  * @param payload Extra parameter to callback function.
196
199
  * @return 0 to continue iterating or non-zero to stop.
197
200
  */
198
- typedef int (*git_stash_cb)(
201
+ typedef int GIT_CALLBACK(git_stash_cb)(
199
202
  size_t index,
200
203
  const char* message,
201
204
  const git_oid *stash_id,
@@ -9,6 +9,8 @@
9
9
 
10
10
  #include "common.h"
11
11
  #include "types.h"
12
+ #include "strarray.h"
13
+ #include "diff.h"
12
14
 
13
15
  /**
14
16
  * @file git2/status.h
@@ -58,7 +60,7 @@ typedef enum {
58
60
  *
59
61
  * `payload` is the value you passed to the foreach function as payload.
60
62
  */
61
- typedef int (*git_status_cb)(
63
+ typedef int GIT_CALLBACK(git_status_cb)(
62
64
  const char *path, unsigned int status_flags, void *payload);
63
65
 
64
66
  /**
@@ -161,27 +163,36 @@ typedef enum {
161
163
  /**
162
164
  * Options to control how `git_status_foreach_ext()` will issue callbacks.
163
165
  *
164
- * This structure is set so that zeroing it out will give you relatively
165
- * sane defaults.
166
+ * Initialize with `GIT_STATUS_OPTIONS_INIT`. Alternatively, you can
167
+ * use `git_status_options_init`.
166
168
  *
167
- * The `show` value is one of the `git_status_show_t` constants that
168
- * control which files to scan and in what order.
169
- *
170
- * The `flags` value is an OR'ed combination of the `git_status_opt_t`
171
- * values above.
172
- *
173
- * The `pathspec` is an array of path patterns to match (using
174
- * fnmatch-style matching), or just an array of paths to match exactly if
175
- * `GIT_STATUS_OPT_DISABLE_PATHSPEC_MATCH` is specified in the flags.
176
- *
177
- * The `baseline` is the tree to be used for comparison to the working directory
178
- * and index; defaults to HEAD.
179
169
  */
180
170
  typedef struct {
181
- unsigned int version;
171
+ unsigned int version; /**< The version */
172
+
173
+ /**
174
+ * The `show` value is one of the `git_status_show_t` constants that
175
+ * control which files to scan and in what order.
176
+ */
182
177
  git_status_show_t show;
178
+
179
+ /**
180
+ * The `flags` value is an OR'ed combination of the `git_status_opt_t`
181
+ * values above.
182
+ */
183
183
  unsigned int flags;
184
+
185
+ /**
186
+ * The `pathspec` is an array of path patterns to match (using
187
+ * fnmatch-style matching), or just an array of paths to match exactly if
188
+ * `GIT_STATUS_OPT_DISABLE_PATHSPEC_MATCH` is specified in the flags.
189
+ */
184
190
  git_strarray pathspec;
191
+
192
+ /**
193
+ * The `baseline` is the tree to be used for comparison to the working directory
194
+ * and index; defaults to HEAD.
195
+ */
185
196
  git_tree *baseline;
186
197
  } git_status_options;
187
198
 
@@ -189,14 +200,16 @@ typedef struct {
189
200
  #define GIT_STATUS_OPTIONS_INIT {GIT_STATUS_OPTIONS_VERSION}
190
201
 
191
202
  /**
203
+ * Initialize git_status_options structure
204
+ *
192
205
  * Initializes a `git_status_options` with default values. Equivalent to
193
- * creating an instance with GIT_STATUS_OPTIONS_INIT.
206
+ * creating an instance with `GIT_STATUS_OPTIONS_INIT`.
194
207
  *
195
- * @param opts The `git_status_options` instance to initialize.
196
- * @param version Version of struct; pass `GIT_STATUS_OPTIONS_VERSION`
208
+ * @param opts The `git_status_options` struct to initialize.
209
+ * @param version The struct version; pass `GIT_STATUS_OPTIONS_VERSION`.
197
210
  * @return Zero on success; -1 on failure.
198
211
  */
199
- GIT_EXTERN(int) git_status_init_options(
212
+ GIT_EXTERN(int) git_status_options_init(
200
213
  git_status_options *opts,
201
214
  unsigned int version);
202
215
 
@@ -115,16 +115,15 @@ typedef enum {
115
115
  * @param payload value you passed to the foreach function as payload
116
116
  * @return 0 on success or error code
117
117
  */
118
- typedef int (*git_submodule_cb)(
118
+ typedef int GIT_CALLBACK(git_submodule_cb)(
119
119
  git_submodule *sm, const char *name, void *payload);
120
120
 
121
121
  /**
122
122
  * Submodule update options structure
123
123
  *
124
- * Use the GIT_SUBMODULE_UPDATE_OPTIONS_INIT to get the default settings,
125
- * like this:
124
+ * Initialize with `GIT_SUBMODULE_UPDATE_OPTIONS_INIT`. Alternatively, you can
125
+ * use `git_submodule_update_options_init`.
126
126
  *
127
- * git_submodule_update_options opts = GIT_SUBMODULE_UPDATE_OPTIONS_INIT;
128
127
  */
129
128
  typedef struct git_submodule_update_options {
130
129
  unsigned int version;
@@ -134,7 +133,7 @@ typedef struct git_submodule_update_options {
134
133
  * checkout, set the `checkout_strategy` to
135
134
  * `GIT_CHECKOUT_NONE`. Generally you will want the use
136
135
  * GIT_CHECKOUT_SAFE to update files in the working
137
- * directory.
136
+ * directory.
138
137
  */
139
138
  git_checkout_options checkout_opts;
140
139
 
@@ -160,14 +159,16 @@ typedef struct git_submodule_update_options {
160
159
  GIT_FETCH_OPTIONS_INIT, 1 }
161
160
 
162
161
  /**
163
- * Initializes a `git_submodule_update_options` with default values.
164
- * Equivalent to creating an instance with GIT_SUBMODULE_UPDATE_OPTIONS_INIT.
162
+ * Initialize git_submodule_update_options structure
165
163
  *
166
- * @param opts The `git_submodule_update_options` instance to initialize.
167
- * @param version Version of struct; pass `GIT_SUBMODULE_UPDATE_OPTIONS_VERSION`
164
+ * Initializes a `git_submodule_update_options` with default values. Equivalent to
165
+ * creating an instance with `GIT_SUBMODULE_UPDATE_OPTIONS_INIT`.
166
+ *
167
+ * @param opts The `git_submodule_update_options` struct to initialize.
168
+ * @param version The struct version; pass `GIT_SUBMODULE_UPDATE_OPTIONS_VERSION`.
168
169
  * @return Zero on success; -1 on failure.
169
170
  */
170
- GIT_EXTERN(int) git_submodule_update_init_options(
171
+ GIT_EXTERN(int) git_submodule_update_options_init(
171
172
  git_submodule_update_options *opts, unsigned int version);
172
173
 
173
174
  /**
@@ -186,7 +187,7 @@ GIT_EXTERN(int) git_submodule_update_init_options(
186
187
  * function works as though GIT_SUBMODULE_UPDATE_OPTIONS_INIT was passed.
187
188
  * @return 0 on success, any non-zero return value from a callback
188
189
  * function, or a negative value to indicate an error (use
189
- * `giterr_last` for a detailed error message).
190
+ * `git_error_last` for a detailed error message).
190
191
  */
191
192
  GIT_EXTERN(int) git_submodule_update(git_submodule *submodule, int init, git_submodule_update_options *options);
192
193
 
@@ -262,7 +263,8 @@ GIT_EXTERN(int) git_submodule_foreach(
262
263
  * from the working directory to the new repo.
263
264
  *
264
265
  * To fully emulate "git submodule add" call this function, then open the
265
- * submodule repo and perform the clone step as needed. Lastly, call
266
+ * submodule repo and perform the clone step as needed (if you don't need
267
+ * anything custom see `git_submodule_add_clone()`). Lastly, call
266
268
  * `git_submodule_add_finalize()` to wrap up adding the new submodule and
267
269
  * .gitmodules to the index to be ready to commit.
268
270
  *
@@ -284,6 +286,22 @@ GIT_EXTERN(int) git_submodule_add_setup(
284
286
  const char *path,
285
287
  int use_gitlink);
286
288
 
289
+ /**
290
+ * Perform the clone step for a newly created submodule.
291
+ *
292
+ * This performs the necessary `git_clone` to setup a newly-created submodule.
293
+ *
294
+ * @param out The newly created repository object. Optional.
295
+ * @param submodule The submodule currently waiting for its clone.
296
+ * @param opts The options to use.
297
+ *
298
+ * @return 0 on success, -1 on other errors (see git_clone).
299
+ */
300
+ GIT_EXTERN(int) git_submodule_clone(
301
+ git_repository **out,
302
+ git_submodule *submodule,
303
+ const git_submodule_update_options *opts);
304
+
287
305
  /**
288
306
  * Resolve the setup of a new git submodule.
289
307
  *