rugged 0.19.0 → 0.28.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (668) hide show
  1. checksums.yaml +7 -0
  2. data/LICENSE +1 -1
  3. data/README.md +184 -33
  4. data/ext/rugged/extconf.rb +111 -28
  5. data/ext/rugged/rugged.c +327 -89
  6. data/ext/rugged/rugged.h +64 -28
  7. data/ext/rugged/rugged_allocator.c +89 -0
  8. data/ext/rugged/rugged_backend.c +17 -0
  9. data/ext/rugged/rugged_blame.c +278 -0
  10. data/ext/rugged/rugged_blob.c +301 -75
  11. data/ext/rugged/rugged_branch.c +92 -242
  12. data/ext/rugged/rugged_branch_collection.c +388 -0
  13. data/ext/rugged/rugged_commit.c +575 -79
  14. data/ext/rugged/rugged_config.c +129 -36
  15. data/ext/rugged/rugged_cred.c +131 -0
  16. data/ext/rugged/rugged_diff.c +291 -122
  17. data/ext/rugged/rugged_diff_delta.c +16 -22
  18. data/ext/rugged/rugged_diff_hunk.c +35 -51
  19. data/ext/rugged/rugged_diff_line.c +23 -36
  20. data/ext/rugged/rugged_index.c +289 -152
  21. data/ext/rugged/rugged_note.c +50 -60
  22. data/ext/rugged/rugged_object.c +13 -30
  23. data/ext/rugged/rugged_patch.c +400 -0
  24. data/ext/rugged/rugged_rebase.c +397 -0
  25. data/ext/rugged/rugged_reference.c +76 -346
  26. data/ext/rugged/rugged_reference_collection.c +423 -0
  27. data/ext/rugged/rugged_remote.c +438 -461
  28. data/ext/rugged/rugged_remote_collection.c +435 -0
  29. data/ext/rugged/rugged_repo.c +1548 -365
  30. data/ext/rugged/rugged_revwalk.c +378 -99
  31. data/ext/rugged/rugged_settings.c +86 -23
  32. data/ext/rugged/rugged_signature.c +47 -37
  33. data/ext/rugged/rugged_submodule.c +835 -0
  34. data/ext/rugged/rugged_submodule_collection.c +366 -0
  35. data/ext/rugged/rugged_tag.c +88 -210
  36. data/ext/rugged/rugged_tag_collection.c +326 -0
  37. data/ext/rugged/rugged_tree.c +460 -217
  38. data/lib/rugged/attributes.rb +46 -0
  39. data/lib/rugged/blob.rb +33 -0
  40. data/lib/rugged/branch.rb +12 -16
  41. data/lib/rugged/commit.rb +9 -0
  42. data/lib/rugged/console.rb +5 -0
  43. data/lib/rugged/credentials.rb +48 -0
  44. data/lib/rugged/diff/delta.rb +6 -2
  45. data/lib/rugged/diff/hunk.rb +9 -9
  46. data/lib/rugged/diff/line.rb +28 -5
  47. data/lib/rugged/diff.rb +7 -1
  48. data/lib/rugged/index.rb +120 -0
  49. data/lib/rugged/object.rb +5 -0
  50. data/lib/rugged/patch.rb +41 -0
  51. data/lib/rugged/reference.rb +6 -3
  52. data/lib/rugged/remote.rb +5 -9
  53. data/lib/rugged/repository.rb +126 -14
  54. data/lib/rugged/submodule_collection.rb +53 -0
  55. data/lib/rugged/tag.rb +45 -16
  56. data/lib/rugged/tree.rb +163 -1
  57. data/lib/rugged/version.rb +6 -1
  58. data/lib/rugged/walker.rb +5 -0
  59. data/lib/rugged.rb +16 -1
  60. data/vendor/libgit2/AUTHORS +77 -0
  61. data/vendor/libgit2/CMakeLists.txt +317 -0
  62. data/vendor/libgit2/COPYING +993 -0
  63. data/vendor/libgit2/cmake/Modules/AddCFlagIfSupported.cmake +30 -0
  64. data/vendor/libgit2/cmake/Modules/CheckPrototypeDefinition.c.in +29 -0
  65. data/vendor/libgit2/cmake/Modules/CheckPrototypeDefinition.cmake +96 -0
  66. data/vendor/libgit2/cmake/Modules/EnableWarnings.cmake +11 -0
  67. data/vendor/libgit2/cmake/Modules/FindCoreFoundation.cmake +26 -0
  68. data/vendor/libgit2/cmake/Modules/FindGSSAPI.cmake +324 -0
  69. data/vendor/libgit2/cmake/Modules/FindHTTP_Parser.cmake +39 -0
  70. data/vendor/libgit2/cmake/Modules/FindIconv.cmake +45 -0
  71. data/vendor/libgit2/cmake/Modules/FindPkgLibraries.cmake +28 -0
  72. data/vendor/libgit2/cmake/Modules/FindSecurity.cmake +28 -0
  73. data/vendor/libgit2/cmake/Modules/FindStatNsec.cmake +20 -0
  74. data/vendor/libgit2/cmake/Modules/FindmbedTLS.cmake +93 -0
  75. data/vendor/libgit2/cmake/Modules/IdeSplitSources.cmake +22 -0
  76. data/vendor/libgit2/deps/http-parser/CMakeLists.txt +5 -0
  77. data/vendor/libgit2/deps/http-parser/COPYING +23 -0
  78. data/vendor/libgit2/deps/http-parser/http_parser.c +5 -2
  79. data/vendor/libgit2/deps/http-parser/http_parser.h +2 -0
  80. data/vendor/libgit2/deps/regex/CMakeLists.txt +2 -0
  81. data/vendor/libgit2/deps/regex/COPYING +502 -0
  82. data/vendor/libgit2/deps/regex/regex.c +10 -3
  83. data/vendor/libgit2/deps/winhttp/CMakeLists.txt +26 -0
  84. data/vendor/libgit2/deps/winhttp/COPYING.GPL +993 -0
  85. data/vendor/libgit2/deps/winhttp/COPYING.LGPL +502 -0
  86. data/vendor/libgit2/deps/winhttp/urlmon.h +45 -0
  87. data/vendor/libgit2/deps/winhttp/winhttp.def +29 -0
  88. data/vendor/libgit2/deps/winhttp/winhttp.h +594 -0
  89. data/vendor/libgit2/deps/winhttp/winhttp64.def +29 -0
  90. data/vendor/libgit2/deps/zlib/CMakeLists.txt +5 -0
  91. data/vendor/libgit2/deps/zlib/COPYING +27 -0
  92. data/vendor/libgit2/deps/zlib/adler32.c +51 -34
  93. data/vendor/libgit2/deps/zlib/crc32.c +61 -61
  94. data/vendor/libgit2/deps/zlib/crc32.h +1 -1
  95. data/vendor/libgit2/deps/zlib/deflate.c +681 -352
  96. data/vendor/libgit2/deps/zlib/deflate.h +25 -18
  97. data/vendor/libgit2/deps/zlib/gzguts.h +218 -0
  98. data/vendor/libgit2/deps/zlib/infback.c +640 -0
  99. data/vendor/libgit2/deps/zlib/inffast.c +36 -53
  100. data/vendor/libgit2/deps/zlib/inffixed.h +3 -3
  101. data/vendor/libgit2/deps/zlib/inflate.c +167 -86
  102. data/vendor/libgit2/deps/zlib/inflate.h +7 -4
  103. data/vendor/libgit2/deps/zlib/inftrees.c +24 -50
  104. data/vendor/libgit2/deps/zlib/trees.c +55 -96
  105. data/vendor/libgit2/deps/zlib/zconf.h +499 -19
  106. data/vendor/libgit2/deps/zlib/zlib.h +526 -227
  107. data/vendor/libgit2/deps/zlib/zutil.c +39 -32
  108. data/vendor/libgit2/deps/zlib/zutil.h +75 -78
  109. data/vendor/libgit2/include/git2/annotated_commit.h +125 -0
  110. data/vendor/libgit2/include/git2/apply.h +129 -0
  111. data/vendor/libgit2/include/git2/attr.h +36 -21
  112. data/vendor/libgit2/include/git2/blame.h +229 -0
  113. data/vendor/libgit2/include/git2/blob.h +81 -44
  114. data/vendor/libgit2/include/git2/branch.h +81 -42
  115. data/vendor/libgit2/include/git2/buffer.h +128 -0
  116. data/vendor/libgit2/include/git2/checkout.h +141 -67
  117. data/vendor/libgit2/include/git2/cherrypick.h +92 -0
  118. data/vendor/libgit2/include/git2/clone.h +157 -58
  119. data/vendor/libgit2/include/git2/commit.h +231 -12
  120. data/vendor/libgit2/include/git2/common.h +216 -30
  121. data/vendor/libgit2/include/git2/config.h +274 -48
  122. data/vendor/libgit2/include/git2/cred_helpers.h +4 -4
  123. data/vendor/libgit2/include/git2/deprecated.h +253 -0
  124. data/vendor/libgit2/include/git2/describe.h +189 -0
  125. data/vendor/libgit2/include/git2/diff.h +985 -575
  126. data/vendor/libgit2/include/git2/errors.h +93 -52
  127. data/vendor/libgit2/include/git2/filter.h +217 -0
  128. data/vendor/libgit2/include/git2/global.h +44 -0
  129. data/vendor/libgit2/include/git2/graph.h +17 -0
  130. data/vendor/libgit2/include/git2/ignore.h +2 -2
  131. data/vendor/libgit2/include/git2/index.h +269 -94
  132. data/vendor/libgit2/include/git2/indexer.h +44 -12
  133. data/vendor/libgit2/include/git2/mailmap.h +115 -0
  134. data/vendor/libgit2/include/git2/merge.h +501 -64
  135. data/vendor/libgit2/include/git2/message.h +52 -17
  136. data/vendor/libgit2/include/git2/net.h +11 -5
  137. data/vendor/libgit2/include/git2/notes.h +120 -16
  138. data/vendor/libgit2/include/git2/object.h +62 -23
  139. data/vendor/libgit2/include/git2/odb.h +140 -24
  140. data/vendor/libgit2/include/git2/odb_backend.h +56 -12
  141. data/vendor/libgit2/include/git2/oid.h +17 -18
  142. data/vendor/libgit2/include/git2/oidarray.h +40 -0
  143. data/vendor/libgit2/include/git2/pack.h +86 -7
  144. data/vendor/libgit2/include/git2/patch.h +274 -0
  145. data/vendor/libgit2/include/git2/pathspec.h +280 -0
  146. data/vendor/libgit2/include/git2/proxy.h +96 -0
  147. data/vendor/libgit2/include/git2/rebase.h +323 -0
  148. data/vendor/libgit2/include/git2/reflog.h +12 -9
  149. data/vendor/libgit2/include/git2/refs.h +241 -46
  150. data/vendor/libgit2/include/git2/refspec.h +20 -4
  151. data/vendor/libgit2/include/git2/remote.h +636 -209
  152. data/vendor/libgit2/include/git2/repository.h +267 -57
  153. data/vendor/libgit2/include/git2/reset.h +36 -6
  154. data/vendor/libgit2/include/git2/revert.h +91 -0
  155. data/vendor/libgit2/include/git2/revparse.h +27 -16
  156. data/vendor/libgit2/include/git2/revwalk.h +78 -35
  157. data/vendor/libgit2/include/git2/signature.h +32 -5
  158. data/vendor/libgit2/include/git2/stash.h +160 -21
  159. data/vendor/libgit2/include/git2/status.h +92 -30
  160. data/vendor/libgit2/include/git2/submodule.h +226 -133
  161. data/vendor/libgit2/include/git2/sys/alloc.h +101 -0
  162. data/vendor/libgit2/include/git2/sys/commit.h +38 -4
  163. data/vendor/libgit2/include/git2/sys/config.h +68 -9
  164. data/vendor/libgit2/include/git2/sys/diff.h +94 -0
  165. data/vendor/libgit2/include/git2/sys/filter.h +332 -0
  166. data/vendor/libgit2/include/git2/sys/hashsig.h +106 -0
  167. data/vendor/libgit2/include/git2/sys/index.h +6 -5
  168. data/vendor/libgit2/include/git2/sys/mempack.h +86 -0
  169. data/vendor/libgit2/include/git2/sys/merge.h +182 -0
  170. data/vendor/libgit2/include/git2/sys/odb_backend.h +66 -28
  171. data/vendor/libgit2/include/git2/sys/openssl.h +38 -0
  172. data/vendor/libgit2/include/git2/sys/path.h +64 -0
  173. data/vendor/libgit2/include/git2/sys/refdb_backend.h +79 -19
  174. data/vendor/libgit2/include/git2/sys/reflog.h +21 -0
  175. data/vendor/libgit2/include/git2/sys/refs.h +13 -2
  176. data/vendor/libgit2/include/git2/sys/repository.h +64 -1
  177. data/vendor/libgit2/include/git2/sys/stream.h +138 -0
  178. data/vendor/libgit2/include/git2/sys/time.h +31 -0
  179. data/vendor/libgit2/include/git2/sys/transport.h +439 -0
  180. data/vendor/libgit2/include/git2/tag.h +11 -2
  181. data/vendor/libgit2/include/git2/trace.h +1 -1
  182. data/vendor/libgit2/include/git2/transaction.h +121 -0
  183. data/vendor/libgit2/include/git2/transport.h +261 -292
  184. data/vendor/libgit2/include/git2/tree.h +111 -21
  185. data/vendor/libgit2/include/git2/types.h +244 -32
  186. data/vendor/libgit2/include/git2/version.h +5 -2
  187. data/vendor/libgit2/include/git2/worktree.h +255 -0
  188. data/vendor/libgit2/include/git2.h +50 -40
  189. data/vendor/libgit2/libgit2.pc.in +13 -0
  190. data/vendor/libgit2/src/CMakeLists.txt +525 -0
  191. data/vendor/libgit2/src/alloc.c +55 -0
  192. data/vendor/libgit2/src/alloc.h +40 -0
  193. data/vendor/libgit2/src/annotated_commit.c +228 -0
  194. data/vendor/libgit2/src/annotated_commit.h +52 -0
  195. data/vendor/libgit2/src/apply.c +855 -0
  196. data/vendor/libgit2/src/apply.h +25 -0
  197. data/vendor/libgit2/src/array.h +74 -16
  198. data/vendor/libgit2/src/attr.c +239 -408
  199. data/vendor/libgit2/src/attr.h +3 -33
  200. data/vendor/libgit2/src/attr_file.c +424 -156
  201. data/vendor/libgit2/src/attr_file.h +95 -23
  202. data/vendor/libgit2/src/attrcache.c +469 -0
  203. data/vendor/libgit2/src/attrcache.h +37 -5
  204. data/vendor/libgit2/src/bitvec.h +75 -0
  205. data/vendor/libgit2/src/blame.c +532 -0
  206. data/vendor/libgit2/src/blame.h +95 -0
  207. data/vendor/libgit2/src/blame_git.c +668 -0
  208. data/vendor/libgit2/src/blame_git.h +22 -0
  209. data/vendor/libgit2/src/blob.c +233 -129
  210. data/vendor/libgit2/src/blob.h +29 -1
  211. data/vendor/libgit2/src/branch.c +295 -197
  212. data/vendor/libgit2/src/branch.h +2 -0
  213. data/vendor/libgit2/src/buf_text.c +52 -27
  214. data/vendor/libgit2/src/buf_text.h +7 -7
  215. data/vendor/libgit2/src/buffer.c +609 -52
  216. data/vendor/libgit2/src/buffer.h +68 -23
  217. data/vendor/libgit2/src/cache.c +48 -51
  218. data/vendor/libgit2/src/cache.h +6 -4
  219. data/vendor/libgit2/src/cc-compat.h +35 -7
  220. data/vendor/libgit2/src/checkout.c +1827 -483
  221. data/vendor/libgit2/src/checkout.h +4 -1
  222. data/vendor/libgit2/src/cherrypick.c +230 -0
  223. data/vendor/libgit2/src/clone.c +338 -258
  224. data/vendor/libgit2/src/{compress.h → clone.h} +5 -5
  225. data/vendor/libgit2/src/commit.c +711 -124
  226. data/vendor/libgit2/src/commit.h +10 -3
  227. data/vendor/libgit2/src/commit_list.c +21 -14
  228. data/vendor/libgit2/src/commit_list.h +9 -3
  229. data/vendor/libgit2/src/common.h +153 -13
  230. data/vendor/libgit2/src/config.c +871 -242
  231. data/vendor/libgit2/src/config.h +58 -14
  232. data/vendor/libgit2/src/config_backend.h +84 -0
  233. data/vendor/libgit2/src/config_cache.c +44 -18
  234. data/vendor/libgit2/src/config_entries.c +259 -0
  235. data/vendor/libgit2/src/config_entries.h +23 -0
  236. data/vendor/libgit2/src/config_file.c +837 -1113
  237. data/vendor/libgit2/src/config_mem.c +224 -0
  238. data/vendor/libgit2/src/config_parse.c +558 -0
  239. data/vendor/libgit2/src/config_parse.h +64 -0
  240. data/vendor/libgit2/src/crlf.c +290 -195
  241. data/vendor/libgit2/src/date.c +35 -7
  242. data/vendor/libgit2/src/delta.c +275 -71
  243. data/vendor/libgit2/src/delta.h +80 -58
  244. data/vendor/libgit2/src/describe.c +893 -0
  245. data/vendor/libgit2/src/diff.c +330 -1128
  246. data/vendor/libgit2/src/diff.h +25 -67
  247. data/vendor/libgit2/src/diff_driver.c +225 -109
  248. data/vendor/libgit2/src/diff_driver.h +5 -2
  249. data/vendor/libgit2/src/diff_file.c +128 -103
  250. data/vendor/libgit2/src/diff_file.h +17 -12
  251. data/vendor/libgit2/src/diff_generate.c +1622 -0
  252. data/vendor/libgit2/src/diff_generate.h +128 -0
  253. data/vendor/libgit2/src/diff_parse.c +108 -0
  254. data/vendor/libgit2/src/diff_parse.h +20 -0
  255. data/vendor/libgit2/src/diff_print.c +578 -218
  256. data/vendor/libgit2/src/diff_stats.c +362 -0
  257. data/vendor/libgit2/src/diff_tform.c +429 -257
  258. data/vendor/libgit2/src/diff_tform.h +25 -0
  259. data/vendor/libgit2/src/diff_xdiff.c +143 -46
  260. data/vendor/libgit2/src/diff_xdiff.h +12 -5
  261. data/vendor/libgit2/src/errors.c +150 -34
  262. data/vendor/libgit2/src/features.h.in +37 -0
  263. data/vendor/libgit2/src/fetch.c +69 -46
  264. data/vendor/libgit2/src/fetch.h +6 -12
  265. data/vendor/libgit2/src/fetchhead.c +40 -33
  266. data/vendor/libgit2/src/fetchhead.h +5 -4
  267. data/vendor/libgit2/src/filebuf.c +163 -61
  268. data/vendor/libgit2/src/filebuf.h +13 -7
  269. data/vendor/libgit2/src/fileops.c +549 -407
  270. data/vendor/libgit2/src/fileops.h +97 -106
  271. data/vendor/libgit2/src/filter.c +989 -46
  272. data/vendor/libgit2/src/filter.h +21 -70
  273. data/vendor/libgit2/src/fnmatch.c +67 -11
  274. data/vendor/libgit2/src/fnmatch.h +27 -7
  275. data/vendor/libgit2/src/global.c +257 -63
  276. data/vendor/libgit2/src/global.h +19 -0
  277. data/vendor/libgit2/src/graph.c +39 -23
  278. data/vendor/libgit2/src/hash/hash_collisiondetect.h +51 -0
  279. data/vendor/libgit2/src/hash/hash_common_crypto.h +61 -0
  280. data/vendor/libgit2/src/hash/hash_generic.c +3 -3
  281. data/vendor/libgit2/src/hash/hash_generic.h +10 -5
  282. data/vendor/libgit2/src/hash/hash_mbedtls.c +38 -0
  283. data/vendor/libgit2/src/hash/hash_mbedtls.h +24 -0
  284. data/vendor/libgit2/src/hash/hash_openssl.h +26 -8
  285. data/vendor/libgit2/src/hash/hash_win32.c +71 -43
  286. data/vendor/libgit2/src/hash/hash_win32.h +4 -3
  287. data/vendor/libgit2/src/hash/sha1dc/sha1.c +1900 -0
  288. data/vendor/libgit2/src/hash/sha1dc/sha1.h +110 -0
  289. data/vendor/libgit2/src/hash/sha1dc/ubc_check.c +372 -0
  290. data/vendor/libgit2/src/hash/sha1dc/ubc_check.h +52 -0
  291. data/vendor/libgit2/src/hash.c +0 -1
  292. data/vendor/libgit2/src/hash.h +13 -6
  293. data/vendor/libgit2/src/hashsig.c +121 -126
  294. data/vendor/libgit2/src/ident.c +129 -0
  295. data/vendor/libgit2/src/idxmap.c +153 -0
  296. data/vendor/libgit2/src/idxmap.h +41 -0
  297. data/vendor/libgit2/src/ignore.c +362 -123
  298. data/vendor/libgit2/src/ignore.h +16 -4
  299. data/vendor/libgit2/src/index.c +2131 -692
  300. data/vendor/libgit2/src/index.h +138 -6
  301. data/vendor/libgit2/src/indexer.c +866 -266
  302. data/vendor/libgit2/src/indexer.h +16 -0
  303. data/vendor/libgit2/src/integer.h +106 -0
  304. data/vendor/libgit2/src/iterator.c +1888 -967
  305. data/vendor/libgit2/src/iterator.h +130 -67
  306. data/vendor/libgit2/src/khash.h +43 -29
  307. data/vendor/libgit2/src/mailmap.c +485 -0
  308. data/vendor/libgit2/src/mailmap.h +35 -0
  309. data/vendor/libgit2/src/map.h +1 -1
  310. data/vendor/libgit2/src/merge.c +1679 -479
  311. data/vendor/libgit2/src/merge.h +89 -22
  312. data/vendor/libgit2/src/merge_driver.c +426 -0
  313. data/vendor/libgit2/src/merge_driver.h +62 -0
  314. data/vendor/libgit2/src/merge_file.c +238 -101
  315. data/vendor/libgit2/src/message.c +4 -28
  316. data/vendor/libgit2/src/message.h +3 -1
  317. data/vendor/libgit2/src/mwindow.c +123 -15
  318. data/vendor/libgit2/src/mwindow.h +10 -1
  319. data/vendor/libgit2/src/netops.c +178 -499
  320. data/vendor/libgit2/src/netops.h +51 -27
  321. data/vendor/libgit2/src/notes.c +251 -94
  322. data/vendor/libgit2/src/notes.h +5 -2
  323. data/vendor/libgit2/src/object.c +253 -67
  324. data/vendor/libgit2/src/object.h +40 -2
  325. data/vendor/libgit2/src/object_api.c +30 -11
  326. data/vendor/libgit2/src/odb.c +765 -201
  327. data/vendor/libgit2/src/odb.h +40 -8
  328. data/vendor/libgit2/src/odb_loose.c +560 -346
  329. data/vendor/libgit2/src/odb_mempack.c +185 -0
  330. data/vendor/libgit2/src/odb_pack.c +117 -73
  331. data/vendor/libgit2/src/offmap.c +113 -0
  332. data/vendor/libgit2/src/offmap.h +32 -42
  333. data/vendor/libgit2/src/oid.c +45 -25
  334. data/vendor/libgit2/src/oid.h +26 -8
  335. data/vendor/libgit2/src/oidarray.c +34 -0
  336. data/vendor/libgit2/src/oidarray.h +20 -0
  337. data/vendor/libgit2/src/oidmap.c +125 -0
  338. data/vendor/libgit2/src/oidmap.h +30 -17
  339. data/vendor/libgit2/src/pack-objects.c +688 -265
  340. data/vendor/libgit2/src/pack-objects.h +27 -13
  341. data/vendor/libgit2/src/pack.c +418 -202
  342. data/vendor/libgit2/src/pack.h +25 -16
  343. data/vendor/libgit2/src/parse.c +124 -0
  344. data/vendor/libgit2/src/parse.h +61 -0
  345. data/vendor/libgit2/src/patch.c +223 -0
  346. data/vendor/libgit2/src/patch.h +68 -0
  347. data/vendor/libgit2/src/patch_generate.c +901 -0
  348. data/vendor/libgit2/src/patch_generate.h +69 -0
  349. data/vendor/libgit2/src/patch_parse.c +1136 -0
  350. data/vendor/libgit2/src/patch_parse.h +51 -0
  351. data/vendor/libgit2/src/path.c +1247 -241
  352. data/vendor/libgit2/src/path.h +353 -57
  353. data/vendor/libgit2/src/pathspec.c +586 -58
  354. data/vendor/libgit2/src/pathspec.h +37 -15
  355. data/vendor/libgit2/src/pool.c +134 -221
  356. data/vendor/libgit2/src/pool.h +38 -50
  357. data/vendor/libgit2/src/posix.c +76 -10
  358. data/vendor/libgit2/src/posix.h +74 -32
  359. data/vendor/libgit2/src/pqueue.c +79 -117
  360. data/vendor/libgit2/src/pqueue.h +38 -82
  361. data/vendor/libgit2/src/proxy.c +39 -0
  362. data/vendor/libgit2/src/proxy.h +17 -0
  363. data/vendor/libgit2/src/push.c +178 -279
  364. data/vendor/libgit2/src/push.h +93 -4
  365. data/vendor/libgit2/src/reader.c +265 -0
  366. data/vendor/libgit2/src/reader.h +107 -0
  367. data/vendor/libgit2/src/rebase.c +1364 -0
  368. data/vendor/libgit2/src/refdb.c +74 -19
  369. data/vendor/libgit2/src/refdb.h +16 -3
  370. data/vendor/libgit2/src/refdb_fs.c +1472 -603
  371. data/vendor/libgit2/src/refdb_fs.h +4 -0
  372. data/vendor/libgit2/src/reflog.c +40 -330
  373. data/vendor/libgit2/src/reflog.h +8 -2
  374. data/vendor/libgit2/src/refs.c +641 -225
  375. data/vendor/libgit2/src/refs.h +53 -6
  376. data/vendor/libgit2/src/refspec.c +175 -62
  377. data/vendor/libgit2/src/refspec.h +10 -25
  378. data/vendor/libgit2/src/remote.c +1741 -723
  379. data/vendor/libgit2/src/remote.h +17 -5
  380. data/vendor/libgit2/src/repository.c +1505 -421
  381. data/vendor/libgit2/src/repository.h +95 -15
  382. data/vendor/libgit2/src/reset.c +63 -26
  383. data/vendor/libgit2/src/revert.c +232 -0
  384. data/vendor/libgit2/src/revparse.c +94 -80
  385. data/vendor/libgit2/src/revwalk.c +427 -194
  386. data/vendor/libgit2/src/revwalk.h +14 -5
  387. data/vendor/libgit2/src/settings.c +290 -0
  388. data/vendor/libgit2/src/sha1_lookup.c +16 -159
  389. data/vendor/libgit2/src/sha1_lookup.h +5 -4
  390. data/vendor/libgit2/src/signature.c +138 -26
  391. data/vendor/libgit2/src/signature.h +5 -0
  392. data/vendor/libgit2/src/sortedcache.c +395 -0
  393. data/vendor/libgit2/src/sortedcache.h +180 -0
  394. data/vendor/libgit2/src/stash.c +629 -168
  395. data/vendor/libgit2/src/status.c +125 -75
  396. data/vendor/libgit2/src/status.h +4 -2
  397. data/vendor/libgit2/src/stdalloc.c +120 -0
  398. data/vendor/libgit2/src/stdalloc.h +17 -0
  399. data/vendor/libgit2/src/stream.h +86 -0
  400. data/vendor/libgit2/src/streams/mbedtls.c +483 -0
  401. data/vendor/libgit2/src/streams/mbedtls.h +23 -0
  402. data/vendor/libgit2/src/streams/openssl.c +789 -0
  403. data/vendor/libgit2/src/streams/openssl.h +23 -0
  404. data/vendor/libgit2/src/streams/registry.c +118 -0
  405. data/vendor/libgit2/src/streams/registry.h +19 -0
  406. data/vendor/libgit2/src/streams/socket.c +235 -0
  407. data/vendor/libgit2/src/streams/socket.h +23 -0
  408. data/vendor/libgit2/src/streams/stransport.c +323 -0
  409. data/vendor/libgit2/src/streams/stransport.h +21 -0
  410. data/vendor/libgit2/src/streams/tls.c +73 -0
  411. data/vendor/libgit2/src/streams/tls.h +31 -0
  412. data/vendor/libgit2/src/strmap.c +147 -0
  413. data/vendor/libgit2/src/strmap.h +46 -51
  414. data/vendor/libgit2/src/strnlen.h +24 -0
  415. data/vendor/libgit2/src/submodule.c +1633 -877
  416. data/vendor/libgit2/src/submodule.h +83 -21
  417. data/vendor/libgit2/src/sysdir.c +355 -0
  418. data/vendor/libgit2/src/sysdir.h +119 -0
  419. data/vendor/libgit2/src/tag.c +87 -62
  420. data/vendor/libgit2/src/tag.h +4 -1
  421. data/vendor/libgit2/src/thread-utils.c +3 -0
  422. data/vendor/libgit2/src/thread-utils.h +71 -35
  423. data/vendor/libgit2/src/trace.c +4 -4
  424. data/vendor/libgit2/src/trace.h +11 -3
  425. data/vendor/libgit2/src/trailer.c +416 -0
  426. data/vendor/libgit2/src/transaction.c +382 -0
  427. data/vendor/libgit2/src/transaction.h +14 -0
  428. data/vendor/libgit2/src/transport.c +133 -67
  429. data/vendor/libgit2/src/transports/auth.c +75 -0
  430. data/vendor/libgit2/src/transports/auth.h +64 -0
  431. data/vendor/libgit2/src/transports/auth_negotiate.c +277 -0
  432. data/vendor/libgit2/src/transports/auth_negotiate.h +27 -0
  433. data/vendor/libgit2/src/transports/cred.c +296 -68
  434. data/vendor/libgit2/src/transports/cred.h +16 -0
  435. data/vendor/libgit2/src/transports/cred_helpers.c +4 -0
  436. data/vendor/libgit2/src/transports/git.c +108 -90
  437. data/vendor/libgit2/src/transports/http.c +803 -258
  438. data/vendor/libgit2/src/transports/http.h +25 -0
  439. data/vendor/libgit2/src/transports/local.c +265 -169
  440. data/vendor/libgit2/src/transports/smart.c +255 -45
  441. data/vendor/libgit2/src/transports/smart.h +42 -22
  442. data/vendor/libgit2/src/transports/smart_pkt.c +250 -159
  443. data/vendor/libgit2/src/transports/smart_protocol.c +414 -196
  444. data/vendor/libgit2/src/transports/ssh.c +645 -236
  445. data/vendor/libgit2/src/transports/ssh.h +14 -0
  446. data/vendor/libgit2/src/transports/winhttp.c +809 -353
  447. data/vendor/libgit2/src/tree-cache.c +138 -52
  448. data/vendor/libgit2/src/tree-cache.h +14 -7
  449. data/vendor/libgit2/src/tree.c +620 -259
  450. data/vendor/libgit2/src/tree.h +12 -19
  451. data/vendor/libgit2/src/tsort.c +3 -2
  452. data/vendor/libgit2/src/unix/map.c +25 -7
  453. data/vendor/libgit2/src/unix/posix.h +77 -12
  454. data/vendor/libgit2/src/unix/pthread.h +56 -0
  455. data/vendor/libgit2/src/unix/realpath.c +12 -8
  456. data/vendor/libgit2/src/userdiff.h +208 -0
  457. data/vendor/libgit2/src/util.c +349 -165
  458. data/vendor/libgit2/src/util.h +167 -85
  459. data/vendor/libgit2/src/varint.c +43 -0
  460. data/vendor/libgit2/src/varint.h +17 -0
  461. data/vendor/libgit2/src/vector.c +156 -33
  462. data/vendor/libgit2/src/vector.h +41 -5
  463. data/vendor/libgit2/src/win32/dir.c +22 -42
  464. data/vendor/libgit2/src/win32/dir.h +7 -5
  465. data/vendor/libgit2/src/win32/error.c +6 -32
  466. data/vendor/libgit2/src/win32/error.h +4 -2
  467. data/vendor/libgit2/src/win32/findfile.c +62 -69
  468. data/vendor/libgit2/src/win32/findfile.h +5 -13
  469. data/vendor/libgit2/src/win32/git2.rc +44 -0
  470. data/vendor/libgit2/src/win32/map.c +39 -11
  471. data/vendor/libgit2/src/win32/mingw-compat.h +10 -11
  472. data/vendor/libgit2/src/win32/msvc-compat.h +10 -33
  473. data/vendor/libgit2/src/win32/path_w32.c +476 -0
  474. data/vendor/libgit2/src/win32/path_w32.h +104 -0
  475. data/vendor/libgit2/src/win32/posix.h +35 -30
  476. data/vendor/libgit2/src/win32/posix_w32.c +659 -327
  477. data/vendor/libgit2/src/win32/precompiled.h +7 -2
  478. data/vendor/libgit2/src/win32/reparse.h +57 -0
  479. data/vendor/libgit2/src/win32/thread.c +258 -0
  480. data/vendor/libgit2/src/win32/thread.h +64 -0
  481. data/vendor/libgit2/src/win32/utf-conv.c +127 -62
  482. data/vendor/libgit2/src/win32/utf-conv.h +47 -6
  483. data/vendor/libgit2/src/win32/version.h +21 -4
  484. data/vendor/libgit2/src/win32/w32_buffer.c +54 -0
  485. data/vendor/libgit2/src/win32/w32_buffer.h +20 -0
  486. data/vendor/libgit2/src/win32/w32_crtdbg_stacktrace.c +438 -0
  487. data/vendor/libgit2/src/win32/w32_crtdbg_stacktrace.h +129 -0
  488. data/vendor/libgit2/src/win32/w32_stack.c +193 -0
  489. data/vendor/libgit2/src/win32/w32_stack.h +140 -0
  490. data/vendor/libgit2/src/win32/w32_util.c +95 -0
  491. data/vendor/libgit2/src/win32/w32_util.h +170 -0
  492. data/vendor/libgit2/src/win32/win32-compat.h +52 -0
  493. data/vendor/libgit2/src/worktree.c +578 -0
  494. data/vendor/libgit2/src/worktree.h +39 -0
  495. data/vendor/libgit2/src/xdiff/xdiff.h +33 -18
  496. data/vendor/libgit2/src/xdiff/xdiffi.c +578 -88
  497. data/vendor/libgit2/src/xdiff/xdiffi.h +3 -2
  498. data/vendor/libgit2/src/xdiff/xemit.c +106 -45
  499. data/vendor/libgit2/src/xdiff/xemit.h +3 -3
  500. data/vendor/libgit2/src/xdiff/xhistogram.c +5 -4
  501. data/vendor/libgit2/src/xdiff/xinclude.h +3 -2
  502. data/vendor/libgit2/src/xdiff/xmacros.h +2 -2
  503. data/vendor/libgit2/src/xdiff/xmerge.c +167 -48
  504. data/vendor/libgit2/src/xdiff/xpatience.c +42 -10
  505. data/vendor/libgit2/src/xdiff/xprepare.c +14 -14
  506. data/vendor/libgit2/src/xdiff/xprepare.h +2 -2
  507. data/vendor/libgit2/src/xdiff/xtypes.h +2 -2
  508. data/vendor/libgit2/src/xdiff/xutils.c +60 -56
  509. data/vendor/libgit2/src/xdiff/xutils.h +3 -5
  510. data/vendor/libgit2/src/zstream.c +205 -0
  511. data/vendor/libgit2/src/zstream.h +53 -0
  512. metadata +281 -233
  513. data/Rakefile +0 -61
  514. data/ext/rugged/rugged_diff_patch.c +0 -169
  515. data/lib/rugged/diff/patch.rb +0 -28
  516. data/test/blob_test.rb +0 -341
  517. data/test/branch_test.rb +0 -199
  518. data/test/commit_test.rb +0 -104
  519. data/test/config_test.rb +0 -45
  520. data/test/coverage/cover.rb +0 -133
  521. data/test/diff_test.rb +0 -777
  522. data/test/errors_test.rb +0 -34
  523. data/test/fixtures/alternate/objects/14/6ae76773c91e3b1d00cf7a338ec55ae58297e2 +0 -0
  524. data/test/fixtures/alternate/objects/14/9c32d47e99d0a3572ff1e70a2e0051bbf347a9 +0 -0
  525. data/test/fixtures/alternate/objects/14/fb3108588f9421bf764041e5e3ac305eb6277f +0 -0
  526. data/test/fixtures/archive.tar.gz +0 -0
  527. data/test/fixtures/attr/attr0 +0 -1
  528. data/test/fixtures/attr/attr1 +0 -29
  529. data/test/fixtures/attr/attr2 +0 -21
  530. data/test/fixtures/attr/attr3 +0 -4
  531. data/test/fixtures/attr/binfile +0 -1
  532. data/test/fixtures/attr/dir/file +0 -0
  533. data/test/fixtures/attr/file +0 -1
  534. data/test/fixtures/attr/gitattributes +0 -29
  535. data/test/fixtures/attr/gitignore +0 -2
  536. data/test/fixtures/attr/ign +0 -1
  537. data/test/fixtures/attr/macro_bad +0 -1
  538. data/test/fixtures/attr/macro_test +0 -1
  539. data/test/fixtures/attr/root_test1 +0 -1
  540. data/test/fixtures/attr/root_test2 +0 -6
  541. data/test/fixtures/attr/root_test3 +0 -19
  542. data/test/fixtures/attr/root_test4.txt +0 -14
  543. data/test/fixtures/attr/sub/abc +0 -37
  544. data/test/fixtures/attr/sub/dir/file +0 -0
  545. data/test/fixtures/attr/sub/file +0 -1
  546. data/test/fixtures/attr/sub/ign/file +0 -1
  547. data/test/fixtures/attr/sub/ign/sub/file +0 -1
  548. data/test/fixtures/attr/sub/sub/dir +0 -0
  549. data/test/fixtures/attr/sub/sub/file +0 -1
  550. data/test/fixtures/attr/sub/sub/subsub.txt +0 -1
  551. data/test/fixtures/attr/sub/subdir_test1 +0 -2
  552. data/test/fixtures/attr/sub/subdir_test2.txt +0 -1
  553. data/test/fixtures/diff/another.txt +0 -38
  554. data/test/fixtures/diff/readme.txt +0 -36
  555. data/test/fixtures/mergedrepo/conflicts-one.txt +0 -5
  556. data/test/fixtures/mergedrepo/conflicts-two.txt +0 -5
  557. data/test/fixtures/mergedrepo/one.txt +0 -10
  558. data/test/fixtures/mergedrepo/two.txt +0 -12
  559. data/test/fixtures/status/current_file +0 -1
  560. data/test/fixtures/status/ignored_file +0 -1
  561. data/test/fixtures/status/modified_file +0 -2
  562. data/test/fixtures/status/new_file +0 -1
  563. data/test/fixtures/status/staged_changes +0 -2
  564. data/test/fixtures/status/staged_changes_modified_file +0 -3
  565. data/test/fixtures/status/staged_delete_modified_file +0 -1
  566. data/test/fixtures/status/staged_new_file +0 -1
  567. data/test/fixtures/status/staged_new_file_modified_file +0 -2
  568. data/test/fixtures/status/subdir/current_file +0 -1
  569. data/test/fixtures/status/subdir/modified_file +0 -2
  570. data/test/fixtures/status/subdir/new_file +0 -1
  571. data/test/fixtures/status/subdir.txt +0 -2
  572. data/test/fixtures/status//350/277/231 +0 -1
  573. data/test/fixtures/testrepo.git/HEAD +0 -1
  574. data/test/fixtures/testrepo.git/config +0 -13
  575. data/test/fixtures/testrepo.git/description +0 -1
  576. data/test/fixtures/testrepo.git/index +0 -0
  577. data/test/fixtures/testrepo.git/info/exclude +0 -6
  578. data/test/fixtures/testrepo.git/logs/HEAD +0 -3
  579. data/test/fixtures/testrepo.git/logs/refs/heads/master +0 -3
  580. data/test/fixtures/testrepo.git/logs/refs/notes/commits +0 -1
  581. data/test/fixtures/testrepo.git/objects/0c/37a5391bbff43c37f0d0371823a5509eed5b1d +0 -0
  582. data/test/fixtures/testrepo.git/objects/13/85f264afb75a56a5bec74243be9b367ba4ca08 +0 -0
  583. data/test/fixtures/testrepo.git/objects/18/1037049a54a1eb5fab404658a3a250b44335d7 +0 -0
  584. data/test/fixtures/testrepo.git/objects/18/10dff58d8a660512d4832e740f692884338ccd +0 -0
  585. data/test/fixtures/testrepo.git/objects/2d/2eff63372b08adf0a9eb84109ccf7d19e2f3a2 +0 -0
  586. data/test/fixtures/testrepo.git/objects/36/060c58702ed4c2a40832c51758d5344201d89a +0 -2
  587. data/test/fixtures/testrepo.git/objects/44/1034f860c1d5d90e4188d11ae0d325176869a8 +0 -1
  588. data/test/fixtures/testrepo.git/objects/45/b983be36b73c0788dc9cbcb76cbb80fc7bb057 +0 -0
  589. data/test/fixtures/testrepo.git/objects/4a/202b346bb0fb0db7eff3cffeb3c70babbd2045 +0 -2
  590. data/test/fixtures/testrepo.git/objects/5b/5b025afb0b4c913b4c338a42934a3863bf3644 +0 -2
  591. data/test/fixtures/testrepo.git/objects/60/d415052a33de2150bf68757f6461df4f563ae4 +0 -0
  592. data/test/fixtures/testrepo.git/objects/61/9f9935957e010c419cb9d15621916ddfcc0b96 +0 -0
  593. data/test/fixtures/testrepo.git/objects/68/8a8f4ef7496901d15322972f96e212a9e466cc +0 -1
  594. data/test/fixtures/testrepo.git/objects/75/057dd4114e74cca1d750d0aee1647c903cb60a +0 -0
  595. data/test/fixtures/testrepo.git/objects/77/71329dfa3002caf8c61a0ceb62a31d09023f37 +0 -0
  596. data/test/fixtures/testrepo.git/objects/81/4889a078c031f61ed08ab5fa863aea9314344d +0 -0
  597. data/test/fixtures/testrepo.git/objects/84/96071c1b46c854b31185ea97743be6a8774479 +0 -0
  598. data/test/fixtures/testrepo.git/objects/94/eca2de348d5f672faf56b0decafa5937e3235e +0 -0
  599. data/test/fixtures/testrepo.git/objects/9b/7384fe1676186192842f5d3e129457b62db9e3 +0 -0
  600. data/test/fixtures/testrepo.git/objects/9f/d738e8f7967c078dceed8190330fc8648ee56a +0 -3
  601. data/test/fixtures/testrepo.git/objects/a4/a7dce85cf63874e984719f4fdd239f5145052f +0 -2
  602. data/test/fixtures/testrepo.git/objects/a7/1586c1dfe8a71c6cbf6c129f404c5642ff31bd +0 -0
  603. data/test/fixtures/testrepo.git/objects/a8/233120f6ad708f843d861ce2b7228ec4e3dec6 +0 -0
  604. data/test/fixtures/testrepo.git/objects/b7/4713326bc972cc15751ed504dca6f6f3b91f7a +0 -3
  605. data/test/fixtures/testrepo.git/objects/be/3563ae3f795b2b4353bcce3a527ad0a4f7f644 +0 -3
  606. data/test/fixtures/testrepo.git/objects/c4/7800c7266a2be04c571c04d5a6614691ea99bd +0 -3
  607. data/test/fixtures/testrepo.git/objects/c4/dc1555e4d4fa0e0c9c3fc46734c7c35b3ce90b +0 -0
  608. data/test/fixtures/testrepo.git/objects/e6/9de29bb2d1d6434b8b29ae775ad8c2e48c5391 +0 -0
  609. data/test/fixtures/testrepo.git/objects/f6/0079018b664e4e79329a7ef9559c8d9e0378d1 +0 -0
  610. data/test/fixtures/testrepo.git/objects/fa/49b077972391ad58037050f2a75f74e3671e92 +0 -0
  611. data/test/fixtures/testrepo.git/objects/fd/093bff70906175335656e6ce6ae05783708765 +0 -0
  612. data/test/fixtures/testrepo.git/objects/pack/pack-d7c6adf9f61318f041845b01440d09aa7a91e1b5.idx +0 -0
  613. data/test/fixtures/testrepo.git/objects/pack/pack-d7c6adf9f61318f041845b01440d09aa7a91e1b5.pack +0 -0
  614. data/test/fixtures/testrepo.git/packed-refs +0 -2
  615. data/test/fixtures/testrepo.git/refs/heads/master +0 -1
  616. data/test/fixtures/testrepo.git/refs/notes/commits +0 -1
  617. data/test/fixtures/testrepo.git/refs/tags/v0.9 +0 -1
  618. data/test/fixtures/testrepo.git/refs/tags/v1.0 +0 -1
  619. data/test/fixtures/text_file.md +0 -464
  620. data/test/fixtures/unsymlinked.git/HEAD +0 -1
  621. data/test/fixtures/unsymlinked.git/config +0 -6
  622. data/test/fixtures/unsymlinked.git/description +0 -1
  623. data/test/fixtures/unsymlinked.git/info/exclude +0 -2
  624. data/test/fixtures/unsymlinked.git/objects/08/8b64704e0d6b8bd061dea879418cb5442a3fbf +0 -0
  625. data/test/fixtures/unsymlinked.git/objects/13/a5e939bca25940c069fd2169d993dba328e30b +0 -0
  626. data/test/fixtures/unsymlinked.git/objects/19/bf568e59e3a0b363cafb4106226e62d4a4c41c +0 -0
  627. data/test/fixtures/unsymlinked.git/objects/58/1fadd35b4cf320d102a152f918729011604773 +0 -0
  628. data/test/fixtures/unsymlinked.git/objects/5c/87b6791e8b13da658a14d1ef7e09b5dc3bac8c +0 -0
  629. data/test/fixtures/unsymlinked.git/objects/6f/e5f5398af85fb3de8a6aba0339b6d3bfa26a27 +0 -0
  630. data/test/fixtures/unsymlinked.git/objects/7f/ccd75616ec188b8f1b23d67506a334cc34a49d +0 -0
  631. data/test/fixtures/unsymlinked.git/objects/80/6999882bf91d24241e4077906b9017605eb1f3 +0 -0
  632. data/test/fixtures/unsymlinked.git/objects/83/7d176303c5005505ec1e4a30231c40930c0230 +0 -0
  633. data/test/fixtures/unsymlinked.git/objects/a8/595ccca04f40818ae0155c8f9c77a230e597b6 +0 -2
  634. data/test/fixtures/unsymlinked.git/objects/cf/8f1cf5cce859c438d6cc067284cb5e161206e7 +0 -0
  635. data/test/fixtures/unsymlinked.git/objects/d5/278d05c8607ec420bfee4cf219fbc0eeebfd6a +0 -0
  636. data/test/fixtures/unsymlinked.git/objects/f4/e16fb76536591a41454194058d048d8e4dd2e9 +0 -0
  637. data/test/fixtures/unsymlinked.git/objects/f9/e65619d93fdf2673882e0a261c5e93b1a84006 +0 -0
  638. data/test/fixtures/unsymlinked.git/refs/heads/exe-file +0 -1
  639. data/test/fixtures/unsymlinked.git/refs/heads/master +0 -1
  640. data/test/fixtures/unsymlinked.git/refs/heads/reg-file +0 -1
  641. data/test/index_test.rb +0 -333
  642. data/test/lib_test.rb +0 -127
  643. data/test/note_test.rb +0 -158
  644. data/test/object_test.rb +0 -43
  645. data/test/reference_test.rb +0 -207
  646. data/test/remote_test.rb +0 -324
  647. data/test/repo_pack_test.rb +0 -24
  648. data/test/repo_reset_test.rb +0 -82
  649. data/test/repo_test.rb +0 -402
  650. data/test/tag_test.rb +0 -68
  651. data/test/test_helper.rb +0 -92
  652. data/test/tree_test.rb +0 -91
  653. data/test/walker_test.rb +0 -88
  654. data/vendor/libgit2/Makefile.embed +0 -42
  655. data/vendor/libgit2/include/git2/push.h +0 -131
  656. data/vendor/libgit2/include/git2/threads.h +0 -50
  657. data/vendor/libgit2/src/amiga/map.c +0 -48
  658. data/vendor/libgit2/src/bswap.h +0 -97
  659. data/vendor/libgit2/src/compress.c +0 -53
  660. data/vendor/libgit2/src/config_file.h +0 -60
  661. data/vendor/libgit2/src/delta-apply.c +0 -134
  662. data/vendor/libgit2/src/delta-apply.h +0 -50
  663. data/vendor/libgit2/src/diff_patch.c +0 -995
  664. data/vendor/libgit2/src/diff_patch.h +0 -46
  665. data/vendor/libgit2/src/hashsig.h +0 -72
  666. data/vendor/libgit2/src/merge_file.h +0 -71
  667. data/vendor/libgit2/src/win32/pthread.c +0 -144
  668. data/vendor/libgit2/src/win32/pthread.h +0 -50
