rugged 0.27.10 → 0.27.10.1

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 +0 -1
  4. data/vendor/libgit2/CMakeLists.txt +54 -98
  5. data/vendor/libgit2/COPYING +0 -28
  6. data/vendor/libgit2/cmake/Modules/AddCFlagIfSupported.cmake +1 -15
  7. data/vendor/libgit2/cmake/Modules/EnableWarnings.cmake +8 -9
  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/FindSecurity.cmake +2 -2
  11. data/vendor/libgit2/cmake/Modules/FindStatNsec.cmake +0 -6
  12. data/vendor/libgit2/deps/http-parser/CMakeLists.txt +0 -2
  13. data/vendor/libgit2/deps/http-parser/{COPYING → LICENSE-MIT} +0 -0
  14. data/vendor/libgit2/deps/http-parser/http_parser.c +6 -11
  15. data/vendor/libgit2/deps/regex/CMakeLists.txt +2 -0
  16. data/vendor/libgit2/deps/regex/config.h +7 -0
  17. data/vendor/libgit2/deps/regex/regcomp.c +3857 -0
  18. data/vendor/libgit2/deps/regex/regex.c +92 -0
  19. data/vendor/libgit2/deps/regex/regex.h +582 -0
  20. data/vendor/libgit2/deps/regex/regex_internal.c +1744 -0
  21. data/vendor/libgit2/deps/regex/regex_internal.h +819 -0
  22. data/vendor/libgit2/deps/regex/regexec.c +4369 -0
  23. data/vendor/libgit2/deps/zlib/CMakeLists.txt +0 -1
  24. data/vendor/libgit2/deps/zlib/adler32.c +7 -0
  25. data/vendor/libgit2/deps/zlib/crc32.c +7 -0
  26. data/vendor/libgit2/include/git2.h +0 -5
  27. data/vendor/libgit2/include/git2/annotated_commit.h +0 -9
  28. data/vendor/libgit2/include/git2/attr.h +20 -38
  29. data/vendor/libgit2/include/git2/blame.h +25 -42
  30. data/vendor/libgit2/include/git2/blob.h +13 -45
  31. data/vendor/libgit2/include/git2/branch.h +1 -1
  32. data/vendor/libgit2/include/git2/buffer.h +16 -22
  33. data/vendor/libgit2/include/git2/checkout.h +32 -65
  34. data/vendor/libgit2/include/git2/cherrypick.h +7 -9
  35. data/vendor/libgit2/include/git2/clone.h +10 -12
  36. data/vendor/libgit2/include/git2/commit.h +3 -53
  37. data/vendor/libgit2/include/git2/common.h +8 -60
  38. data/vendor/libgit2/include/git2/config.h +19 -30
  39. data/vendor/libgit2/include/git2/describe.h +9 -32
  40. data/vendor/libgit2/include/git2/diff.h +156 -208
  41. data/vendor/libgit2/include/git2/errors.h +46 -54
  42. data/vendor/libgit2/include/git2/filter.h +0 -8
  43. data/vendor/libgit2/include/git2/ignore.h +2 -2
  44. data/vendor/libgit2/include/git2/index.h +52 -74
  45. data/vendor/libgit2/include/git2/indexer.h +6 -76
  46. data/vendor/libgit2/include/git2/inttypes.h +309 -0
  47. data/vendor/libgit2/include/git2/merge.h +18 -35
  48. data/vendor/libgit2/include/git2/net.h +5 -0
  49. data/vendor/libgit2/include/git2/notes.h +1 -1
  50. data/vendor/libgit2/include/git2/object.h +29 -17
  51. data/vendor/libgit2/include/git2/odb.h +11 -12
  52. data/vendor/libgit2/include/git2/odb_backend.h +9 -10
  53. data/vendor/libgit2/include/git2/oid.h +2 -2
  54. data/vendor/libgit2/include/git2/pack.h +3 -14
  55. data/vendor/libgit2/include/git2/proxy.h +8 -14
  56. data/vendor/libgit2/include/git2/rebase.h +6 -53
  57. data/vendor/libgit2/include/git2/refs.h +15 -33
  58. data/vendor/libgit2/include/git2/refspec.h +0 -17
  59. data/vendor/libgit2/include/git2/remote.h +24 -123
  60. data/vendor/libgit2/include/git2/repository.h +39 -76
  61. data/vendor/libgit2/include/git2/revert.h +4 -6
  62. data/vendor/libgit2/include/git2/revwalk.h +7 -7
  63. data/vendor/libgit2/include/git2/signature.h +2 -2
  64. data/vendor/libgit2/include/git2/stash.h +12 -15
  65. data/vendor/libgit2/include/git2/status.h +20 -33
  66. data/vendor/libgit2/include/git2/submodule.h +12 -30
  67. data/vendor/libgit2/include/git2/sys/commit.h +1 -1
  68. data/vendor/libgit2/include/git2/sys/config.h +13 -13
  69. data/vendor/libgit2/include/git2/sys/filter.h +6 -6
  70. data/vendor/libgit2/include/git2/sys/index.h +0 -3
  71. data/vendor/libgit2/include/git2/sys/mempack.h +35 -35
  72. data/vendor/libgit2/include/git2/sys/merge.h +4 -9
  73. data/vendor/libgit2/include/git2/sys/odb_backend.h +22 -66
  74. data/vendor/libgit2/include/git2/sys/refdb_backend.h +40 -76
  75. data/vendor/libgit2/include/git2/sys/repository.h +1 -5
  76. data/vendor/libgit2/include/git2/sys/stream.h +12 -92
  77. data/vendor/libgit2/include/git2/sys/time.h +31 -0
  78. data/vendor/libgit2/include/git2/sys/transport.h +83 -129
  79. data/vendor/libgit2/include/git2/tag.h +4 -13
  80. data/vendor/libgit2/include/git2/trace.h +2 -2
  81. data/vendor/libgit2/include/git2/transaction.h +0 -1
  82. data/vendor/libgit2/include/git2/transport.h +311 -11
  83. data/vendor/libgit2/include/git2/tree.h +4 -4
  84. data/vendor/libgit2/include/git2/types.h +111 -33
  85. data/vendor/libgit2/include/git2/version.h +4 -4
  86. data/vendor/libgit2/include/git2/worktree.h +13 -48
  87. data/vendor/libgit2/libgit2.pc.in +13 -0
  88. data/vendor/libgit2/src/CMakeLists.txt +164 -96
  89. data/vendor/libgit2/src/annotated_commit.c +8 -15
  90. data/vendor/libgit2/src/apply.c +31 -537
  91. data/vendor/libgit2/src/apply.h +1 -3
  92. data/vendor/libgit2/src/array.h +2 -2
  93. data/vendor/libgit2/src/attr.c +75 -81
  94. data/vendor/libgit2/src/attr_file.c +121 -207
  95. data/vendor/libgit2/src/attr_file.h +9 -9
  96. data/vendor/libgit2/src/attrcache.c +53 -51
  97. data/vendor/libgit2/src/attrcache.h +1 -2
  98. data/vendor/libgit2/src/blame.c +20 -47
  99. data/vendor/libgit2/src/blame.h +1 -2
  100. data/vendor/libgit2/src/blame_git.c +20 -37
  101. data/vendor/libgit2/src/blob.c +42 -128
  102. data/vendor/libgit2/src/blob.h +2 -19
  103. data/vendor/libgit2/src/branch.c +43 -67
  104. data/vendor/libgit2/src/buf_text.c +6 -7
  105. data/vendor/libgit2/src/buffer.c +57 -69
  106. data/vendor/libgit2/src/buffer.h +1 -1
  107. data/vendor/libgit2/src/cache.c +45 -38
  108. data/vendor/libgit2/src/cache.h +3 -3
  109. data/vendor/libgit2/src/cc-compat.h +3 -20
  110. data/vendor/libgit2/src/checkout.c +90 -109
  111. data/vendor/libgit2/src/cherrypick.c +9 -15
  112. data/vendor/libgit2/src/clone.c +27 -49
  113. data/vendor/libgit2/src/clone.h +0 -4
  114. data/vendor/libgit2/src/commit.c +49 -117
  115. data/vendor/libgit2/src/commit.h +0 -7
  116. data/vendor/libgit2/src/commit_list.c +78 -30
  117. data/vendor/libgit2/src/commit_list.h +2 -2
  118. data/vendor/libgit2/src/common.h +91 -27
  119. data/vendor/libgit2/src/config.c +176 -194
  120. data/vendor/libgit2/src/config.h +20 -8
  121. data/vendor/libgit2/src/config_cache.c +35 -41
  122. data/vendor/libgit2/src/config_file.c +753 -439
  123. data/vendor/libgit2/src/config_file.h +73 -0
  124. data/vendor/libgit2/src/config_parse.c +63 -114
  125. data/vendor/libgit2/src/config_parse.h +16 -17
  126. data/vendor/libgit2/src/crlf.c +190 -219
  127. data/vendor/libgit2/src/delta.c +18 -25
  128. data/vendor/libgit2/src/describe.c +41 -42
  129. data/vendor/libgit2/src/diff.c +68 -53
  130. data/vendor/libgit2/src/diff.h +1 -2
  131. data/vendor/libgit2/src/diff_driver.c +49 -47
  132. data/vendor/libgit2/src/diff_file.c +17 -19
  133. data/vendor/libgit2/src/diff_file.h +1 -1
  134. data/vendor/libgit2/src/diff_generate.c +106 -162
  135. data/vendor/libgit2/src/diff_generate.h +3 -3
  136. data/vendor/libgit2/src/diff_parse.c +4 -4
  137. data/vendor/libgit2/src/diff_print.c +30 -42
  138. data/vendor/libgit2/src/diff_stats.c +7 -22
  139. data/vendor/libgit2/src/diff_tform.c +16 -16
  140. data/vendor/libgit2/src/diff_xdiff.c +3 -15
  141. data/vendor/libgit2/src/errors.c +39 -51
  142. data/vendor/libgit2/src/features.h.in +3 -11
  143. data/vendor/libgit2/src/fetch.c +5 -10
  144. data/vendor/libgit2/src/fetchhead.c +17 -17
  145. data/vendor/libgit2/src/filebuf.c +36 -32
  146. data/vendor/libgit2/src/filebuf.h +2 -2
  147. data/vendor/libgit2/src/{futils.c → fileops.c} +73 -80
  148. data/vendor/libgit2/src/{futils.h → fileops.h} +6 -6
  149. data/vendor/libgit2/src/filter.c +38 -46
  150. data/vendor/libgit2/src/filter.h +10 -0
  151. data/vendor/libgit2/src/fnmatch.c +248 -0
  152. data/vendor/libgit2/src/fnmatch.h +48 -0
  153. data/vendor/libgit2/src/global.c +63 -48
  154. data/vendor/libgit2/src/global.h +2 -0
  155. data/vendor/libgit2/src/hash.c +0 -61
  156. data/vendor/libgit2/src/hash.h +19 -20
  157. data/vendor/libgit2/src/hash/hash_collisiondetect.h +47 -0
  158. data/vendor/libgit2/src/hash/{sha1/common_crypto.c → hash_common_crypto.h} +17 -17
  159. data/vendor/libgit2/src/hash/{sha1/generic.c → hash_generic.c} +10 -22
  160. data/vendor/libgit2/src/hash/{sha1/generic.h → hash_generic.h} +10 -4
  161. data/vendor/libgit2/src/hash/hash_openssl.h +59 -0
  162. data/vendor/libgit2/src/hash/{sha1/win32.c → hash_win32.c} +37 -47
  163. data/vendor/libgit2/src/hash/{sha1/win32.h → hash_win32.h} +19 -6
  164. data/vendor/libgit2/src/hash/{sha1/sha1dc → sha1dc}/sha1.c +3 -14
  165. data/vendor/libgit2/src/hash/{sha1/sha1dc → sha1dc}/sha1.h +0 -0
  166. data/vendor/libgit2/src/hash/{sha1/sha1dc → sha1dc}/ubc_check.c +0 -0
  167. data/vendor/libgit2/src/hash/{sha1/sha1dc → sha1dc}/ubc_check.h +0 -0
  168. data/vendor/libgit2/src/hashsig.c +5 -5
  169. data/vendor/libgit2/src/idxmap.c +61 -107
  170. data/vendor/libgit2/src/idxmap.h +31 -153
  171. data/vendor/libgit2/src/ignore.c +47 -43
  172. data/vendor/libgit2/src/index.c +232 -337
  173. data/vendor/libgit2/src/index.h +1 -17
  174. data/vendor/libgit2/src/indexer.c +175 -346
  175. data/vendor/libgit2/src/integer.h +26 -71
  176. data/vendor/libgit2/src/iterator.c +70 -142
  177. data/vendor/libgit2/src/iterator.h +0 -15
  178. data/vendor/libgit2/src/khash.h +1 -3
  179. data/vendor/libgit2/src/map.h +1 -1
  180. data/vendor/libgit2/src/merge.c +100 -144
  181. data/vendor/libgit2/src/merge_driver.c +11 -11
  182. data/vendor/libgit2/src/merge_file.c +2 -2
  183. data/vendor/libgit2/src/mwindow.c +29 -24
  184. data/vendor/libgit2/src/mwindow.h +4 -4
  185. data/vendor/libgit2/src/netops.c +156 -55
  186. data/vendor/libgit2/src/netops.h +23 -3
  187. data/vendor/libgit2/src/notes.c +11 -16
  188. data/vendor/libgit2/src/object.c +69 -120
  189. data/vendor/libgit2/src/object.h +9 -22
  190. data/vendor/libgit2/src/object_api.c +8 -8
  191. data/vendor/libgit2/src/odb.c +93 -116
  192. data/vendor/libgit2/src/odb.h +7 -8
  193. data/vendor/libgit2/src/odb_loose.c +55 -62
  194. data/vendor/libgit2/src/odb_mempack.c +34 -21
  195. data/vendor/libgit2/src/odb_pack.c +14 -18
  196. data/vendor/libgit2/src/offmap.c +35 -53
  197. data/vendor/libgit2/src/offmap.h +21 -108
  198. data/vendor/libgit2/src/oid.c +7 -12
  199. data/vendor/libgit2/src/oidmap.c +47 -49
  200. data/vendor/libgit2/src/oidmap.h +24 -101
  201. data/vendor/libgit2/src/pack-objects.c +87 -88
  202. data/vendor/libgit2/src/pack-objects.h +8 -2
  203. data/vendor/libgit2/src/pack.c +101 -99
  204. data/vendor/libgit2/src/pack.h +19 -17
  205. data/vendor/libgit2/src/parse.c +0 -10
  206. data/vendor/libgit2/src/parse.h +3 -3
  207. data/vendor/libgit2/src/patch.c +4 -4
  208. data/vendor/libgit2/src/patch_generate.c +20 -20
  209. data/vendor/libgit2/src/patch_parse.c +63 -151
  210. data/vendor/libgit2/src/path.c +104 -117
  211. data/vendor/libgit2/src/path.h +71 -3
  212. data/vendor/libgit2/src/pathspec.c +19 -19
  213. data/vendor/libgit2/src/pool.c +22 -26
  214. data/vendor/libgit2/src/pool.h +7 -7
  215. data/vendor/libgit2/src/posix.c +10 -10
  216. data/vendor/libgit2/src/posix.h +1 -12
  217. data/vendor/libgit2/src/proxy.c +3 -8
  218. data/vendor/libgit2/src/push.c +31 -37
  219. data/vendor/libgit2/src/push.h +1 -2
  220. data/vendor/libgit2/src/rebase.c +59 -115
  221. data/vendor/libgit2/src/refdb.c +3 -15
  222. data/vendor/libgit2/src/refdb_fs.c +254 -381
  223. data/vendor/libgit2/src/reflog.c +15 -13
  224. data/vendor/libgit2/src/refs.c +88 -118
  225. data/vendor/libgit2/src/refs.h +3 -5
  226. data/vendor/libgit2/src/refspec.c +37 -56
  227. data/vendor/libgit2/src/refspec.h +1 -1
  228. data/vendor/libgit2/src/remote.c +215 -266
  229. data/vendor/libgit2/src/remote.h +2 -11
  230. data/vendor/libgit2/src/repository.c +225 -280
  231. data/vendor/libgit2/src/repository.h +40 -52
  232. data/vendor/libgit2/src/reset.c +8 -8
  233. data/vendor/libgit2/src/revert.c +9 -14
  234. data/vendor/libgit2/src/revparse.c +48 -47
  235. data/vendor/libgit2/src/revwalk.c +57 -120
  236. data/vendor/libgit2/src/revwalk.h +1 -22
  237. data/vendor/libgit2/src/settings.c +10 -47
  238. data/vendor/libgit2/src/signature.c +11 -11
  239. data/vendor/libgit2/src/sortedcache.c +36 -22
  240. data/vendor/libgit2/src/sortedcache.h +1 -1
  241. data/vendor/libgit2/src/stash.c +99 -125
  242. data/vendor/libgit2/src/status.c +22 -28
  243. data/vendor/libgit2/src/stream.h +2 -17
  244. data/vendor/libgit2/src/streams/curl.c +385 -0
  245. data/vendor/libgit2/src/{allocators/stdalloc.h → streams/curl.h} +5 -5
  246. data/vendor/libgit2/src/streams/openssl.c +114 -224
  247. data/vendor/libgit2/src/streams/openssl.h +108 -4
  248. data/vendor/libgit2/src/streams/socket.c +30 -55
  249. data/vendor/libgit2/src/streams/stransport.c +32 -57
  250. data/vendor/libgit2/src/streams/stransport.h +0 -5
  251. data/vendor/libgit2/src/streams/tls.c +19 -50
  252. data/vendor/libgit2/src/streams/tls.h +4 -12
  253. data/vendor/libgit2/src/strmap.c +74 -47
  254. data/vendor/libgit2/src/strmap.h +33 -108
  255. data/vendor/libgit2/src/submodule.c +216 -272
  256. data/vendor/libgit2/src/submodule.h +1 -1
  257. data/vendor/libgit2/src/sysdir.c +19 -29
  258. data/vendor/libgit2/src/tag.c +28 -41
  259. data/vendor/libgit2/src/tag.h +1 -2
  260. data/vendor/libgit2/src/trace.c +2 -2
  261. data/vendor/libgit2/src/trace.h +3 -3
  262. data/vendor/libgit2/src/trailer.c +38 -52
  263. data/vendor/libgit2/src/transaction.c +29 -30
  264. data/vendor/libgit2/src/transport.c +5 -5
  265. data/vendor/libgit2/src/transports/auth.c +11 -15
  266. data/vendor/libgit2/src/transports/auth.h +3 -10
  267. data/vendor/libgit2/src/transports/auth_negotiate.c +18 -33
  268. data/vendor/libgit2/src/transports/auth_negotiate.h +2 -2
  269. data/vendor/libgit2/src/transports/cred.c +24 -24
  270. data/vendor/libgit2/src/{allocators/win32_crtdbg.h → transports/cred.h} +4 -5
  271. data/vendor/libgit2/src/transports/git.c +31 -26
  272. data/vendor/libgit2/src/transports/http.c +348 -881
  273. data/vendor/libgit2/src/transports/http.h +0 -2
  274. data/vendor/libgit2/src/transports/local.c +35 -35
  275. data/vendor/libgit2/src/transports/smart.c +47 -70
  276. data/vendor/libgit2/src/transports/smart.h +4 -3
  277. data/vendor/libgit2/src/transports/smart_pkt.c +40 -43
  278. data/vendor/libgit2/src/transports/smart_protocol.c +116 -96
  279. data/vendor/libgit2/src/transports/ssh.c +66 -77
  280. data/vendor/libgit2/src/transports/winhttp.c +314 -318
  281. data/vendor/libgit2/src/tree-cache.c +12 -19
  282. data/vendor/libgit2/src/tree.c +142 -103
  283. data/vendor/libgit2/src/tree.h +12 -1
  284. data/vendor/libgit2/src/unix/map.c +3 -3
  285. data/vendor/libgit2/src/unix/posix.h +11 -1
  286. data/vendor/libgit2/src/userdiff.h +1 -3
  287. data/vendor/libgit2/src/util.c +56 -70
  288. data/vendor/libgit2/src/util.h +156 -28
  289. data/vendor/libgit2/src/vector.c +4 -4
  290. data/vendor/libgit2/src/win32/dir.c +3 -3
  291. data/vendor/libgit2/src/win32/findfile.c +3 -3
  292. data/vendor/libgit2/src/win32/map.c +11 -9
  293. data/vendor/libgit2/src/win32/msvc-compat.h +0 -6
  294. data/vendor/libgit2/src/win32/path_w32.c +9 -113
  295. data/vendor/libgit2/src/win32/path_w32.h +29 -18
  296. data/vendor/libgit2/src/win32/posix.h +4 -1
  297. data/vendor/libgit2/src/win32/posix_w32.c +45 -70
  298. data/vendor/libgit2/src/win32/precompiled.h +2 -0
  299. data/vendor/libgit2/src/win32/thread.c +10 -5
  300. data/vendor/libgit2/src/win32/w32_buffer.c +5 -9
  301. data/vendor/libgit2/src/win32/w32_crtdbg_stacktrace.c +2 -3
  302. data/vendor/libgit2/src/win32/w32_crtdbg_stacktrace.h +75 -26
  303. data/vendor/libgit2/src/win32/w32_stack.c +11 -6
  304. data/vendor/libgit2/src/win32/w32_stack.h +3 -3
  305. data/vendor/libgit2/src/win32/w32_util.c +64 -27
  306. data/vendor/libgit2/src/win32/w32_util.h +49 -5
  307. data/vendor/libgit2/src/worktree.c +60 -95
  308. data/vendor/libgit2/src/worktree.h +0 -2
  309. data/vendor/libgit2/src/xdiff/xdiffi.c +5 -7
  310. data/vendor/libgit2/src/xdiff/xhistogram.c +1 -1
  311. data/vendor/libgit2/src/xdiff/xmerge.c +15 -27
  312. data/vendor/libgit2/src/xdiff/xpatience.c +0 -3
  313. data/vendor/libgit2/src/zstream.c +4 -4
  314. metadata +33 -122
  315. data/vendor/libgit2/cmake/Modules/FindGSSFramework.cmake +0 -28
  316. data/vendor/libgit2/cmake/Modules/FindPCRE.cmake +0 -38
  317. data/vendor/libgit2/cmake/Modules/FindPCRE2.cmake +0 -37
  318. data/vendor/libgit2/cmake/Modules/FindmbedTLS.cmake +0 -93
  319. data/vendor/libgit2/cmake/Modules/PkgBuildConfig.cmake +0 -110
  320. data/vendor/libgit2/cmake/Modules/SelectGSSAPI.cmake +0 -53
  321. data/vendor/libgit2/cmake/Modules/SelectHTTPSBackend.cmake +0 -124
  322. data/vendor/libgit2/cmake/Modules/SelectHashes.cmake +0 -66
  323. data/vendor/libgit2/deps/ntlmclient/CMakeLists.txt +0 -21
  324. data/vendor/libgit2/deps/ntlmclient/compat.h +0 -33
  325. data/vendor/libgit2/deps/ntlmclient/crypt.h +0 -64
  326. data/vendor/libgit2/deps/ntlmclient/crypt_commoncrypto.c +0 -120
  327. data/vendor/libgit2/deps/ntlmclient/crypt_commoncrypto.h +0 -18
  328. data/vendor/libgit2/deps/ntlmclient/crypt_mbedtls.c +0 -145
  329. data/vendor/libgit2/deps/ntlmclient/crypt_mbedtls.h +0 -18
  330. data/vendor/libgit2/deps/ntlmclient/crypt_openssl.c +0 -130
  331. data/vendor/libgit2/deps/ntlmclient/crypt_openssl.h +0 -21
  332. data/vendor/libgit2/deps/ntlmclient/ntlm.c +0 -1420
  333. data/vendor/libgit2/deps/ntlmclient/ntlm.h +0 -174
  334. data/vendor/libgit2/deps/ntlmclient/ntlmclient.h +0 -320
  335. data/vendor/libgit2/deps/ntlmclient/unicode.h +0 -36
  336. data/vendor/libgit2/deps/ntlmclient/unicode_builtin.c +0 -445
  337. data/vendor/libgit2/deps/ntlmclient/unicode_iconv.c +0 -201
  338. data/vendor/libgit2/deps/ntlmclient/utf8.h +0 -1257
  339. data/vendor/libgit2/deps/ntlmclient/util.c +0 -21
  340. data/vendor/libgit2/deps/ntlmclient/util.h +0 -14
  341. data/vendor/libgit2/deps/pcre/CMakeLists.txt +0 -140
  342. data/vendor/libgit2/deps/pcre/COPYING +0 -5
  343. data/vendor/libgit2/deps/pcre/cmake/COPYING-CMAKE-SCRIPTS +0 -22
  344. data/vendor/libgit2/deps/pcre/cmake/FindEditline.cmake +0 -17
  345. data/vendor/libgit2/deps/pcre/cmake/FindPackageHandleStandardArgs.cmake +0 -58
  346. data/vendor/libgit2/deps/pcre/cmake/FindReadline.cmake +0 -29
  347. data/vendor/libgit2/deps/pcre/config.h.in +0 -57
  348. data/vendor/libgit2/deps/pcre/pcre.h +0 -641
  349. data/vendor/libgit2/deps/pcre/pcre_byte_order.c +0 -319
  350. data/vendor/libgit2/deps/pcre/pcre_chartables.c +0 -198
  351. data/vendor/libgit2/deps/pcre/pcre_compile.c +0 -9800
  352. data/vendor/libgit2/deps/pcre/pcre_config.c +0 -190
  353. data/vendor/libgit2/deps/pcre/pcre_dfa_exec.c +0 -3676
  354. data/vendor/libgit2/deps/pcre/pcre_exec.c +0 -7173
  355. data/vendor/libgit2/deps/pcre/pcre_fullinfo.c +0 -245
  356. data/vendor/libgit2/deps/pcre/pcre_get.c +0 -669
  357. data/vendor/libgit2/deps/pcre/pcre_globals.c +0 -86
  358. data/vendor/libgit2/deps/pcre/pcre_internal.h +0 -2787
  359. data/vendor/libgit2/deps/pcre/pcre_jit_compile.c +0 -11913
  360. data/vendor/libgit2/deps/pcre/pcre_maketables.c +0 -156
  361. data/vendor/libgit2/deps/pcre/pcre_newline.c +0 -210
  362. data/vendor/libgit2/deps/pcre/pcre_ord2utf8.c +0 -94
  363. data/vendor/libgit2/deps/pcre/pcre_printint.c +0 -834
  364. data/vendor/libgit2/deps/pcre/pcre_refcount.c +0 -92
  365. data/vendor/libgit2/deps/pcre/pcre_string_utils.c +0 -211
  366. data/vendor/libgit2/deps/pcre/pcre_study.c +0 -1686
  367. data/vendor/libgit2/deps/pcre/pcre_tables.c +0 -727
  368. data/vendor/libgit2/deps/pcre/pcre_ucd.c +0 -3644
  369. data/vendor/libgit2/deps/pcre/pcre_valid_utf8.c +0 -301
  370. data/vendor/libgit2/deps/pcre/pcre_version.c +0 -98
  371. data/vendor/libgit2/deps/pcre/pcre_xclass.c +0 -268
  372. data/vendor/libgit2/deps/pcre/pcreposix.c +0 -421
  373. data/vendor/libgit2/deps/pcre/pcreposix.h +0 -117
  374. data/vendor/libgit2/deps/pcre/ucp.h +0 -224
  375. data/vendor/libgit2/deps/winhttp/COPYING.GPL +0 -993
  376. data/vendor/libgit2/deps/winhttp/COPYING.LGPL +0 -502
  377. data/vendor/libgit2/deps/zlib/COPYING +0 -27
  378. data/vendor/libgit2/include/git2/apply.h +0 -149
  379. data/vendor/libgit2/include/git2/cert.h +0 -135
  380. data/vendor/libgit2/include/git2/cred.h +0 -308
  381. data/vendor/libgit2/include/git2/deprecated.h +0 -493
  382. data/vendor/libgit2/include/git2/mailmap.h +0 -115
  383. data/vendor/libgit2/include/git2/sys/alloc.h +0 -101
  384. data/vendor/libgit2/include/git2/sys/cred.h +0 -90
  385. data/vendor/libgit2/include/git2/sys/path.h +0 -64
  386. data/vendor/libgit2/src/alloc.c +0 -43
  387. data/vendor/libgit2/src/alloc.h +0 -40
  388. data/vendor/libgit2/src/allocators/stdalloc.c +0 -119
  389. data/vendor/libgit2/src/allocators/win32_crtdbg.c +0 -118
  390. data/vendor/libgit2/src/config_backend.h +0 -96
  391. data/vendor/libgit2/src/config_entries.c +0 -229
  392. data/vendor/libgit2/src/config_entries.h +0 -24
  393. data/vendor/libgit2/src/config_mem.c +0 -220
  394. data/vendor/libgit2/src/config_snapshot.c +0 -206
  395. data/vendor/libgit2/src/errors.h +0 -81
  396. data/vendor/libgit2/src/hash/sha1.h +0 -38
  397. data/vendor/libgit2/src/hash/sha1/collisiondetect.c +0 -48
  398. data/vendor/libgit2/src/hash/sha1/collisiondetect.h +0 -19
  399. data/vendor/libgit2/src/hash/sha1/common_crypto.h +0 -19
  400. data/vendor/libgit2/src/hash/sha1/mbedtls.c +0 -46
  401. data/vendor/libgit2/src/hash/sha1/mbedtls.h +0 -19
  402. data/vendor/libgit2/src/hash/sha1/openssl.c +0 -59
  403. data/vendor/libgit2/src/hash/sha1/openssl.h +0 -19
  404. data/vendor/libgit2/src/mailmap.c +0 -485
  405. data/vendor/libgit2/src/mailmap.h +0 -35
  406. data/vendor/libgit2/src/net.c +0 -184
  407. data/vendor/libgit2/src/net.h +0 -36
  408. data/vendor/libgit2/src/reader.c +0 -265
  409. data/vendor/libgit2/src/reader.h +0 -107
  410. data/vendor/libgit2/src/regexp.c +0 -221
  411. data/vendor/libgit2/src/regexp.h +0 -97
  412. data/vendor/libgit2/src/streams/mbedtls.c +0 -483
  413. data/vendor/libgit2/src/streams/mbedtls.h +0 -23
  414. data/vendor/libgit2/src/streams/registry.c +0 -118
  415. data/vendor/libgit2/src/streams/registry.h +0 -19
  416. data/vendor/libgit2/src/transports/auth_ntlm.c +0 -223
  417. data/vendor/libgit2/src/transports/auth_ntlm.h +0 -35
  418. data/vendor/libgit2/src/wildmatch.c +0 -320
  419. data/vendor/libgit2/src/wildmatch.h +0 -23
  420. data/vendor/libgit2/src/win32/w32_common.h +0 -39
