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
@@ -5,28 +5,29 @@
5
5
  * a Linking Exception. For full terms see the included COPYING file.
6
6
  */
7
7
 
8
- #include "common.h"
8
+ #include "revwalk.h"
9
+
9
10
  #include "commit.h"
10
11
  #include "odb.h"
11
12
  #include "pool.h"
12
13
 
13
- #include "revwalk.h"
14
14
  #include "git2/revparse.h"
15
15
  #include "merge.h"
16
+ #include "vector.h"
16
17
 
17
- #include <regex.h>
18
+ static int get_revision(git_commit_list_node **out, git_revwalk *walk, git_commit_list **list);
18
19
 
19
20
  git_commit_list_node *git_revwalk__commit_lookup(
20
21
  git_revwalk *walk, const git_oid *oid)
21
22
  {
22
23
  git_commit_list_node *commit;
23
- khiter_t pos;
24
+ size_t pos;
24
25
  int ret;
25
26
 
26
27
  /* lookup and reserve space if not already present */
27
- pos = kh_get(oid, walk->commits, oid);
28
- if (pos != kh_end(walk->commits))
29
- return kh_value(walk->commits, pos);
28
+ pos = git_oidmap_lookup_index(walk->commits, oid);
29
+ if (git_oidmap_valid_index(walk->commits, pos))
30
+ return git_oidmap_value_at(walk->commits, pos);
30
31
 
31
32
  commit = git_commit_list_alloc_node(walk);
32
33
  if (commit == NULL)
@@ -34,169 +35,129 @@ git_commit_list_node *git_revwalk__commit_lookup(
34
35
 
35
36
  git_oid_cpy(&commit->oid, oid);
36
37
 
37
- pos = kh_put(oid, walk->commits, &commit->oid, &ret);
38
+ pos = git_oidmap_put(walk->commits, &commit->oid, &ret);
38
39
  assert(ret != 0);
39
- kh_value(walk->commits, pos) = commit;
40
+ git_oidmap_set_value_at(walk->commits, pos, commit);
40
41
 
41
42
  return commit;
42
43
  }
43
44
 
44
- static void mark_uninteresting(git_commit_list_node *commit)
45
- {
46
- unsigned short i;
47
- assert(commit);
48
-
49
- commit->uninteresting = 1;
50
-
51
- /* This means we've reached a merge base, so there's no need to walk any more */
52
- if ((commit->flags & (RESULT | STALE)) == RESULT)
53
- return;
54
-
55
- for (i = 0; i < commit->out_degree; ++i)
56
- if (!commit->parents[i]->uninteresting)
57
- mark_uninteresting(commit->parents[i]);
58
- }
59
-
60
- static int process_commit(git_revwalk *walk, git_commit_list_node *commit, int hide)
45
+ static int push_commit(git_revwalk *walk, const git_oid *oid, int uninteresting, int from_glob)
61
46
  {
47
+ git_oid commit_id;
62
48
  int error;
49
+ git_object *obj, *oobj;
50
+ git_commit_list_node *commit;
51
+ git_commit_list *list;
63
52
 
64
- if (hide)
65
- mark_uninteresting(commit);
66
-
67
- if (commit->seen)
68
- return 0;
69
-
70
- commit->seen = 1;
71
-
72
- if ((error = git_commit_list_parse(walk, commit)) < 0)
53
+ if ((error = git_object_lookup(&oobj, walk->repo, oid, GIT_OBJECT_ANY)) < 0)
73
54
  return error;
74
55
 
75
- return walk->enqueue(walk, commit);
76
- }
77
-
78
- static int process_commit_parents(git_revwalk *walk, git_commit_list_node *commit)
79
- {
80
- unsigned short i;
81
- int error = 0;
82
-
83
- for (i = 0; i < commit->out_degree && !error; ++i)
84
- error = process_commit(walk, commit->parents[i], commit->uninteresting);
56
+ error = git_object_peel(&obj, oobj, GIT_OBJECT_COMMIT);
57
+ git_object_free(oobj);
85
58
 
86
- return error;
87
- }
88
-
89
- static int push_commit(git_revwalk *walk, const git_oid *oid, int uninteresting)
90
- {
91
- git_object *obj;
92
- git_otype type;
93
- git_commit_list_node *commit;
59
+ if (error == GIT_ENOTFOUND || error == GIT_EINVALIDSPEC || error == GIT_EPEEL) {
60
+ /* If this comes from e.g. push_glob("tags"), ignore this */
61
+ if (from_glob)
62
+ return 0;
94
63
 
95
- if (git_object_lookup(&obj, walk->repo, oid, GIT_OBJ_ANY) < 0)
64
+ git_error_set(GIT_ERROR_INVALID, "object is not a committish");
96
65
  return -1;
66
+ }
67
+ if (error < 0)
68
+ return error;
97
69
 
98
- type = git_object_type(obj);
70
+ git_oid_cpy(&commit_id, git_object_id(obj));
99
71
  git_object_free(obj);
100
72
 
101
- if (type != GIT_OBJ_COMMIT) {
102
- giterr_set(GITERR_INVALID, "Object is no commit object");
103
- return -1;
104
- }
105
-
106
- commit = git_revwalk__commit_lookup(walk, oid);
73
+ commit = git_revwalk__commit_lookup(walk, &commit_id);
107
74
  if (commit == NULL)
108
75
  return -1; /* error already reported by failed lookup */
109
76
 
110
- commit->uninteresting = uninteresting;
111
- if (walk->one == NULL && !uninteresting) {
112
- walk->one = commit;
77
+ /* A previous hide already told us we don't want this commit */
78
+ if (commit->uninteresting)
79
+ return 0;
80
+
81
+ if (uninteresting) {
82
+ walk->limited = 1;
83
+ walk->did_hide = 1;
113
84
  } else {
114
- if (git_vector_insert(&walk->twos, commit) < 0)
115
- return -1;
85
+ walk->did_push = 1;
116
86
  }
117
87
 
88
+ commit->uninteresting = uninteresting;
89
+ list = walk->user_input;
90
+ if (git_commit_list_insert(commit, &list) == NULL) {
91
+ git_error_set_oom();
92
+ return -1;
93
+ }
94
+
95
+ walk->user_input = list;
96
+
118
97
  return 0;
119
98
  }
120
99
 
121
100
  int git_revwalk_push(git_revwalk *walk, const git_oid *oid)
122
101
  {
123
102
  assert(walk && oid);
124
- return push_commit(walk, oid, 0);
103
+ return push_commit(walk, oid, 0, false);
125
104
  }
126
105
 
127
106
 
128
107
  int git_revwalk_hide(git_revwalk *walk, const git_oid *oid)
129
108
  {
130
109
  assert(walk && oid);
131
- return push_commit(walk, oid, 1);
110
+ return push_commit(walk, oid, 1, false);
132
111
  }
133
112
 
134
- static int push_ref(git_revwalk *walk, const char *refname, int hide)
113
+ static int push_ref(git_revwalk *walk, const char *refname, int hide, int from_glob)
135
114
  {
136
115
  git_oid oid;
137
116
 
138
117
  if (git_reference_name_to_id(&oid, walk->repo, refname) < 0)
139
118
  return -1;
140
119
 
141
- return push_commit(walk, &oid, hide);
142
- }
143
-
144
- struct push_cb_data {
145
- git_revwalk *walk;
146
- int hide;
147
- };
148
-
149
- static int push_glob_cb(const char *refname, void *data_)
150
- {
151
- struct push_cb_data *data = (struct push_cb_data *)data_;
152
-
153
- return push_ref(data->walk, refname, data->hide);
120
+ return push_commit(walk, &oid, hide, from_glob);
154
121
  }
155
122
 
156
123
  static int push_glob(git_revwalk *walk, const char *glob, int hide)
157
124
  {
125
+ int error = 0;
158
126
  git_buf buf = GIT_BUF_INIT;
159
- struct push_cb_data data;
160
- regex_t preg;
127
+ git_reference *ref;
128
+ git_reference_iterator *iter;
129
+ size_t wildcard;
161
130
 
162
131
  assert(walk && glob);
163
132
 
164
133
  /* refs/ is implied if not given in the glob */
165
- if (strncmp(glob, GIT_REFS_DIR, strlen(GIT_REFS_DIR))) {
166
- git_buf_printf(&buf, GIT_REFS_DIR "%s", glob);
167
- } else {
134
+ if (git__prefixcmp(glob, GIT_REFS_DIR) != 0)
135
+ git_buf_joinpath(&buf, GIT_REFS_DIR, glob);
136
+ else
168
137
  git_buf_puts(&buf, glob);
169
- }
138
+ GIT_ERROR_CHECK_ALLOC_BUF(&buf);
170
139
 
171
140
  /* If no '?', '*' or '[' exist, we append '/ *' to the glob */
172
- memset(&preg, 0x0, sizeof(regex_t));
173
- if (regcomp(&preg, "[?*[]", REG_EXTENDED)) {
174
- giterr_set(GITERR_OS, "Regex failed to compile");
175
- git_buf_free(&buf);
176
- return -1;
177
- }
178
-
179
- if (regexec(&preg, glob, 0, NULL, 0))
180
- git_buf_puts(&buf, "/*");
181
-
182
- if (git_buf_oom(&buf))
183
- goto on_error;
184
-
185
- data.walk = walk;
186
- data.hide = hide;
141
+ wildcard = strcspn(glob, "?*[");
142
+ if (!glob[wildcard])
143
+ git_buf_put(&buf, "/*", 2);
187
144
 
188
- if (git_reference_foreach_glob(
189
- walk->repo, git_buf_cstr(&buf), push_glob_cb, &data) < 0)
190
- goto on_error;
145
+ if ((error = git_reference_iterator_glob_new(&iter, walk->repo, buf.ptr)) < 0)
146
+ goto out;
191
147
 
192
- regfree(&preg);
193
- git_buf_free(&buf);
194
- return 0;
148
+ while ((error = git_reference_next(&ref, iter)) == 0) {
149
+ error = push_ref(walk, git_reference_name(ref), hide, true);
150
+ git_reference_free(ref);
151
+ if (error < 0)
152
+ break;
153
+ }
154
+ git_reference_iterator_free(iter);
195
155
 
196
- on_error:
197
- regfree(&preg);
198
- git_buf_free(&buf);
199
- return -1;
156
+ if (error == GIT_ITEROVER)
157
+ error = 0;
158
+ out:
159
+ git_buf_dispose(&buf);
160
+ return error;
200
161
  }
201
162
 
202
163
  int git_revwalk_push_glob(git_revwalk *walk, const char *glob)
@@ -214,19 +175,19 @@ int git_revwalk_hide_glob(git_revwalk *walk, const char *glob)
214
175
  int git_revwalk_push_head(git_revwalk *walk)
215
176
  {
216
177
  assert(walk);
217
- return push_ref(walk, GIT_HEAD_FILE, 0);
178
+ return push_ref(walk, GIT_HEAD_FILE, 0, false);
218
179
  }
219
180
 
220
181
  int git_revwalk_hide_head(git_revwalk *walk)
221
182
  {
222
183
  assert(walk);
223
- return push_ref(walk, GIT_HEAD_FILE, 1);
184
+ return push_ref(walk, GIT_HEAD_FILE, 1, false);
224
185
  }
225
186
 
226
187
  int git_revwalk_push_ref(git_revwalk *walk, const char *refname)
227
188
  {
228
189
  assert(walk && refname);
229
- return push_ref(walk, refname, 0);
190
+ return push_ref(walk, refname, 0, false);
230
191
  }
231
192
 
232
193
  int git_revwalk_push_range(git_revwalk *walk, const char *range)
@@ -239,14 +200,14 @@ int git_revwalk_push_range(git_revwalk *walk, const char *range)
239
200
 
240
201
  if (revspec.flags & GIT_REVPARSE_MERGE_BASE) {
241
202
  /* TODO: support "<commit>...<commit>" */
242
- giterr_set(GITERR_INVALID, "Symmetric differences not implemented in revwalk");
203
+ git_error_set(GIT_ERROR_INVALID, "symmetric differences not implemented in revwalk");
243
204
  return GIT_EINVALIDSPEC;
244
205
  }
245
206
 
246
- if ((error = push_commit(walk, git_object_id(revspec.from), 1)))
207
+ if ((error = push_commit(walk, git_object_id(revspec.from), 1, false)))
247
208
  goto out;
248
209
 
249
- error = push_commit(walk, git_object_id(revspec.to), 0);
210
+ error = push_commit(walk, git_object_id(revspec.to), 0, false);
250
211
 
251
212
  out:
252
213
  git_object_free(revspec.from);
@@ -257,7 +218,7 @@ out:
257
218
  int git_revwalk_hide_ref(git_revwalk *walk, const char *refname)
258
219
  {
259
220
  assert(walk && refname);
260
- return push_ref(walk, refname, 1);
221
+ return push_ref(walk, refname, 1, false);
261
222
  }
262
223
 
263
224
  static int revwalk_enqueue_timesort(git_revwalk *walk, git_commit_list_node *commit)
@@ -272,20 +233,17 @@ static int revwalk_enqueue_unsorted(git_revwalk *walk, git_commit_list_node *com
272
233
 
273
234
  static int revwalk_next_timesort(git_commit_list_node **object_out, git_revwalk *walk)
274
235
  {
275
- int error;
276
236
  git_commit_list_node *next;
277
237
 
278
238
  while ((next = git_pqueue_pop(&walk->iterator_time)) != NULL) {
279
- if ((error = process_commit_parents(walk, next)) < 0)
280
- return error;
281
-
239
+ /* Some commits might become uninteresting after being added to the list */
282
240
  if (!next->uninteresting) {
283
241
  *object_out = next;
284
242
  return 0;
285
243
  }
286
244
  }
287
245
 
288
- giterr_clear();
246
+ git_error_clear();
289
247
  return GIT_ITEROVER;
290
248
  }
291
249
 
@@ -294,105 +252,356 @@ static int revwalk_next_unsorted(git_commit_list_node **object_out, git_revwalk
294
252
  int error;
295
253
  git_commit_list_node *next;
296
254
 
297
- while ((next = git_commit_list_pop(&walk->iterator_rand)) != NULL) {
298
- if ((error = process_commit_parents(walk, next)) < 0)
299
- return error;
300
-
255
+ while (!(error = get_revision(&next, walk, &walk->iterator_rand))) {
256
+ /* Some commits might become uninteresting after being added to the list */
301
257
  if (!next->uninteresting) {
302
258
  *object_out = next;
303
259
  return 0;
304
260
  }
305
261
  }
306
262
 
307
- giterr_clear();
308
- return GIT_ITEROVER;
263
+ return error;
309
264
  }
310
265
 
311
266
  static int revwalk_next_toposort(git_commit_list_node **object_out, git_revwalk *walk)
312
267
  {
268
+ int error;
313
269
  git_commit_list_node *next;
314
- unsigned short i;
315
270
 
316
- for (;;) {
317
- next = git_commit_list_pop(&walk->iterator_topo);
318
- if (next == NULL) {
319
- giterr_clear();
320
- return GIT_ITEROVER;
271
+ while (!(error = get_revision(&next, walk, &walk->iterator_topo))) {
272
+ /* Some commits might become uninteresting after being added to the list */
273
+ if (!next->uninteresting) {
274
+ *object_out = next;
275
+ return 0;
321
276
  }
277
+ }
322
278
 
323
- if (next->in_degree > 0) {
324
- next->topo_delay = 1;
325
- continue;
279
+ return error;
280
+ }
281
+
282
+ static int revwalk_next_reverse(git_commit_list_node **object_out, git_revwalk *walk)
283
+ {
284
+ *object_out = git_commit_list_pop(&walk->iterator_reverse);
285
+ return *object_out ? 0 : GIT_ITEROVER;
286
+ }
287
+
288
+ static void mark_parents_uninteresting(git_commit_list_node *commit)
289
+ {
290
+ unsigned short i;
291
+ git_commit_list *parents = NULL;
292
+
293
+ for (i = 0; i < commit->out_degree; i++)
294
+ git_commit_list_insert(commit->parents[i], &parents);
295
+
296
+
297
+ while (parents) {
298
+ commit = git_commit_list_pop(&parents);
299
+
300
+ while (commit) {
301
+ if (commit->uninteresting)
302
+ break;
303
+
304
+ commit->uninteresting = 1;
305
+ /*
306
+ * If we've reached this commit some other way
307
+ * already, we need to mark its parents uninteresting
308
+ * as well.
309
+ */
310
+ if (!commit->parents)
311
+ break;
312
+
313
+ for (i = 0; i < commit->out_degree; i++)
314
+ git_commit_list_insert(commit->parents[i], &parents);
315
+ commit = commit->parents[0];
326
316
  }
317
+ }
318
+ }
327
319
 
328
- for (i = 0; i < next->out_degree; ++i) {
329
- git_commit_list_node *parent = next->parents[i];
320
+ static int add_parents_to_list(git_revwalk *walk, git_commit_list_node *commit, git_commit_list **list)
321
+ {
322
+ unsigned short i;
323
+ int error;
330
324
 
331
- if (--parent->in_degree == 0 && parent->topo_delay) {
332
- parent->topo_delay = 0;
333
- if (git_commit_list_insert(parent, &walk->iterator_topo) == NULL)
334
- return -1;
335
- }
325
+ if (commit->added)
326
+ return 0;
327
+
328
+ commit->added = 1;
329
+
330
+ /*
331
+ * Go full on in the uninteresting case as we want to include
332
+ * as many of these as we can.
333
+ *
334
+ * Usually we haven't parsed the parent of a parent, but if we
335
+ * have it we reached it via other means so we want to mark
336
+ * its parents recursively too.
337
+ */
338
+ if (commit->uninteresting) {
339
+ for (i = 0; i < commit->out_degree; i++) {
340
+ git_commit_list_node *p = commit->parents[i];
341
+ p->uninteresting = 1;
342
+
343
+ /* git does it gently here, but we don't like missing objects */
344
+ if ((error = git_commit_list_parse(walk, p)) < 0)
345
+ return error;
346
+
347
+ if (p->parents)
348
+ mark_parents_uninteresting(p);
349
+
350
+ p->seen = 1;
351
+ git_commit_list_insert_by_date(p, list);
336
352
  }
337
353
 
338
- *object_out = next;
339
354
  return 0;
340
355
  }
356
+
357
+ /*
358
+ * Now on to what we do if the commit is indeed
359
+ * interesting. Here we do want things like first-parent take
360
+ * effect as this is what we'll be showing.
361
+ */
362
+ for (i = 0; i < commit->out_degree; i++) {
363
+ git_commit_list_node *p = commit->parents[i];
364
+
365
+ if ((error = git_commit_list_parse(walk, p)) < 0)
366
+ return error;
367
+
368
+ if (walk->hide_cb && walk->hide_cb(&p->oid, walk->hide_cb_payload))
369
+ continue;
370
+
371
+ if (!p->seen) {
372
+ p->seen = 1;
373
+ git_commit_list_insert_by_date(p, list);
374
+ }
375
+
376
+ if (walk->first_parent)
377
+ break;
378
+ }
379
+ return 0;
341
380
  }
342
381
 
343
- static int revwalk_next_reverse(git_commit_list_node **object_out, git_revwalk *walk)
382
+ /* How many unintersting commits we want to look at after we run out of interesting ones */
383
+ #define SLOP 5
384
+
385
+ static int still_interesting(git_commit_list *list, int64_t time, int slop)
344
386
  {
345
- *object_out = git_commit_list_pop(&walk->iterator_reverse);
346
- return *object_out ? 0 : GIT_ITEROVER;
387
+ /* The empty list is pretty boring */
388
+ if (!list)
389
+ return 0;
390
+
391
+ /*
392
+ * If the destination list has commits with an earlier date than our
393
+ * source, we want to reset the slop counter as we're not done.
394
+ */
395
+ if (time <= list->item->time)
396
+ return SLOP;
397
+
398
+ for (; list; list = list->next) {
399
+ /*
400
+ * If the destination list still contains interesting commits we
401
+ * want to continue looking.
402
+ */
403
+ if (!list->item->uninteresting || list->item->time > time)
404
+ return SLOP;
405
+ }
406
+
407
+ /* Everything's uninteresting, reduce the count */
408
+ return slop - 1;
347
409
  }
348
410
 
411
+ static int limit_list(git_commit_list **out, git_revwalk *walk, git_commit_list *commits)
412
+ {
413
+ int error, slop = SLOP;
414
+ int64_t time = INT64_MAX;
415
+ git_commit_list *list = commits;
416
+ git_commit_list *newlist = NULL;
417
+ git_commit_list **p = &newlist;
349
418
 
350
- static int prepare_walk(git_revwalk *walk)
419
+ while (list) {
420
+ git_commit_list_node *commit = git_commit_list_pop(&list);
421
+
422
+ if ((error = add_parents_to_list(walk, commit, &list)) < 0)
423
+ return error;
424
+
425
+ if (commit->uninteresting) {
426
+ mark_parents_uninteresting(commit);
427
+
428
+ slop = still_interesting(list, time, slop);
429
+ if (slop)
430
+ continue;
431
+
432
+ break;
433
+ }
434
+
435
+ if (walk->hide_cb && walk->hide_cb(&commit->oid, walk->hide_cb_payload))
436
+ continue;
437
+
438
+ time = commit->time;
439
+ p = &git_commit_list_insert(commit, p)->next;
440
+ }
441
+
442
+ git_commit_list_free(&list);
443
+ *out = newlist;
444
+ return 0;
445
+ }
446
+
447
+ static int get_revision(git_commit_list_node **out, git_revwalk *walk, git_commit_list **list)
351
448
  {
352
449
  int error;
353
- unsigned int i;
354
- git_commit_list_node *next, *two;
355
- git_commit_list *bases = NULL;
450
+ git_commit_list_node *commit;
451
+
452
+ commit = git_commit_list_pop(list);
453
+ if (!commit) {
454
+ git_error_clear();
455
+ return GIT_ITEROVER;
456
+ }
356
457
 
357
458
  /*
358
- * If walk->one is NULL, there were no positive references,
359
- * so we know that the walk is already over.
459
+ * If we did not run limit_list and we must add parents to the
460
+ * list ourselves.
360
461
  */
361
- if (walk->one == NULL) {
362
- giterr_clear();
363
- return GIT_ITEROVER;
462
+ if (!walk->limited) {
463
+ if ((error = add_parents_to_list(walk, commit, list)) < 0)
464
+ return error;
364
465
  }
365
466
 
366
- /* first figure out what the merge bases are */
367
- if (git_merge__bases_many(&bases, walk, walk->one, &walk->twos) < 0)
368
- return -1;
467
+ *out = commit;
468
+ return 0;
469
+ }
369
470
 
370
- git_commit_list_free(&bases);
371
- if (process_commit(walk, walk->one, walk->one->uninteresting) < 0)
372
- return -1;
471
+ static int sort_in_topological_order(git_commit_list **out, git_revwalk *walk, git_commit_list *list)
472
+ {
473
+ git_commit_list *ll = NULL, *newlist, **pptr;
474
+ git_commit_list_node *next;
475
+ git_pqueue queue;
476
+ git_vector_cmp queue_cmp = NULL;
477
+ unsigned short i;
478
+ int error;
373
479
 
374
- git_vector_foreach(&walk->twos, i, two) {
375
- if (process_commit(walk, two, two->uninteresting) < 0)
376
- return -1;
377
- }
480
+ if (walk->sorting & GIT_SORT_TIME)
481
+ queue_cmp = git_commit_list_time_cmp;
378
482
 
379
- if (walk->sorting & GIT_SORT_TOPOLOGICAL) {
380
- unsigned short i;
483
+ if ((error = git_pqueue_init(&queue, 0, 8, queue_cmp)))
484
+ return error;
485
+
486
+ /*
487
+ * Start by resetting the in-degree to 1 for the commits in
488
+ * our list. We want to go through this list again, so we
489
+ * store it in the commit list as we extract it from the lower
490
+ * machinery.
491
+ */
492
+ for (ll = list; ll; ll = ll->next) {
493
+ ll->item->in_degree = 1;
494
+ }
381
495
 
382
- while ((error = walk->get_next(&next, walk)) == 0) {
383
- for (i = 0; i < next->out_degree; ++i) {
384
- git_commit_list_node *parent = next->parents[i];
496
+ /*
497
+ * Count up how many children each commit has. We limit
498
+ * ourselves to those commits in the original list (in-degree
499
+ * of 1) avoiding setting it for any parent that was hidden.
500
+ */
501
+ for(ll = list; ll; ll = ll->next) {
502
+ for (i = 0; i < ll->item->out_degree; ++i) {
503
+ git_commit_list_node *parent = ll->item->parents[i];
504
+ if (parent->in_degree)
385
505
  parent->in_degree++;
506
+ }
507
+ }
508
+
509
+ /*
510
+ * Now we find the tips i.e. those not reachable from any other node
511
+ * i.e. those which still have an in-degree of 1.
512
+ */
513
+ for(ll = list; ll; ll = ll->next) {
514
+ if (ll->item->in_degree == 1) {
515
+ if ((error = git_pqueue_insert(&queue, ll->item)))
516
+ goto cleanup;
517
+ }
518
+ }
519
+
520
+ /*
521
+ * We need to output the tips in the order that they came out of the
522
+ * traversal, so if we're not doing time-sorting, we need to reverse the
523
+ * pqueue in order to get them to come out as we inserted them.
524
+ */
525
+ if ((walk->sorting & GIT_SORT_TIME) == 0)
526
+ git_pqueue_reverse(&queue);
527
+
528
+
529
+ pptr = &newlist;
530
+ newlist = NULL;
531
+ while ((next = git_pqueue_pop(&queue)) != NULL) {
532
+ for (i = 0; i < next->out_degree; ++i) {
533
+ git_commit_list_node *parent = next->parents[i];
534
+ if (parent->in_degree == 0)
535
+ continue;
536
+
537
+ if (--parent->in_degree == 1) {
538
+ if ((error = git_pqueue_insert(&queue, parent)))
539
+ goto cleanup;
386
540
  }
541
+ }
387
542
 
388
- if (git_commit_list_insert(next, &walk->iterator_topo) == NULL)
389
- return -1;
543
+ /* All the children of 'item' have been emitted (since we got to it via the priority queue) */
544
+ next->in_degree = 0;
545
+
546
+ pptr = &git_commit_list_insert(next, pptr)->next;
547
+ }
548
+
549
+ *out = newlist;
550
+ error = 0;
551
+
552
+ cleanup:
553
+ git_pqueue_free(&queue);
554
+ return error;
555
+ }
556
+
557
+ static int prepare_walk(git_revwalk *walk)
558
+ {
559
+ int error = 0;
560
+ git_commit_list *list, *commits = NULL;
561
+ git_commit_list_node *next;
562
+
563
+ /* If there were no pushes, we know that the walk is already over */
564
+ if (!walk->did_push) {
565
+ git_error_clear();
566
+ return GIT_ITEROVER;
567
+ }
568
+
569
+ for (list = walk->user_input; list; list = list->next) {
570
+ git_commit_list_node *commit = list->item;
571
+ if ((error = git_commit_list_parse(walk, commit)) < 0)
572
+ return error;
573
+
574
+ if (commit->uninteresting)
575
+ mark_parents_uninteresting(commit);
576
+
577
+ if (!commit->seen) {
578
+ commit->seen = 1;
579
+ git_commit_list_insert(commit, &commits);
390
580
  }
581
+ }
391
582
 
392
- if (error != GIT_ITEROVER)
583
+ if (walk->limited && (error = limit_list(&commits, walk, commits)) < 0)
584
+ return error;
585
+
586
+ if (walk->sorting & GIT_SORT_TOPOLOGICAL) {
587
+ error = sort_in_topological_order(&walk->iterator_topo, walk, commits);
588
+ git_commit_list_free(&commits);
589
+
590
+ if (error < 0)
393
591
  return error;
394
592
 
395
593
  walk->get_next = &revwalk_next_toposort;
594
+ } else if (walk->sorting & GIT_SORT_TIME) {
595
+ for (list = commits; list && !error; list = list->next)
596
+ error = walk->enqueue(walk, list->item);
597
+
598
+ git_commit_list_free(&commits);
599
+
600
+ if (error < 0)
601
+ return error;
602
+ } else {
603
+ walk->iterator_rand = commits;
604
+ walk->get_next = revwalk_next_unsorted;
396
605
  }
397
606
 
398
607
  if (walk->sorting & GIT_SORT_REVERSE) {
@@ -414,22 +623,16 @@ static int prepare_walk(git_revwalk *walk)
414
623
 
415
624
  int git_revwalk_new(git_revwalk **revwalk_out, git_repository *repo)
416
625
  {
417
- git_revwalk *walk;
418
-
419
- walk = git__malloc(sizeof(git_revwalk));
420
- GITERR_CHECK_ALLOC(walk);
421
-
422
- memset(walk, 0x0, sizeof(git_revwalk));
626
+ git_revwalk *walk = git__calloc(1, sizeof(git_revwalk));
627
+ GIT_ERROR_CHECK_ALLOC(walk);
423
628
 
424
629
  walk->commits = git_oidmap_alloc();
425
- GITERR_CHECK_ALLOC(walk->commits);
630
+ GIT_ERROR_CHECK_ALLOC(walk->commits);
426
631
 
427
- if (git_pqueue_init(&walk->iterator_time, 8, git_commit_list_time_cmp) < 0 ||
428
- git_vector_init(&walk->twos, 4, NULL) < 0 ||
429
- git_pool_init(&walk->commit_pool, 1,
430
- git_pool__suggest_items_per_page(COMMIT_ALLOC) * COMMIT_ALLOC) < 0)
632
+ if (git_pqueue_init(&walk->iterator_time, 0, 8, git_commit_list_time_cmp) < 0)
431
633
  return -1;
432
634
 
635
+ git_pool_init(&walk->commit_pool, COMMIT_ALLOC);
433
636
  walk->get_next = &revwalk_next_unsorted;
434
637
  walk->enqueue = &revwalk_enqueue_unsorted;
435
638
 
@@ -455,7 +658,6 @@ void git_revwalk_free(git_revwalk *walk)
455
658
  git_oidmap_free(walk->commits);
456
659
  git_pool_clear(&walk->commit_pool);
457
660
  git_pqueue_free(&walk->iterator_time);
458
- git_vector_free(&walk->twos);
459
661
  git__free(walk);
460
662
  }
461
663
 
@@ -481,6 +683,14 @@ void git_revwalk_sorting(git_revwalk *walk, unsigned int sort_mode)
481
683
  walk->get_next = &revwalk_next_unsorted;
482
684
  walk->enqueue = &revwalk_enqueue_unsorted;
483
685
  }
686
+
687
+ if (walk->sorting != GIT_SORT_NONE)
688
+ walk->limited = 1;
689
+ }
690
+
691
+ void git_revwalk_simplify_first_parent(git_revwalk *walk)
692
+ {
693
+ walk->first_parent = 1;
484
694
  }
485
695
 
486
696
  int git_revwalk_next(git_oid *oid, git_revwalk *walk)
@@ -499,7 +709,7 @@ int git_revwalk_next(git_oid *oid, git_revwalk *walk)
499
709
 
500
710
  if (error == GIT_ITEROVER) {
501
711
  git_revwalk_reset(walk);
502
- giterr_clear();
712
+ git_error_clear();
503
713
  return GIT_ITEROVER;
504
714
  }
505
715
 
@@ -515,20 +725,43 @@ void git_revwalk_reset(git_revwalk *walk)
515
725
 
516
726
  assert(walk);
517
727
 
518
- kh_foreach_value(walk->commits, commit, {
728
+ git_oidmap_foreach_value(walk->commits, commit, {
519
729
  commit->seen = 0;
520
730
  commit->in_degree = 0;
521
731
  commit->topo_delay = 0;
522
732
  commit->uninteresting = 0;
733
+ commit->added = 0;
734
+ commit->flags = 0;
523
735
  });
524
736
 
525
737
  git_pqueue_clear(&walk->iterator_time);
526
738
  git_commit_list_free(&walk->iterator_topo);
527
739
  git_commit_list_free(&walk->iterator_rand);
528
740
  git_commit_list_free(&walk->iterator_reverse);
741
+ git_commit_list_free(&walk->user_input);
742
+ walk->first_parent = 0;
529
743
  walk->walking = 0;
744
+ walk->limited = 0;
745
+ walk->did_push = walk->did_hide = 0;
746
+ walk->sorting = GIT_SORT_NONE;
747
+ }
748
+
749
+ int git_revwalk_add_hide_cb(
750
+ git_revwalk *walk,
751
+ git_revwalk_hide_cb hide_cb,
752
+ void *payload)
753
+ {
754
+ assert(walk);
755
+
756
+ if (walk->walking)
757
+ git_revwalk_reset(walk);
530
758
 
531
- walk->one = NULL;
532
- git_vector_clear(&walk->twos);
759
+ walk->hide_cb = hide_cb;
760
+ walk->hide_cb_payload = payload;
761
+
762
+ if (hide_cb)
763
+ walk->limited = 1;
764
+
765
+ return 0;
533
766
  }
534
767