@@ -14,6 +14,8 @@
14
14
  #include "indexer.h"
15
15
  #include "strarray.h"
16
16
  #include "transport.h"
17
+ #include "pack.h"
18
+ #include "proxy.h"
17
19
 
18
20
  /**
19
21
  * @file git2/remote.h
@@ -24,18 +26,8 @@
24
26
  */
25
27
  GIT_BEGIN_DECL
26
28
 
27
- typedef int (*git_remote_rename_problem_cb)(const char *problematic_refspec, void *payload);
28
- /*
29
- * TODO: This functions still need to be implemented:
30
- * - _listcb/_foreach
31
- * - _add
32
- * - _rename
33
- * - _del (needs support from config)
34
- */
35
-
36
29
  /**
37
- * Add a remote with the default fetch refspec to the repository's configuration. This
38
- * calls git_remote_save before returning.
30
+ * Add a remote with the default fetch refspec to the repository's configuration.
39
31
  *
40
32
  * @param out the resulting remote
41
33
  * @param repo the repository in which to create the remote
@@ -50,25 +42,129 @@ GIT_EXTERN(int) git_remote_create(
50
42
  const char *url);
51
43
 
52
44
  /**
53
- * Create a remote in memory
45
+ * Remote creation options flags
46
+ */
47
+ typedef enum {
48
+ /** Ignore the repository apply.insteadOf configuration */
49
+ GIT_REMOTE_CREATE_SKIP_INSTEADOF = (1 << 0),
50
+
51
+ /** Don't build a fetchspec from the name if none is set */
52
+ GIT_REMOTE_CREATE_SKIP_DEFAULT_FETCHSPEC = (1 << 1),
53
+ } git_remote_create_flags;
54
+
55
+ /**
56
+ * Remote creation options structure
54
57
  *
55
- * Create a remote with the given refspec in memory. You can use
56
- * this when you have a URL instead of a remote's name. Note that in-memory
57
- * remotes cannot be converted to persisted remotes.
58
+ * Initialize with `GIT_REMOTE_CREATE_OPTIONS_INIT`. Alternatively, you can
59
+ * use `git_remote_create_init_options`.
58
60
  *
59
- * The name, when provided, will be checked for validity.
60
- * See `git_tag_create()` for rules about valid names.
61
+ */
62
+ typedef struct git_remote_create_options {
63
+ unsigned int version;
64
+
65
+ /**
66
+ * The repository that should own the remote.
67
+ * Setting this to NULL results in a detached remote.
68
+ */
69
+ git_repository *repository;
70
+
71
+ /**
72
+ * The remote's name.
73
+ * Setting this to NULL results in an in-memory/anonymous remote.
74
+ */
75
+ const char *name;
76
+
77
+ /** The fetchspec the remote should use. */
78
+ const char *fetchspec;
79
+
80
+ /** Additional flags for the remote. See git_remote_create_flags. */
81
+ unsigned int flags;
82
+ } git_remote_create_options;
83
+
84
+ #define GIT_REMOTE_CREATE_OPTIONS_VERSION 1
85
+ #define GIT_REMOTE_CREATE_OPTIONS_INIT {GIT_REMOTE_CREATE_OPTIONS_VERSION}
86
+
87
+ /**
88
+ * Initialize git_remote_create_options structure
61
89
  *
62
- * @param out pointer to the new remote object
90
+ * Initializes a `git_remote_create_options` with default values. Equivalent to
91
+ * creating an instance with `GIT_REMOTE_CREATE_OPTIONS_INIT`.
92
+ *
93
+ * @param opts The `git_remote_create_options` struct to initialize.
94
+ * @param version The struct version; pass `GIT_REMOTE_CREATE_OPTIONS_VERSION`.
95
+ * @return Zero on success; -1 on failure.
96
+ */
97
+ GIT_EXTERN(int) git_remote_create_init_options(
98
+ git_remote_create_options *opts,
99
+ unsigned int version);
100
+
101
+ /**
102
+ * Create a remote, with options.
103
+ *
104
+ * This function allows more fine-grained control over the remote creation.
105
+ *
106
+ * Passing NULL as the opts argument will result in a detached remote.
107
+ *
108
+ * @param out the resulting remote
109
+ * @param url the remote's url
110
+ * @param opts the remote creation options
111
+ * @return 0, GIT_EINVALIDSPEC, GIT_EEXISTS or an error code
112
+ */
113
+ GIT_EXTERN(int) git_remote_create_with_opts(
114
+ git_remote **out,
115
+ const char *url,
116
+ const git_remote_create_options *opts);
117
+
118
+ /**
119
+ * Add a remote with the provided fetch refspec (or default if NULL) to the repository's
120
+ * configuration.
121
+ *
122
+ * @param out the resulting remote
123
+ * @param repo the repository in which to create the remote
124
+ * @param name the remote's name
125
+ * @param url the remote's url
126
+ * @param fetch the remote fetch value
127
+ * @return 0, GIT_EINVALIDSPEC, GIT_EEXISTS or an error code
128
+ */
129
+ GIT_EXTERN(int) git_remote_create_with_fetchspec(
130
+ git_remote **out,
131
+ git_repository *repo,
132
+ const char *name,
133
+ const char *url,
134
+ const char *fetch);
135
+
136
+ /**
137
+ * Create an anonymous remote
138
+ *
139
+ * Create a remote with the given url in-memory. You can use this when
140
+ * you have a URL instead of a remote's name.
141
+ *
142
+ * @param out pointer to the new remote objects
63
143
  * @param repo the associated repository
64
- * @param fetch the fetch refspec to use for this remote. May be NULL for defaults.
65
144
  * @param url the remote repository's URL
66
145
  * @return 0 or an error code
67
146
  */