@@ -102,7 +102,7 @@ GIT_EXTERN(const git_oid *) git_tag_target_id(const git_tag *tag);
102
102
  * @param tag a previously loaded tag.
103
103
  * @return type of the tagged object
104
104
  */
105
- GIT_EXTERN(git_object_t) git_tag_target_type(const git_tag *tag);
105
+ GIT_EXTERN(git_otype) git_tag_target_type(const git_tag *tag);
106
106
 
107
107
  /**
108
108
  * Get the name of a tag
@@ -217,7 +217,7 @@ GIT_EXTERN(int) git_tag_annotation_create(
217
217
  * @param force Overwrite existing tags
218
218
  * @return 0 on success; error code otherwise
219
219
  */
220
- GIT_EXTERN(int) git_tag_create_from_buffer(
220
+ GIT_EXTERN(int) git_tag_create_frombuffer(
221
221
  git_oid *oid,
222
222
  git_repository *repo,
223
223
  const char *buffer,
@@ -317,17 +317,8 @@ GIT_EXTERN(int) git_tag_list_match(
317
317
  const char *pattern,
318
318
  git_repository *repo);
319
319
 
320
- /**
321
- * Callback used to iterate over tag names
322
- *
323
- * @see git_tag_foreach
324
- *
325
- * @param name The tag name
326
- * @param oid The tag's OID
327
- * @param payload Payload passed to git_tag_foreach
328
- * @return non-zero to terminate the iteration
329
- */
330
- typedef int GIT_CALLBACK(git_tag_foreach_cb)(const char *name, git_oid *oid, void *payload);
320
+
321
+ typedef int (*git_tag_foreach_cb)(const char *name, git_oid *oid, void *payload);
331
322
 
332
323
  /**
333
324
  * Call callback `cb' for each tag in the repository
@@ -49,7 +49,7 @@ typedef enum {
49
49
  /**
50
50
  * An instance for a tracing function
51
51
  */
52
- typedef void GIT_CALLBACK(git_trace_cb)(git_trace_level_t level, const char *msg);
52
+ typedef void (*git_trace_callback)(git_trace_level_t level, const char *msg);
53
53
 
54
54
  /**
55
55
  * Sets the system tracing configuration to the specified level with the
@@ -60,7 +60,7 @@ typedef void GIT_CALLBACK(git_trace_cb)(git_trace_level_t level, const char *msg
60
60
  * @param cb Function to call with trace data
61
61
  * @return 0 or an error code
62
62
  */
63
- GIT_EXTERN(int) git_trace_set(git_trace_level_t level, git_trace_cb cb);
63
+ GIT_EXTERN(int) git_trace_set(git_trace_level_t level, git_trace_callback cb);
64
64
 
65
65
  /** @} */
66
66
  GIT_END_DECL
@@ -8,7 +8,6 @@
8
8
  #define INCLUDE_git_transaction_h__
9
9
 
10
10
  #include "common.h"
11
- #include "types.h"
12
11
 
13
12
  /**
14
13
  * @file git2/transaction.h
@@ -10,8 +10,6 @@
10
10
  #include "indexer.h"
11
11
  #include "net.h"
12
12
  #include "types.h"
13
- #include "cert.h"
14
- #include "cred.h"
15
13
 
16
14
  /**
17
15
  * @file git2/transport.h
@@ -22,21 +20,323 @@
22
20
  */
23
21
  GIT_BEGIN_DECL
24
22
 
23
+ /** Signature of a function which creates a transport */
24
+ typedef int (*git_transport_cb)(git_transport **out, git_remote *owner, void *param);
25
+
26
+ /**
27
+ * Type of SSH host fingerprint
28
+ */
29
+ typedef enum {
30
+ /** MD5 is available */
31
+ GIT_CERT_SSH_MD5 = (1 << 0),
32
+ /** SHA-1 is available */
33
+ GIT_CERT_SSH_SHA1 = (1 << 1),
34
+ } git_cert_ssh_t;
35
+
36
+ /**
37
+ * Hostkey information taken from libssh2
38
+ */
39
+ typedef struct {
40
+ git_cert parent;
41
+
42
+ /**
43
+ * A hostkey type from libssh2, either
44
+ * `GIT_CERT_SSH_MD5` or `GIT_CERT_SSH_SHA1`
45
+ */
46
+ git_cert_ssh_t type;
47
+
48
+ /**
49
+ * Hostkey hash. If type has `GIT_CERT_SSH_MD5` set, this will
50
+ * have the MD5 hash of the hostkey.
51
+ */
52
+ unsigned char hash_md5[16];
53
+
54
+ /**
55
+ * Hostkey hash. If type has `GIT_CERT_SSH_SHA1` set, this will
56
+ * have the SHA-1 hash of the hostkey.
57
+ */
58
+ unsigned char hash_sha1[20];
59
+ } git_cert_hostkey;
60
+
25
61
  /**
26
- * Callback for messages recieved by the transport.
62
+ * X.509 certificate information
63
+ */
64
+ typedef struct {
65
+ git_cert parent;
66
+ /**
67
+ * Pointer to the X.509 certificate data
68
+ */
69
+ void *data;
70
+ /**
71
+ * Length of the memory block pointed to by `data`.
72
+ */
73
+ size_t len;
74
+ } git_cert_x509;
75
+
76
+ /*
77
+ *** Begin interface for credentials acquisition ***
78
+ */
79
+
80
+ /** Authentication type requested */
81
+ typedef enum {
82
+ /* git_cred_userpass_plaintext */
83
+ GIT_CREDTYPE_USERPASS_PLAINTEXT = (1u << 0),
84
+
85
+ /* git_cred_ssh_key */
86
+ GIT_CREDTYPE_SSH_KEY = (1u << 1),
87
+
88
+ /* git_cred_ssh_custom */
89
+ GIT_CREDTYPE_SSH_CUSTOM = (1u << 2),
90
+
91
+ /* git_cred_default */
92
+ GIT_CREDTYPE_DEFAULT = (1u << 3),
93
+
94
+ /* git_cred_ssh_interactive */
95
+ GIT_CREDTYPE_SSH_INTERACTIVE = (1u << 4),
96
+
97
+ /**
98
+ * Username-only information
99
+ *
100
+ * If the SSH transport does not know which username to use,
101
+ * it will ask via this credential type.
102
+ */
103
+ GIT_CREDTYPE_USERNAME = (1u << 5),
104
+
105
+ /**
106
+ * Credentials read from memory.
107
+ *
108
+ * Only available for libssh2+OpenSSL for now.
109
+ */
110
+ GIT_CREDTYPE_SSH_MEMORY = (1u << 6),
111
+ } git_credtype_t;
112
+
113
+ /* The base structure for all credential types */
114
+ typedef struct git_cred git_cred;
115
+
116
+ struct git_cred {
117
+ git_credtype_t credtype;
118
+ void (*free)(git_cred *cred);
119
+ };
120
+
121
+ /** A plaintext username and password */
122
+ typedef struct {
123
+ git_cred parent;
124
+ char *username;
125
+ char *password;
126
+ } git_cred_userpass_plaintext;
127
+
128
+
129
+ /*
130
+ * If the user hasn't included libssh2.h before git2.h, we need to
131
+ * define a few types for the callback signatures.
132
+ */
133
+ #ifndef LIBSSH2_VERSION
134
+ typedef struct _LIBSSH2_SESSION LIBSSH2_SESSION;
135
+ typedef struct _LIBSSH2_USERAUTH_KBDINT_PROMPT LIBSSH2_USERAUTH_KBDINT_PROMPT;
136
+ typedef struct _LIBSSH2_USERAUTH_KBDINT_RESPONSE LIBSSH2_USERAUTH_KBDINT_RESPONSE;
137
+ #endif
138
+
139
+ typedef int (*git_cred_sign_callback)(LIBSSH2_SESSION *session, unsigned char **sig, size_t *sig_len, const unsigned char *data, size_t data_len, void **abstract);
140
+ typedef void (*git_cred_ssh_interactive_callback)(const char* name, int name_len, const char* instruction, int instruction_len, int num_prompts, const LIBSSH2_USERAUTH_KBDINT_PROMPT* prompts, LIBSSH2_USERAUTH_KBDINT_RESPONSE* responses, void **abstract);
141
+
142
+ /**
143
+ * A ssh key from disk
144
+ */
145
+ typedef struct git_cred_ssh_key {
146
+ git_cred parent;
147
+ char *username;
148
+ char *publickey;
149
+ char *privatekey;
150
+ char *passphrase;
151
+ } git_cred_ssh_key;
152
+
153
+ /**
154
+ * Keyboard-interactive based ssh authentication
155
+ */
156
+ typedef struct git_cred_ssh_interactive {
157
+ git_cred parent;
158
+ char *username;
159
+ git_cred_ssh_interactive_callback prompt_callback;
160
+ void *payload;
161
+ } git_cred_ssh_interactive;
162
+
163
+ /**
164
+ * A key with a custom signature function
165
+ */
166
+ typedef struct git_cred_ssh_custom {
167
+ git_cred parent;
168
+ char *username;
169
+ char *publickey;
170
+ size_t publickey_len;
171
+ git_cred_sign_callback sign_callback;
172
+ void *payload;
173
+ } git_cred_ssh_custom;
174
+
175
+ /** A key for NTLM/Kerberos "default" credentials */
176
+ typedef struct git_cred git_cred_default;
177
+
178
+ /** Username-only credential information */
179
+ typedef struct git_cred_username {
180
+ git_cred parent;
181
+ char username[1];
182
+ } git_cred_username;
183
+
184
+ /**
185
+ * Check whether a credential object contains username information.
27
186
  *
28
- * Return a negative value to cancel the network operation.
187
+ * @param cred object to check
188
+ * @return 1 if the credential object has non-NULL username, 0 otherwise
189
+ */
190
+ GIT_EXTERN(int) git_cred_has_username(git_cred *cred);
191
+
192
+ /**
193
+ * Create a new plain-text username and password credential object.
194
+ * The supplied credential parameter will be internally duplicated.
29
195
  *
30
- * @param str The message from the transport
31
- * @param len The length of the message
32
- * @param payload Payload provided by the caller
196
+ * @param out The newly created credential object.
197
+ * @param username The username of the credential.
198
+ * @param password The password of the credential.
199
+ * @return 0 for success or an error code for failure
33
200
  */
34
- typedef int GIT_CALLBACK(git_transport_message_cb)(const char *str, int len, void *payload);
201
+ GIT_EXTERN(int) git_cred_userpass_plaintext_new(
202
+ git_cred **out,
203
+ const char *username,
204
+ const char *password);
35
205
 
36
- /** Signature of a function which creates a transport */
37
- typedef int GIT_CALLBACK(git_transport_cb)(git_transport **out, git_remote *owner, void *param);
206
+ /**
207
+ * Create a new passphrase-protected ssh key credential object.
208
+ * The supplied credential parameter will be internally duplicated.
209
+ *
210
+ * @param out The newly created credential object.
211
+ * @param username username to use to authenticate
212
+ * @param publickey The path to the public key of the credential.
213
+ * @param privatekey The path to the private key of the credential.
214
+ * @param passphrase The passphrase of the credential.
215
+ * @return 0 for success or an error code for failure
216
+ */
217
+ GIT_EXTERN(int) git_cred_ssh_key_new(
218
+ git_cred **out,
219
+ const char *username,
220
+ const char *publickey,
221
+ const char *privatekey,
222
+ const char *passphrase);
223
+
224
+ /**
225
+ * Create a new ssh keyboard-interactive based credential object.
226
+ * The supplied credential parameter will be internally duplicated.
227
+ *
228
+ * @param username Username to use to authenticate.
229
+ * @param prompt_callback The callback method used for prompts.
230
+ * @param payload Additional data to pass to the callback.
231
+ * @return 0 for success or an error code for failure.
232
+ */
233
+ GIT_EXTERN(int) git_cred_ssh_interactive_new(
234
+ git_cred **out,
235
+ const char *username,
236
+ git_cred_ssh_interactive_callback prompt_callback,
237
+ void *payload);
238
+
239
+ /**
240
+ * Create a new ssh key credential object used for querying an ssh-agent.
241
+ * The supplied credential parameter will be internally duplicated.
242
+ *
243
+ * @param out The newly created credential object.
244
+ * @param username username to use to authenticate
245
+ * @return 0 for success or an error code for failure
246
+ */
247
+ GIT_EXTERN(int) git_cred_ssh_key_from_agent(
248
+ git_cred **out,
249
+ const char *username);
250
+
251
+ /**
252
+ * Create an ssh key credential with a custom signing function.
253
+ *
254
+ * This lets you use your own function to sign the challenge.
255
+ *
256
+ * This function and its credential type is provided for completeness
257
+ * and wraps `libssh2_userauth_publickey()`, which is undocumented.
258
+ *
259
+ * The supplied credential parameter will be internally duplicated.
260
+ *
261
+ * @param out The newly created credential object.
262
+ * @param username username to use to authenticate
263
+ * @param publickey The bytes of the public key.
264
+ * @param publickey_len The length of the public key in bytes.
265
+ * @param sign_callback The callback method to sign the data during the challenge.
266
+ * @param payload Additional data to pass to the callback.
267
+ * @return 0 for success or an error code for failure
268
+ */
269
+ GIT_EXTERN(int) git_cred_ssh_custom_new(
270
+ git_cred **out,
271
+ const char *username,
272
+ const char *publickey,
273
+ size_t publickey_len,
274
+ git_cred_sign_callback sign_callback,
275
+ void *payload);
276
+
277
+ /**
278
+ * Create a "default" credential usable for Negotiate mechanisms like NTLM
279
+ * or Kerberos authentication.
280
+ *
281
+ * @return 0 for success or an error code for failure
282
+ */
283
+ GIT_EXTERN(int) git_cred_default_new(git_cred **out);
284
+
285
+ /**
286
+ * Create a credential to specify a username.
287
+ *
288
+ * This is used with ssh authentication to query for the username if
289
+ * none is specified in the url.
290
+ */
291
+ GIT_EXTERN(int) git_cred_username_new(git_cred **cred, const char *username);
292
+
293
+ /**
294
+ * Create a new ssh key credential object reading the keys from memory.
295
+ *
296
+ * @param out The newly created credential object.
297
+ * @param username username to use to authenticate.
298
+ * @param publickey The public key of the credential.
299
+ * @param privatekey The private key of the credential.
300
+ * @param passphrase The passphrase of the credential.
301
+ * @return 0 for success or an error code for failure
302
+ */
303
+ GIT_EXTERN(int) git_cred_ssh_key_memory_new(
304
+ git_cred **out,
305
+ const char *username,
306
+ const char *publickey,
307
+ const char *privatekey,
308
+ const char *passphrase);
309
+
310
+
311
+ /**
312
+ * Free a credential.
313
+ *
314
+ * This is only necessary if you own the object; that is, if you are a
315
+ * transport.
316
+ *
317
+ * @param cred the object to free
318
+ */
319
+ GIT_EXTERN(void) git_cred_free(git_cred *cred);
320
+
321
+ /**
322
+ * Signature of a function which acquires a credential object.
323
+ *
324
+ * @param cred The newly created credential object.
325
+ * @param url The resource for which we are demanding a credential.
326
+ * @param username_from_url The username that was embedded in a "user\@host"
327
+ * remote url, or NULL if not included.
328
+ * @param allowed_types A bitmask stating which cred types are OK to return.
329
+ * @param payload The payload provided when specifying this callback.
330
+ * @return 0 for success, < 0 to indicate an error, > 0 to indicate
331
+ * no credential was acquired
332
+ */
333
+ typedef int (*git_cred_acquire_cb)(
334
+ git_cred **cred,
335
+ const char *url,
336
+ const char *username_from_url,
337
+ unsigned int allowed_types,
338
+ void *payload);
38
339
 
39
340
  /** @} */
40
341
  GIT_END_DECL
41
-
42
342
  #endif
@@ -189,7 +189,7 @@ GIT_EXTERN(const git_oid *) git_tree_entry_id(const git_tree_entry *entry);
189
189
  * @param entry a tree entry
190
190
  * @return the type of the pointed object
191
191
  */
192
- GIT_EXTERN(git_object_t) git_tree_entry_type(const git_tree_entry *entry);
192
+ GIT_EXTERN(git_otype) git_tree_entry_type(const git_tree_entry *entry);
193
193
 
194
194
  /**
195
195
  * Get the UNIX file attributes of a tree entry
@@ -267,7 +267,7 @@ GIT_EXTERN(void) git_treebuilder_clear(git_treebuilder *bld);
267
267
  * @param bld a previously loaded treebuilder.
268
268
  * @return the number of entries in the treebuilder
269
269
  */
270
- GIT_EXTERN(size_t) git_treebuilder_entrycount(git_treebuilder *bld);
270
+ GIT_EXTERN(unsigned int) git_treebuilder_entrycount(git_treebuilder *bld);
271
271
 
272
272
  /**
273
273
  * Free a tree builder
@@ -344,7 +344,7 @@ GIT_EXTERN(int) git_treebuilder_remove(
344
344
  * entry should be left alone and any non-zero value meaning that the
345
345
  * entry should be removed from the treebuilder list (i.e. filtered out).
346
346
  */
347
- typedef int GIT_CALLBACK(git_treebuilder_filter_cb)(
347
+ typedef int (*git_treebuilder_filter_cb)(
348
348
  const git_tree_entry *entry, void *payload);
349
349
 
350
350
  /**
@@ -391,7 +391,7 @@ GIT_EXTERN(int) git_treebuilder_write_with_buffer(
391
391
  git_oid *oid, git_treebuilder *bld, git_buf *tree);
392
392
 
393
393
  /** Callback for the tree traversal method */
394
- typedef int GIT_CALLBACK(git_treewalk_cb)(
394
+ typedef int (*git_treewalk_cb)(
395
395
  const char *root, const git_tree_entry *entry, void *payload);
396
396
 
397
397
  /** Tree traversal modes */
@@ -59,27 +59,23 @@ typedef __haiku_std_int64 git_time_t;
59
59
  * app, even though /we/ define _FILE_OFFSET_BITS=64.
60
60
  */
61
61
  typedef int64_t git_off_t;
62
- typedef int64_t git_time_t; /**< time in seconds from epoch */
62
+ typedef int64_t git_time_t;
63
63
 
64
64
  #endif
65
65
 
66
- /** The maximum size of an object */
67
- typedef uint64_t git_object_size_t;
68
-
69
- #include "buffer.h"
70
- #include "oid.h"
71
-
72
66
  /** Basic type (loose or packed) of any Git object. */
73
67
  typedef enum {
74
- GIT_OBJECT_ANY = -2, /**< Object can be any of the following */
75
- GIT_OBJECT_INVALID = -1, /**< Object is invalid. */
76
- GIT_OBJECT_COMMIT = 1, /**< A commit object. */
77
- GIT_OBJECT_TREE = 2, /**< A tree (directory listing) object. */
78
- GIT_OBJECT_BLOB = 3, /**< A file revision object. */
79
- GIT_OBJECT_TAG = 4, /**< An annotated tag object. */
80
- GIT_OBJECT_OFS_DELTA = 6, /**< A delta, base is given by an offset. */
81
- GIT_OBJECT_REF_DELTA = 7, /**< A delta, base is given by object id. */
82
- } git_object_t;
68
+ GIT_OBJ_ANY = -2, /**< Object can be any of the following */
69
+ GIT_OBJ_BAD = -1, /**< Object is invalid. */
70
+ GIT_OBJ__EXT1 = 0, /**< Reserved for future use. */
71
+ GIT_OBJ_COMMIT = 1, /**< A commit object. */
72
+ GIT_OBJ_TREE = 2, /**< A tree (directory listing) object. */
73
+ GIT_OBJ_BLOB = 3, /**< A file revision object. */
74
+ GIT_OBJ_TAG = 4, /**< An annotated tag object. */
75
+ GIT_OBJ__EXT2 = 5, /**< Reserved for future use. */
76
+ GIT_OBJ_OFS_DELTA = 6, /**< A delta, base is given by an offset. */
77
+ GIT_OBJ_REF_DELTA = 7, /**< A delta, base is given by object id. */
78
+ } git_otype;
83
79
 
84
80
  /** An open object database handle. */
85
81
  typedef struct git_odb git_odb;
@@ -138,9 +134,6 @@ typedef struct git_treebuilder git_treebuilder;
138
134
  /** Memory representation of an index file. */
139
135
  typedef struct git_index git_index;
140
136
 
141
- /** An iterator for entries in the index. */
142
- typedef struct git_index_iterator git_index_iterator;
143
-
144
137
  /** An iterator for conflicts in the index. */
145
138
  typedef struct git_index_conflict_iterator git_index_conflict_iterator;
146
139
 
@@ -188,6 +181,9 @@ typedef struct git_transaction git_transaction;
188
181
  /** Annotated commits, the input to merge and rebase. */
189
182
  typedef struct git_annotated_commit git_annotated_commit;
190
183
 
184
+ /** Merge result */
185
+ typedef struct git_merge_result git_merge_result;
186
+
191
187
  /** Representation of a status collection */
192
188
  typedef struct git_status_list git_status_list;
193
189
 
@@ -196,11 +192,11 @@ typedef struct git_rebase git_rebase;
196
192
 
197
193
  /** Basic type of any Git reference. */
198
194
  typedef enum {
199
- GIT_REFERENCE_INVALID = 0, /**< Invalid reference */
200
- GIT_REFERENCE_DIRECT = 1, /**< A reference that points at an object id */
201
- GIT_REFERENCE_SYMBOLIC = 2, /**< A reference that points at another reference */
202
- GIT_REFERENCE_ALL = GIT_REFERENCE_DIRECT | GIT_REFERENCE_SYMBOLIC,
203
- } git_reference_t;
195
+ GIT_REF_INVALID = 0, /**< Invalid reference */
196
+ GIT_REF_OID = 1, /**< A reference which points at an object id */
197
+ GIT_REF_SYMBOLIC = 2, /**< A reference which points at another reference */
198
+ GIT_REF_LISTALL = GIT_REF_OID|GIT_REF_SYMBOLIC,
199
+ } git_ref_t;
204
200
 
205
201
  /** Basic type of any Git branch. */
206
202
  typedef enum {
@@ -219,7 +215,7 @@ typedef enum {
219
215
  GIT_FILEMODE_COMMIT = 0160000,
220
216
  } git_filemode_t;
221
217
 
222
- /**
218
+ /*
223
219
  * A refspec specifies the mapping between remote and local reference
224
220
  * names when fetch or pushing.
225
221
  */
@@ -247,10 +243,95 @@ typedef struct git_push git_push;
247
243
  typedef struct git_remote_head git_remote_head;
248
244
  typedef struct git_remote_callbacks git_remote_callbacks;
249
245
 
246
+ /**
247
+ * This is passed as the first argument to the callback to allow the
248
+ * user to see the progress.
249
+ *
250
+ * - total_objects: number of objects in the packfile being downloaded
251
+ * - indexed_objects: received objects that have been hashed
252
+ * - received_objects: objects which have been downloaded
253
+ * - local_objects: locally-available objects that have been injected
254
+ * in order to fix a thin pack.
255
+ * - received-bytes: size of the packfile received up to now
256
+ */
257
+ typedef struct git_transfer_progress {
258
+ unsigned int total_objects;
259
+ unsigned int indexed_objects;
260
+ unsigned int received_objects;
261
+ unsigned int local_objects;
262
+ unsigned int total_deltas;
263
+ unsigned int indexed_deltas;
264
+ size_t received_bytes;
265
+ } git_transfer_progress;
266
+
267
+ /**
268
+ * Type for progress callbacks during indexing. Return a value less than zero
269
+ * to cancel the transfer.
270
+ *
271
+ * @param stats Structure containing information about the state of the transfer
272
+ * @param payload Payload provided by caller
273
+ */
274
+ typedef int (*git_transfer_progress_cb)(const git_transfer_progress *stats, void *payload);
275
+
276
+ /**
277
+ * Type for messages delivered by the transport. Return a negative value
278
+ * to cancel the network operation.
279
+ *
280
+ * @param str The message from the transport
281
+ * @param len The length of the message
282
+ * @param payload Payload provided by the caller
283
+ */
284
+ typedef int (*git_transport_message_cb)(const char *str, int len, void *payload);
285
+
286
+
287
+ /**
288
+ * Type of host certificate structure that is passed to the check callback
289
+ */
290
+ typedef enum git_cert_t {
291
+ /**
292
+ * No information about the certificate is available. This may
293
+ * happen when using curl.
294
+ */
295
+ GIT_CERT_NONE,
296
+ /**
297
+ * The `data` argument to the callback will be a pointer to
298
+ * the DER-encoded data.
299
+ */
300
+ GIT_CERT_X509,
301
+ /**
302
+ * The `data` argument to the callback will be a pointer to a
303
+ * `git_cert_hostkey` structure.
304
+ */
305
+ GIT_CERT_HOSTKEY_LIBSSH2,
306
+ /**
307
+ * The `data` argument to the callback will be a pointer to a
308
+ * `git_strarray` with `name:content` strings containing
309
+ * information about the certificate. This is used when using
310
+ * curl.
311
+ */
312
+ GIT_CERT_STRARRAY,
313
+ } git_cert_t;
314
+
250
315
  /**
251
316
  * Parent type for `git_cert_hostkey` and `git_cert_x509`.
252
317
  */
253
- typedef struct git_cert git_cert;
318
+ typedef struct {
319
+ /**
320
+ * Type of certificate. A `GIT_CERT_` value.
321
+ */
322
+ git_cert_t cert_type;
323
+ } git_cert;
324
+
325
+ /**
326
+ * Callback for the user's custom certificate checks.
327
+ *
328
+ * @param cert The host certificate
329
+ * @param valid Whether the libgit2 checks (OpenSSL or WinHTTP) think
330
+ * this certificate is valid
331
+ * @param host Hostname of the host libgit2 connected to
332
+ * @param payload Payload provided by the caller
333
+ */
334
+ typedef int (*git_transport_certificate_check_cb)(git_cert *cert, int valid, const char *host, void *payload);
254
335
 
255
336
  /**
256
337
  * Opaque structure representing a submodule.
@@ -344,18 +425,15 @@ typedef enum {
344
425
  GIT_SUBMODULE_RECURSE_ONDEMAND = 2,
345
426
  } git_submodule_recurse_t;
346
427
 
428
+ /** A type to write in a streaming fashion, for example, for filters. */
347
429
  typedef struct git_writestream git_writestream;
348
430
 
349
- /** A type to write in a streaming fashion, for example, for filters. */
350
431
  struct git_writestream {
351
- int GIT_CALLBACK(write)(git_writestream *stream, const char *buffer, size_t len);
352
- int GIT_CALLBACK(close)(git_writestream *stream);
353
- void GIT_CALLBACK(free)(git_writestream *stream);
432
+ int (*write)(git_writestream *stream, const char *buffer, size_t len);
433
+ int (*close)(git_writestream *stream);
434
+ void (*free)(git_writestream *stream);
354
435
  };
355
436
 
356
- /** Representation of .mailmap file state. */
357
- typedef struct git_mailmap git_mailmap;
358
-
359
437
  /** @} */
360
438
  GIT_END_DECL
361
439