68
- GIT_EXTERN(int) git_remote_create_inmemory(
147
+ GIT_EXTERN(int) git_remote_create_anonymous(
69
148
  git_remote **out,
70
149
  git_repository *repo,
71
- const char *fetch,
150
+ const char *url);
151
+
152
+ /**
153
+ * Create a remote without a connected local repo
154
+ *
155
+ * Create a remote with the given url in-memory. You can use this when
156
+ * you have a URL instead of a remote's name.
157
+ *
158
+ * Contrasted with git_remote_create_anonymous, a detached remote
159
+ * will not consider any repo configuration values (such as insteadof url
160
+ * substitutions).
161
+ *
162
+ * @param out pointer to the new remote objects
163
+ * @param url the remote repository's URL
164
+ * @return 0 or an error code
165
+ */
166
+ GIT_EXTERN(int) git_remote_create_detached(
167
+ git_remote **out,
72
168
  const char *url);
73
169
 
74
170
  /**
@@ -82,18 +178,27 @@ GIT_EXTERN(int) git_remote_create_inmemory(
82
178
  * @param name the remote's name
83
179
  * @return 0, GIT_ENOTFOUND, GIT_EINVALIDSPEC or an error code
84
180
  */
85
- GIT_EXTERN(int) git_remote_load(git_remote **out, git_repository *repo, const char *name);
181
+ GIT_EXTERN(int) git_remote_lookup(git_remote **out, git_repository *repo, const char *name);
86
182
 
87
183
  /**
88
- * Save a remote to its repository's configuration
184
+ * Create a copy of an existing remote. All internal strings are also
185
+ * duplicated. Callbacks are not duplicated.
89
186
  *
90
- * One can't save a in-memory remote. Doing so will
91
- * result in a GIT_EINVALIDSPEC being returned.
187
+ * Call `git_remote_free` to free the data.
92
188
  *
93
- * @param remote the remote to save to config
94
- * @return 0, GIT_EINVALIDSPEC or an error code
189
+ * @param dest pointer where to store the copy
190
+ * @param source object to copy
191
+ * @return 0 or an error code
192
+ */
193
+ GIT_EXTERN(int) git_remote_dup(git_remote **dest, git_remote *source);
194
+
195
+ /**
196
+ * Get the remote's repository
197
+ *
198
+ * @param remote the remote
199
+ * @return a pointer to the repository
95
200
  */
96
- GIT_EXTERN(int) git_remote_save(const git_remote *remote);
201
+ GIT_EXTERN(git_repository *) git_remote_owner(const git_remote *remote);
97
202
 
98
203
  /**
99
204
  * Get the remote's name
@@ -106,6 +211,9 @@ GIT_EXTERN(const char *) git_remote_name(const git_remote *remote);
106
211
  /**
107
212
  * Get the remote's url
108
213
  *
214
+ * If url.*.insteadOf has been configured for this URL, it will
215
+ * return the modified URL.
216
+ *
109
217
  * @param remote the remote
110
218
  * @return a pointer to the url
111
219
  */
@@ -114,41 +222,52 @@ GIT_EXTERN(const char *) git_remote_url(const git_remote *remote);
114
222
  /**
115
223
  * Get the remote's url for pushing
116
224
  *
225
+ * If url.*.pushInsteadOf has been configured for this URL, it
226
+ * will return the modified URL.
227
+ *
117
228
  * @param remote the remote
118
229
  * @return a pointer to the url or NULL if no special url for pushing is set
119
230
  */
120
231
  GIT_EXTERN(const char *) git_remote_pushurl(const git_remote *remote);
121
232
 
122
233
  /**
123
- * Set the remote's url
234
+ * Set the remote's url in the configuration
124
235
  *
125
- * Existing connections will not be updated.
236
+ * Remote objects already in memory will not be affected. This assumes
237
+ * the common case of a single-url remote and will otherwise return an error.
126
238
  *
127
- * @param remote the remote
239
+ * @param repo the repository in which to perform the change
240
+ * @param remote the remote's name
128
241
  * @param url the url to set
129
242
  * @return 0 or an error value
130
243
  */
131
- GIT_EXTERN(int) git_remote_set_url(git_remote *remote, const char* url);
244
+ GIT_EXTERN(int) git_remote_set_url(git_repository *repo, const char *remote, const char* url);
132
245
 
133
246
  /**
134
- * Set the remote's url for pushing
247
+ * Set the remote's url for pushing in the configuration.
135
248
  *
136
- * Existing connections will not be updated.
249
+ * Remote objects already in memory will not be affected. This assumes
250
+ * the common case of a single-url remote and will otherwise return an error.
137
251
  *
138
- * @param remote the remote
139
- * @param url the url to set or NULL to clear the pushurl
140
- * @return 0 or an error value
252
+ *
253
+ * @param repo the repository in which to perform the change
254
+ * @param remote the remote's name
255
+ * @param url the url to set
141
256
  */
142
- GIT_EXTERN(int) git_remote_set_pushurl(git_remote *remote, const char* url);
257
+ GIT_EXTERN(int) git_remote_set_pushurl(git_repository *repo, const char *remote, const char* url);
143
258
 
144
259
  /**
145
- * Add a fetch refspec to the remote
260
+ * Add a fetch refspec to the remote's configuration
146
261
  *
147
- * @param remote the remote
148
- * @apram refspec the new fetch refspec
149
- * @return 0 or an error value
262
+ * Add the given refspec to the fetch list in the configuration. No
263
+ * loaded remote instances will be affected.
264
+ *
265
+ * @param repo the repository in which to change the configuration
266
+ * @param remote the name of the remote to change
267
+ * @param refspec the new fetch refspec
268
+ * @return 0, GIT_EINVALIDSPEC if refspec is invalid or an error value
150
269
  */
151
- GIT_EXTERN(int) git_remote_add_fetch(git_remote *remote, const char *refspec);
270
+ GIT_EXTERN(int) git_remote_add_fetch(git_repository *repo, const char *remote, const char *refspec);
152
271
 
153
272
  /**
154
273
  * Get the remote's list of fetch refspecs
@@ -159,16 +278,20 @@ GIT_EXTERN(int) git_remote_add_fetch(git_remote *remote, const char *refspec);
159
278
  * @param array pointer to the array in which to store the strings
160
279
  * @param remote the remote to query
161
280
  */
162
- GIT_EXTERN(int) git_remote_get_fetch_refspecs(git_strarray *array, git_remote *remote);
281
+ GIT_EXTERN(int) git_remote_get_fetch_refspecs(git_strarray *array, const git_remote *remote);
163
282
 
164
283
  /**
165
- * Add a push refspec to the remote
284
+ * Add a push refspec to the remote's configuration
166
285
  *
167
- * @param remote the remote
286
+ * Add the given refspec to the push list in the configuration. No
287
+ * loaded remote instances will be affected.
288
+ *
289
+ * @param repo the repository in which to change the configuration
290
+ * @param remote the name of the remote to change
168
291
  * @param refspec the new push refspec
169
- * @return 0 or an error value
292
+ * @return 0, GIT_EINVALIDSPEC if refspec is invalid or an error value
170
293
  */
171
- GIT_EXTERN(int) git_remote_add_push(git_remote *remote, const char *refspec);
294
+ GIT_EXTERN(int) git_remote_add_push(git_repository *repo, const char *remote, const char *refspec);
172
295
 
173
296
  /**
174
297
  * Get the remote's list of push refspecs
@@ -179,16 +302,7 @@ GIT_EXTERN(int) git_remote_add_push(git_remote *remote, const char *refspec);
179
302
  * @param array pointer to the array in which to store the strings
180
303
  * @param remote the remote to query
181
304
  */
182
- GIT_EXTERN(int) git_remote_get_push_refspecs(git_strarray *array, git_remote *remote);
183
-
184
- /**
185
- * Clear the refspecs
186
- *
187
- * Remove all configured fetch and push refspecs from the remote.
188
- *
189
- * @param remote the remote
190
- */
191
- GIT_EXTERN(void) git_remote_clear_refspecs(git_remote *remote);
305
+ GIT_EXTERN(int) git_remote_get_push_refspecs(git_strarray *array, const git_remote *remote);
192
306
 
193
307
  /**
194
308
  * Get the number of refspecs for a remote
@@ -196,7 +310,7 @@ GIT_EXTERN(void) git_remote_clear_refspecs(git_remote *remote);
196
310
  * @param remote the remote
197
311
  * @return the amount of refspecs configured in this remote
198
312
  */
199
- GIT_EXTERN(size_t) git_remote_refspec_count(git_remote *remote);
313
+ GIT_EXTERN(size_t) git_remote_refspec_count(const git_remote *remote);
200
314
 
201
315
  /**
202
316
  * Get a refspec from the remote
@@ -205,16 +319,7 @@ GIT_EXTERN(size_t) git_remote_refspec_count(git_remote *remote);
205
319
  * @param n the refspec to get
206
320
  * @return the nth refspec
207
321
  */
208
- GIT_EXTERN(const git_refspec *)git_remote_get_refspec(git_remote *remote, size_t n);
209
-
210
- /**
211
- * Remove a refspec from the remote
212
- *
213
- * @param remote the remote to query
214
- * @param n the refspec to remove
215
- * @return 0 or GIT_ENOTFOUND
216
- */
217
- GIT_EXTERN(int) git_remote_remove_refspec(git_remote *remote, size_t n);
322
+ GIT_EXTERN(const git_refspec *)git_remote_get_refspec(const git_remote *remote, size_t n);
218
323
 
219
324
  /**
220
325
  * Open a connection to a remote
@@ -226,46 +331,34 @@ GIT_EXTERN(int) git_remote_remove_refspec(git_remote *remote, size_t n);
226
331
  * @param remote the remote to connect to
227
332
  * @param direction GIT_DIRECTION_FETCH if you want to fetch or
228
333
  * GIT_DIRECTION_PUSH if you want to push
334
+ * @param callbacks the callbacks to use for this connection
335
+ * @param proxy_opts proxy settings
336
+ * @param custom_headers extra HTTP headers to use in this connection
229
337
  * @return 0 or an error code
230
338
  */
231
- GIT_EXTERN(int) git_remote_connect(git_remote *remote, git_direction direction);
339
+ GIT_EXTERN(int) git_remote_connect(git_remote *remote, git_direction direction, const git_remote_callbacks *callbacks, const git_proxy_options *proxy_opts, const git_strarray *custom_headers);
232
340
 
233
341
  /**
234
- * Get a list of refs at the remote
342
+ * Get the remote repository's reference advertisement list
235
343
  *
236
- * The remote (or more exactly its transport) must be connected. The
237
- * memory belongs to the remote.
344
+ * Get the list of references with which the server responds to a new
345
+ * connection.
238
346
  *
239
- * If you a return a non-zero value from the callback, this will stop
240
- * looping over the refs.
347
+ * The remote (or more exactly its transport) must have connected to
348
+ * the remote repository. This list is available as soon as the
349
+ * connection to the remote is initiated and it remains available
350
+ * after disconnecting.
241
351
  *
242
- * @param remote the remote
243
- * @param list_cb function to call with each ref discovered at the remote
244
- * @param payload additional data to pass to the callback
245
- * @return 0 on success, GIT_EUSER on non-zero callback, or error code
246
- */
247
- GIT_EXTERN(int) git_remote_ls(git_remote *remote, git_headlist_cb list_cb, void *payload);
248
-
249
- /**
250
- * Download the packfile
251
- *
252
- * Negotiate what objects should be downloaded and download the
253
- * packfile with those objects. The packfile is downloaded with a
254
- * temporary filename, as it's final name is not known yet. If there
255
- * was no packfile needed (all the objects were available locally),
256
- * filename will be NULL and the function will return success.
352
+ * The memory belongs to the remote. The pointer will be valid as long
353
+ * as a new connection is not initiated, but it is recommended that
354
+ * you make a copy in order to make use of the data.
257
355
  *
258
- * @param remote the remote to download from
259
- * @param progress_cb function to call with progress information. Be aware that
260
- * this is called inline with network and indexing operations, so performance
261
- * may be affected.
262
- * @param payload payload for the progress callback
263
- * @return 0 or an error code
356
+ * @param out pointer to the array
357
+ * @param size the number of remote heads
358
+ * @param remote the remote
359
+ * @return 0 on success, or an error code
264
360
  */
265
- GIT_EXTERN(int) git_remote_download(
266
- git_remote *remote,
267
- git_transfer_progress_callback progress_cb,
268
- void *payload);
361
+ GIT_EXTERN(int) git_remote_ls(const git_remote_head ***out, size_t *size, git_remote *remote);
269
362
 
270
363
  /**
271
364
  * Check whether the remote is connected
@@ -276,7 +369,7 @@ GIT_EXTERN(int) git_remote_download(
276
369
  * @param remote the remote
277
370
  * @return 1 if it's connected, 0 otherwise.
278
371
  */
279
- GIT_EXTERN(int) git_remote_connected(git_remote *remote);
372
+ GIT_EXTERN(int) git_remote_connected(const git_remote *remote);
280
373
 
281
374
  /**
282
375
  * Cancel the operation
@@ -291,8 +384,7 @@ GIT_EXTERN(void) git_remote_stop(git_remote *remote);
291
384
  /**
292
385
  * Disconnect from the remote
293
386
  *
294
- * Close the connection to the remote and free the underlying
295
- * transport.
387
+ * Close the connection to the remote.
296
388
  *
297
389
  * @param remote the remote to disconnect from
298
390
  */
@@ -309,145 +401,465 @@ GIT_EXTERN(void) git_remote_disconnect(git_remote *remote);
309
401
  GIT_EXTERN(void) git_remote_free(git_remote *remote);
310
402
 
311
403
  /**
312
- * Update the tips to the new state
404
+ * Get a list of the configured remotes for a repo
313
405
  *
314
- * @param remote the remote to update
406
+ * The string array must be freed by the user.
407
+ *
408
+ * @param out a string array which receives the names of the remotes
409
+ * @param repo the repository to query
315
410
  * @return 0 or an error code
316
411
  */
317
- GIT_EXTERN(int) git_remote_update_tips(git_remote *remote);
412
+ GIT_EXTERN(int) git_remote_list(git_strarray *out, git_repository *repo);
318
413
 
319
414
  /**
320
- * Return whether a string is a valid remote URL
321
- *
322
- * @param url the url to check
323
- * @return 1 if the url is valid, 0 otherwise
415
+ * Argument to the completion callback which tells it which operation
416
+ * finished.
417
+ */
418
+ typedef enum git_remote_completion_type {
419
+ GIT_REMOTE_COMPLETION_DOWNLOAD,
420
+ GIT_REMOTE_COMPLETION_INDEXING,
421
+ GIT_REMOTE_COMPLETION_ERROR,
422
+ } git_remote_completion_type;
423
+
424
+ /** Push network progress notification function */
425
+ typedef int GIT_CALLBACK(git_push_transfer_progress)(
426
+ unsigned int current,
427
+ unsigned int total,
428
+ size_t bytes,
429
+ void* payload);
430
+ /**
431
+ * Represents an update which will be performed on the remote during push
324
432
  */
325
- GIT_EXTERN(int) git_remote_valid_url(const char *url);
433
+ typedef struct {
434
+ /**
435
+ * The source name of the reference
436
+ */
437
+ char *src_refname;
438
+ /**
439
+ * The name of the reference to update on the server
440
+ */
441
+ char *dst_refname;
442
+ /**
443
+ * The current target of the reference
444
+ */
445
+ git_oid src;
446
+ /**
447
+ * The new target for the reference
448
+ */
449
+ git_oid dst;
450
+ } git_push_update;
326
451
 
327
452
  /**
328
- * Return whether the passed URL is supported by this version of the library.
453
+ * Callback used to inform of upcoming updates.
329
454
  *
330
- * @param url the url to check
331
- * @return 1 if the url is supported, 0 otherwise
332
- */
333
- GIT_EXTERN(int) git_remote_supported_url(const char* url);
455
+ * @param updates an array containing the updates which will be sent
456
+ * as commands to the destination.
457
+ * @param len number of elements in `updates`
458
+ * @param payload Payload provided by the caller
459
+ */
460
+ typedef int GIT_CALLBACK(git_push_negotiation)(const git_push_update **updates, size_t len, void *payload);
334
461
 
335
462
  /**
336
- * Get a list of the configured remotes for a repo
463
+ * Callback used to inform of the update status from the remote.
337
464
  *
338
- * The string array must be freed by the user.
465
+ * Called for each updated reference on push. If `status` is
466
+ * not `NULL`, the update was rejected by the remote server
467
+ * and `status` contains the reason given.
339
468
  *
340
- * @param out a string array which receives the names of the remotes
341
- * @param repo the repository to query
342
- * @return 0 or an error code
469
+ * @param refname refname specifying to the remote ref
470
+ * @param status status message sent from the remote
471
+ * @param data data provided by the caller
472
+ * @return 0 on success, otherwise an error
343
473
  */
344
- GIT_EXTERN(int) git_remote_list(git_strarray *out, git_repository *repo);
474
+ typedef int GIT_CALLBACK(git_push_update_reference_cb)(const char *refname, const char *status, void *data);
345
475
 
346
476
  /**
347
- * Choose whether to check the server's certificate (applies to HTTPS only)
477
+ * The callback settings structure
348
478
  *
349
- * @param remote the remote to configure
350
- * @param check whether to check the server's certificate (defaults to yes)
479
+ * Set the callbacks to be called by the remote when informing the user
480
+ * about the progress of the network operations.
351
481
  */
352
- GIT_EXTERN(void) git_remote_check_cert(git_remote *remote, int check);
482
+ struct git_remote_callbacks {
483
+ unsigned int version;
484
+ /**
485
+ * Textual progress from the remote. Text send over the
486
+ * progress side-band will be passed to this function (this is
487
+ * the 'counting objects' output).
488
+ */
489
+ git_transport_message_cb sideband_progress;
490
+
491
+ /**
492
+ * Completion is called when different parts of the download
493
+ * process are done (currently unused).
494
+ */
495
+ int GIT_CALLBACK(completion)(git_remote_completion_type type, void *data);
496
+
497
+ /**
498
+ * This will be called if the remote host requires
499
+ * authentication in order to connect to it.
500
+ *
501
+ * Returning GIT_PASSTHROUGH will make libgit2 behave as
502
+ * though this field isn't set.
503
+ */
504
+ git_cred_acquire_cb credentials;
505
+
506
+ /**
507
+ * If cert verification fails, this will be called to let the
508
+ * user make the final decision of whether to allow the
509
+ * connection to proceed. Returns 0 to allow the connection
510
+ * or a negative value to indicate an error.
511
+ */
512
+ git_transport_certificate_check_cb certificate_check;
513
+
514
+ /**
515
+ * During the download of new data, this will be regularly
516
+ * called with the current count of progress done by the
517
+ * indexer.
518
+ */
519
+ git_transfer_progress_cb transfer_progress;
520
+
521
+ /**
522
+ * Each time a reference is updated locally, this function
523
+ * will be called with information about it.
524
+ */
525
+ int GIT_CALLBACK(update_tips)(const char *refname, const git_oid *a, const git_oid *b, void *data);
526
+
527
+ /**
528
+ * Function to call with progress information during pack
529
+ * building. Be aware that this is called inline with pack
530
+ * building operations, so performance may be affected.
531
+ */
532
+ git_packbuilder_progress pack_progress;
533
+
534
+ /**
535
+ * Function to call with progress information during the
536
+ * upload portion of a push. Be aware that this is called
537
+ * inline with pack building operations, so performance may be
538
+ * affected.
539
+ */
540
+ git_push_transfer_progress push_transfer_progress;
541
+
542
+ /**
543
+ * See documentation of git_push_update_reference_cb
544
+ */
545
+ git_push_update_reference_cb push_update_reference;
546
+
547
+ /**
548
+ * Called once between the negotiation step and the upload. It
549
+ * provides information about what updates will be performed.
550
+ */
551
+ git_push_negotiation push_negotiation;
552
+
553
+ /**
554
+ * Create the transport to use for this operation. Leave NULL
555
+ * to auto-detect.
556
+ */
557
+ git_transport_cb transport;
558
+
559
+ /**
560
+ * This will be passed to each of the callbacks in this struct
561
+ * as the last parameter.
562
+ */
563
+ void *payload;
564
+ };
565
+
566
+ #define GIT_REMOTE_CALLBACKS_VERSION 1
567
+ #define GIT_REMOTE_CALLBACKS_INIT {GIT_REMOTE_CALLBACKS_VERSION}
353
568
 
354
569
  /**
355
- * Set a credentials acquisition callback for this remote. If the remote is
356
- * not available for anonymous access, then you must set this callback in order
357
- * to provide credentials to the transport at the time of authentication
358
- * failure so that retry can be performed.
570
+ * Initializes a `git_remote_callbacks` with default values. Equivalent to
571
+ * creating an instance with GIT_REMOTE_CALLBACKS_INIT.
359
572
  *
360
- * @param remote the remote to configure
361
- * @param cred_acquire_cb The credentials acquisition callback to use (defaults
362
- * to NULL)
573
+ * @param opts the `git_remote_callbacks` struct to initialize
574
+ * @param version Version of struct; pass `GIT_REMOTE_CALLBACKS_VERSION`
575
+ * @return Zero on success; -1 on failure.
363
576
  */
364
- GIT_EXTERN(void) git_remote_set_cred_acquire_cb(
365
- git_remote *remote,
366
- git_cred_acquire_cb cred_acquire_cb,
367
- void *payload);
577
+ GIT_EXTERN(int) git_remote_init_callbacks(
578
+ git_remote_callbacks *opts,
579
+ unsigned int version);
580
+
581
+ typedef enum {
582
+ /**
583
+ * Use the setting from the configuration
584
+ */
585
+ GIT_FETCH_PRUNE_UNSPECIFIED,
586
+ /**
587
+ * Force pruning on
588
+ */
589
+ GIT_FETCH_PRUNE,
590
+ /**
591
+ * Force pruning off
592
+ */
593
+ GIT_FETCH_NO_PRUNE,
594
+ } git_fetch_prune_t;
368
595
 
369
596
  /**
370
- * Sets a custom transport for the remote. The caller can use this function
371
- * to bypass the automatic discovery of a transport by URL scheme (i.e.
372
- * http://, https://, git://) and supply their own transport to be used
373
- * instead. After providing the transport to a remote using this function,
374
- * the transport object belongs exclusively to that remote, and the remote will
375
- * free it when it is freed with git_remote_free.
597
+ * Automatic tag following option
376
598
  *
377
- * @param remote the remote to configure
378
- * @param transport the transport object for the remote to use
379
- * @return 0 or an error code
599
+ * Lets us select the --tags option to use.
380
600
  */
381
- GIT_EXTERN(int) git_remote_set_transport(
382
- git_remote *remote,
383
- git_transport *transport);
601
+ typedef enum {
602
+ /**
603
+ * Use the setting from the configuration.
604
+ */
605
+ GIT_REMOTE_DOWNLOAD_TAGS_UNSPECIFIED = 0,
606
+ /**
607
+ * Ask the server for tags pointing to objects we're already
608
+ * downloading.
609
+ */
610
+ GIT_REMOTE_DOWNLOAD_TAGS_AUTO,
611
+ /**
612
+ * Don't ask for any tags beyond the refspecs.
613
+ */
614
+ GIT_REMOTE_DOWNLOAD_TAGS_NONE,
615
+ /**
616
+ * Ask for the all the tags.
617
+ */
618
+ GIT_REMOTE_DOWNLOAD_TAGS_ALL,
619
+ } git_remote_autotag_option_t;
384
620
 
385
621
  /**
386
- * Argument to the completion callback which tells it which operation
387
- * finished.
622
+ * Fetch options structure.
623
+ *
624
+ * Zero out for defaults. Initialize with `GIT_FETCH_OPTIONS_INIT` macro to
625
+ * correctly set the `version` field. E.g.
626
+ *
627
+ * git_fetch_options opts = GIT_FETCH_OPTIONS_INIT;
388
628
  */
389
- typedef enum git_remote_completion_type {
390
- GIT_REMOTE_COMPLETION_DOWNLOAD,
391
- GIT_REMOTE_COMPLETION_INDEXING,
392
- GIT_REMOTE_COMPLETION_ERROR,
393
- } git_remote_completion_type;
629
+ typedef struct {
630
+ int version;
631
+
632
+ /**
633
+ * Callbacks to use for this fetch operation
634
+ */
635
+ git_remote_callbacks callbacks;
636
+
637
+ /**
638
+ * Whether to perform a prune after the fetch
639
+ */
640
+ git_fetch_prune_t prune;
641
+
642
+ /**
643
+ * Whether to write the results to FETCH_HEAD. Defaults to
644
+ * on. Leave this default in order to behave like git.
645
+ */
646
+ int update_fetchhead;
647
+
648
+ /**
649
+ * Determines how to behave regarding tags on the remote, such
650
+ * as auto-downloading tags for objects we're downloading or
651
+ * downloading all of them.
652
+ *
653
+ * The default is to auto-follow tags.
654
+ */
655
+ git_remote_autotag_option_t download_tags;
656
+
657
+ /**
658
+ * Proxy options to use, by default no proxy is used.
659
+ */
660
+ git_proxy_options proxy_opts;
661
+
662
+ /**
663
+ * Extra headers for this fetch operation
664
+ */
665
+ git_strarray custom_headers;
666
+ } git_fetch_options;
667
+
668
+ #define GIT_FETCH_OPTIONS_VERSION 1
669
+ #define GIT_FETCH_OPTIONS_INIT { GIT_FETCH_OPTIONS_VERSION, GIT_REMOTE_CALLBACKS_INIT, GIT_FETCH_PRUNE_UNSPECIFIED, 1, \
670
+ GIT_REMOTE_DOWNLOAD_TAGS_UNSPECIFIED, GIT_PROXY_OPTIONS_INIT }
394
671
 
395
672
  /**
396
- * The callback settings structure
673
+ * Initialize git_fetch_options structure
397
674
  *
398
- * Set the calbacks to be called by the remote.
675
+ * Initializes a `git_fetch_options` with default values. Equivalent to
676
+ * creating an instance with `GIT_FETCH_OPTIONS_INIT`.
677
+ *
678
+ * @param opts The `git_fetch_options` struct to initialize.
679
+ * @param version The struct version; pass `GIT_FETCH_OPTIONS_VERSION`.
680
+ * @return Zero on success; -1 on failure.
399
681
  */
400
- struct git_remote_callbacks {
682
+ GIT_EXTERN(int) git_fetch_init_options(
683
+ git_fetch_options *opts,
684
+ unsigned int version);
685
+
686
+
687
+ /**
688
+ * Controls the behavior of a git_push object.
689
+ */
690
+ typedef struct {
401
691
  unsigned int version;
402
- void (*progress)(const char *str, int len, void *data);
403
- int (*completion)(git_remote_completion_type type, void *data);
404
- int (*update_tips)(const char *refname, const git_oid *a, const git_oid *b, void *data);
405
- void *payload;
406
- };
407
692
 
408
- #define GIT_REMOTE_CALLBACKS_VERSION 1
409
- #define GIT_REMOTE_CALLBACKS_INIT {GIT_REMOTE_CALLBACKS_VERSION}
693
+ /**
694
+ * If the transport being used to push to the remote requires the creation
695
+ * of a pack file, this controls the number of worker threads used by
696
+ * the packbuilder when creating that pack file to be sent to the remote.
697
+ *
698
+ * If set to 0, the packbuilder will auto-detect the number of threads
699
+ * to create. The default value is 1.
700
+ */
701
+ unsigned int pb_parallelism;
702
+
703
+ /**
704
+ * Callbacks to use for this push operation
705
+ */
706
+ git_remote_callbacks callbacks;
707
+
708
+ /**
709
+ * Proxy options to use, by default no proxy is used.
710
+ */
711
+ git_proxy_options proxy_opts;
712
+
713
+ /**
714
+ * Extra headers for this push operation
715
+ */
716
+ git_strarray custom_headers;
717
+ } git_push_options;
718
+
719
+ #define GIT_PUSH_OPTIONS_VERSION 1
720
+ #define GIT_PUSH_OPTIONS_INIT { GIT_PUSH_OPTIONS_VERSION, 1, GIT_REMOTE_CALLBACKS_INIT, GIT_PROXY_OPTIONS_INIT }
721
+
722
+ /**
723
+ * Initialize git_push_options structure
724
+ *
725
+ * Initializes a `git_push_options` with default values. Equivalent to
726
+ * creating an instance with `GIT_PUSH_OPTIONS_INIT`.
727
+ *
728
+ * @param opts The `git_push_options` struct to initialize.
729
+ * @param version The struct version; pass `GIT_PUSH_OPTIONS_VERSION`.
730
+ * @return Zero on success; -1 on failure.
731
+ */
732
+ GIT_EXTERN(int) git_push_init_options(
733
+ git_push_options *opts,
734
+ unsigned int version);
410
735
 
411
736
  /**
412
- * Set the callbacks for a remote
737
+ * Download and index the packfile
413
738
  *
414
- * Note that the remote keeps its own copy of the data and you need to
415
- * call this function again if you want to change the callbacks.
739
+ * Connect to the remote if it hasn't been done yet, negotiate with
740
+ * the remote git which objects are missing, download and index the
741
+ * packfile.
416
742
  *
417
- * @param remote the remote to configure
418
- * @param callbacks a pointer to the user's callback settings
743
+ * The .idx file will be created and both it and the packfile with be
744
+ * renamed to their final name.
745
+ *
746
+ * @param remote the remote
747
+ * @param refspecs the refspecs to use for this negotiation and
748
+ * download. Use NULL or an empty array to use the base refspecs
749
+ * @param opts the options to use for this fetch
750
+ * @return 0 or an error code
751
+ */
752
+ GIT_EXTERN(int) git_remote_download(git_remote *remote, const git_strarray *refspecs, const git_fetch_options *opts);
753
+
754
+ /**
755
+ * Create a packfile and send it to the server
756
+ *
757
+ * Connect to the remote if it hasn't been done yet, negotiate with
758
+ * the remote git which objects are missing, create a packfile with the missing objects and send it.
759
+ *
760
+ * @param remote the remote
761
+ * @param refspecs the refspecs to use for this negotiation and
762
+ * upload. Use NULL or an empty array to use the base refspecs
763
+ * @param opts the options to use for this push
764
+ * @return 0 or an error code
765
+ */
766
+ GIT_EXTERN(int) git_remote_upload(git_remote *remote, const git_strarray *refspecs, const git_push_options *opts);
767
+
768
+ /**
769
+ * Update the tips to the new state
770
+ *
771
+ * @param remote the remote to update
772
+ * @param reflog_message The message to insert into the reflogs. If
773
+ * NULL and fetching, the default is "fetch <name>", where <name> is
774
+ * the name of the remote (or its url, for in-memory remotes). This
775
+ * parameter is ignored when pushing.
776
+ * @param callbacks pointer to the callback structure to use
777
+ * @param update_fetchhead whether to write to FETCH_HEAD. Pass 1 to behave like git.
778
+ * @param download_tags what the behaviour for downloading tags is for this fetch. This is
779
+ * ignored for push. This must be the same value passed to `git_remote_download()`.
780
+ * @return 0 or an error code
781
+ */
782
+ GIT_EXTERN(int) git_remote_update_tips(
783
+ git_remote *remote,
784
+ const git_remote_callbacks *callbacks,
785
+ int update_fetchhead,
786
+ git_remote_autotag_option_t download_tags,
787
+ const char *reflog_message);
788
+
789
+ /**
790
+ * Download new data and update tips
791
+ *
792
+ * Convenience function to connect to a remote, download the data,
793
+ * disconnect and update the remote-tracking branches.
794
+ *
795
+ * @param remote the remote to fetch from
796
+ * @param refspecs the refspecs to use for this fetch. Pass NULL or an
797
+ * empty array to use the base refspecs.
798
+ * @param opts options to use for this fetch
799
+ * @param reflog_message The message to insert into the reflogs. If NULL, the
800
+ * default is "fetch"
801
+ * @return 0 or an error code
802
+ */
803
+ GIT_EXTERN(int) git_remote_fetch(
804
+ git_remote *remote,
805
+ const git_strarray *refspecs,
806
+ const git_fetch_options *opts,
807
+ const char *reflog_message);
808
+
809
+ /**
810
+ * Prune tracking refs that are no longer present on remote
811
+ *
812
+ * @param remote the remote to prune
813
+ * @param callbacks callbacks to use for this prune
419
814
  * @return 0 or an error code
420
815
  */
421
- GIT_EXTERN(int) git_remote_set_callbacks(git_remote *remote, git_remote_callbacks *callbacks);
816
+ GIT_EXTERN(int) git_remote_prune(git_remote *remote, const git_remote_callbacks *callbacks);
817
+
818
+ /**
819
+ * Perform a push
820
+ *
821
+ * Peform all the steps from a push.
822
+ *
823
+ * @param remote the remote to push to
824
+ * @param refspecs the refspecs to use for pushing. If NULL or an empty
825
+ * array, the configured refspecs will be used
826
+ * @param opts options to use for this push
827
+ */
828
+ GIT_EXTERN(int) git_remote_push(git_remote *remote,
829
+ const git_strarray *refspecs,
830
+ const git_push_options *opts);
422
831
 
423
832
  /**
424
833
  * Get the statistics structure that is filled in by the fetch operation.
425
834
  */
426
835
  GIT_EXTERN(const git_transfer_progress *) git_remote_stats(git_remote *remote);
427
836
 
428
- typedef enum {
429
- GIT_REMOTE_DOWNLOAD_TAGS_AUTO = 0,
430
- GIT_REMOTE_DOWNLOAD_TAGS_NONE = 1,
431
- GIT_REMOTE_DOWNLOAD_TAGS_ALL = 2
432
- } git_remote_autotag_option_t;
433
-
434
837
  /**
435
838
  * Retrieve the tag auto-follow setting
436
839
  *
437
840
  * @param remote the remote to query
438
841
  * @return the auto-follow setting
439
842
  */
440
- GIT_EXTERN(git_remote_autotag_option_t) git_remote_autotag(git_remote *remote);
843
+ GIT_EXTERN(git_remote_autotag_option_t) git_remote_autotag(const git_remote *remote);
441
844
 
442
845
  /**
443
- * Set the tag auto-follow setting
846
+ * Set the remote's tag following setting.
847
+ *
848
+ * The change will be made in the configuration. No loaded remotes
849
+ * will be affected.
444
850
  *
445
- * @param remote the remote to configure
446
- * @param value a GIT_REMOTE_DOWNLOAD_TAGS value
851
+ * @param repo the repository in which to make the change
852
+ * @param remote the name of the remote
853
+ * @param value the new value to take.
447
854
  */
448
- GIT_EXTERN(void) git_remote_set_autotag(
449
- git_remote *remote,
450
- git_remote_autotag_option_t value);
855
+ GIT_EXTERN(int) git_remote_set_autotag(git_repository *repo, const char *remote, git_remote_autotag_option_t value);
856
+ /**
857
+ * Retrieve the ref-prune setting
858
+ *
859
+ * @param remote the remote to query
860
+ * @return the ref-prune setting
861
+ */
862
+ GIT_EXTERN(int) git_remote_prune_refs(const git_remote *remote);
451
863
 
452
864
  /**
453
865
  * Give the remote a new name
@@ -458,45 +870,60 @@ GIT_EXTERN(void) git_remote_set_autotag(
458
870
  * The new name will be checked for validity.
459
871
  * See `git_tag_create()` for rules about valid names.
460
872
  *
461
- * A temporary in-memory remote cannot be given a name with this method.
873
+ * No loaded instances of a the remote with the old name will change
874
+ * their name or their list of refspecs.
462
875
  *
463
- * @param remote the remote to rename
876
+ * @param problems non-default refspecs cannot be renamed and will be
877
+ * stored here for further processing by the caller. Always free this
878
+ * strarray on successful return.
879
+ * @param repo the repository in which to rename
880
+ * @param name the current name of the remote
464
881
  * @param new_name the new name the remote should bear
465
- * @param callback Optional callback to notify the consumer of fetch refspecs
466
- * that haven't been automatically updated and need potential manual tweaking.
467
- * @param payload Additional data to pass to the callback
468
882
  * @return 0, GIT_EINVALIDSPEC, GIT_EEXISTS or an error code
469
883
  */
470
884
  GIT_EXTERN(int) git_remote_rename(
471
- git_remote *remote,
472
- const char *new_name,
473
- git_remote_rename_problem_cb callback,
474
- void *payload);
885
+ git_strarray *problems,
886
+ git_repository *repo,
887
+ const char *name,
888
+ const char *new_name);
475
889
 
476
890
  /**
477
- * Retrieve the update FETCH_HEAD setting.
891
+ * Ensure the remote name is well-formed.
478
892
  *
479
- * @param remote the remote to query
480
- * @return the update FETCH_HEAD setting
893
+ * @param remote_name name to be checked.
894
+ * @return 1 if the reference name is acceptable; 0 if it isn't
481
895
  */
482
- GIT_EXTERN(int) git_remote_update_fetchhead(git_remote *remote);
896
+ GIT_EXTERN(int) git_remote_is_valid_name(const char *remote_name);
483
897
 
484
898
  /**
485
- * Sets the update FETCH_HEAD setting. By default, FETCH_HEAD will be
486
- * updated on every fetch. Set to 0 to disable.
487
- *
488
- * @param remote the remote to configure
489
- * @param value 0 to disable updating FETCH_HEAD
490
- */
491
- GIT_EXTERN(void) git_remote_set_update_fetchhead(git_remote *remote, int value);
899
+ * Delete an existing persisted remote.
900
+ *
901
+ * All remote-tracking branches and configuration settings
902
+ * for the remote will be removed.
903
+ *
904
+ * @param repo the repository in which to act
905
+ * @param name the name of the remote to delete
906
+ * @return 0 on success, or an error code.
907
+ */
908
+ GIT_EXTERN(int) git_remote_delete(git_repository *repo, const char *name);
492
909
 
493
910
  /**
494
- * Ensure the remote name is well-formed.
911
+ * Retrieve the name of the remote's default branch
495
912
  *
496
- * @param remote_name name to be checked.
497
- * @return 1 if the reference name is acceptable; 0 if it isn't
913
+ * The default branch of a repository is the branch which HEAD points
914
+ * to. If the remote does not support reporting this information
915
+ * directly, it performs the guess as git does; that is, if there are
916
+ * multiple branches which point to the same commit, the first one is
917
+ * chosen. If the master branch is a candidate, it wins.
918
+ *
919
+ * This function must only be called after connecting.
920
+ *
921
+ * @param out the buffern in which to store the reference name
922
+ * @param remote the remote
923
+ * @return 0, GIT_ENOTFOUND if the remote does not have any references
924
+ * or none of them point to HEAD's commit, or an error message.
498
925
  */
499
- GIT_EXTERN(int) git_remote_is_valid_name(const char *remote_name);
926
+ GIT_EXTERN(int) git_remote_default_branch(git_buf *out, git_remote *remote);
500
927
 
501
928
  /** @} */
502
929
  GIT_END_DECL