rugged 0.16.0 → 0.17.0b1

Sign up to get free protection for your applications and to get access to all the features.
Files changed (392) hide show
  1. data/README.md +373 -243
  2. data/Rakefile +22 -0
  3. data/ext/rugged/extconf.rb +9 -6
  4. data/ext/rugged/rugged.c +123 -31
  5. data/ext/rugged/rugged.h +11 -10
  6. data/ext/rugged/rugged_blob.c +181 -18
  7. data/ext/rugged/rugged_commit.c +196 -18
  8. data/ext/rugged/rugged_config.c +94 -5
  9. data/ext/rugged/rugged_object.c +54 -1
  10. data/ext/rugged/rugged_reference.c +203 -15
  11. data/ext/rugged/{remote.c → rugged_remote.c} +35 -10
  12. data/ext/rugged/rugged_repo.c +323 -81
  13. data/ext/rugged/rugged_revwalk.c +57 -4
  14. data/ext/rugged/rugged_signature.c +3 -3
  15. data/ext/rugged/rugged_tag.c +72 -1
  16. data/ext/rugged/rugged_tree.c +70 -2
  17. data/ext/rugged/vendor/libgit2-dist/deps/regex/config.h +7 -0
  18. data/ext/rugged/vendor/libgit2-dist/deps/regex/regcomp.c +3856 -0
  19. data/ext/rugged/vendor/libgit2-dist/deps/regex/regex.c +85 -0
  20. data/ext/rugged/vendor/libgit2-dist/deps/regex/regex.h +582 -0
  21. data/ext/rugged/vendor/libgit2-dist/deps/regex/regex_internal.c +1744 -0
  22. data/ext/rugged/vendor/libgit2-dist/deps/regex/regex_internal.h +810 -0
  23. data/ext/rugged/vendor/libgit2-dist/deps/regex/regexec.c +4369 -0
  24. data/ext/rugged/vendor/libgit2-dist/examples/diff.c +238 -0
  25. data/ext/rugged/vendor/libgit2-dist/examples/general.c +4 -4
  26. data/ext/rugged/vendor/libgit2-dist/examples/network/fetch.c +101 -85
  27. data/ext/rugged/vendor/libgit2-dist/examples/network/git2.c +7 -3
  28. data/ext/rugged/vendor/libgit2-dist/examples/network/index-pack.c +80 -25
  29. data/ext/rugged/vendor/libgit2-dist/examples/network/ls-remote.c +6 -6
  30. data/ext/rugged/vendor/libgit2-dist/include/git2/attr.h +224 -0
  31. data/ext/rugged/vendor/libgit2-dist/include/git2/blob.h +59 -5
  32. data/ext/rugged/vendor/libgit2-dist/include/git2/branch.h +114 -7
  33. data/ext/rugged/vendor/libgit2-dist/include/git2/commit.h +14 -7
  34. data/ext/rugged/vendor/libgit2-dist/include/git2/common.h +4 -3
  35. data/ext/rugged/vendor/libgit2-dist/include/git2/config.h +105 -27
  36. data/ext/rugged/vendor/libgit2-dist/include/git2/diff.h +409 -0
  37. data/ext/rugged/vendor/libgit2-dist/include/git2/errors.h +47 -82
  38. data/ext/rugged/vendor/libgit2-dist/include/git2/index.h +25 -10
  39. data/ext/rugged/vendor/libgit2-dist/include/git2/indexer.h +46 -1
  40. data/ext/rugged/vendor/libgit2-dist/include/git2/merge.h +35 -0
  41. data/ext/rugged/vendor/libgit2-dist/include/git2/net.h +1 -1
  42. data/ext/rugged/vendor/libgit2-dist/include/git2/notes.h +139 -0
  43. data/ext/rugged/vendor/libgit2-dist/include/git2/object.h +5 -5
  44. data/ext/rugged/vendor/libgit2-dist/include/git2/odb.h +13 -13
  45. data/ext/rugged/vendor/libgit2-dist/include/git2/odb_backend.h +8 -8
  46. data/ext/rugged/vendor/libgit2-dist/include/git2/oid.h +14 -9
  47. data/ext/rugged/vendor/libgit2-dist/include/git2/reflog.h +5 -5
  48. data/ext/rugged/vendor/libgit2-dist/include/git2/refs.h +37 -17
  49. data/ext/rugged/vendor/libgit2-dist/include/git2/refspec.h +17 -9
  50. data/ext/rugged/vendor/libgit2-dist/include/git2/remote.h +83 -16
  51. data/ext/rugged/vendor/libgit2-dist/include/git2/repository.h +24 -10
  52. data/ext/rugged/vendor/libgit2-dist/include/git2/reset.h +44 -0
  53. data/ext/rugged/vendor/libgit2-dist/include/git2/revparse.h +36 -0
  54. data/ext/rugged/vendor/libgit2-dist/include/git2/revwalk.h +74 -6
  55. data/ext/rugged/vendor/libgit2-dist/include/git2/signature.h +3 -3
  56. data/ext/rugged/vendor/libgit2-dist/include/git2/status.h +120 -19
  57. data/ext/rugged/vendor/libgit2-dist/include/git2/submodule.h +103 -0
  58. data/ext/rugged/vendor/libgit2-dist/include/git2/tag.h +28 -10
  59. data/ext/rugged/vendor/libgit2-dist/include/git2/threads.h +1 -1
  60. data/ext/rugged/vendor/libgit2-dist/include/git2/tree.h +13 -13
  61. data/ext/rugged/vendor/libgit2-dist/include/git2/types.h +16 -2
  62. data/ext/rugged/vendor/libgit2-dist/include/git2/version.h +3 -3
  63. data/ext/rugged/vendor/libgit2-dist/include/git2/windows.h +1 -1
  64. data/ext/rugged/vendor/libgit2-dist/include/git2.h +7 -2
  65. data/ext/rugged/vendor/libgit2-dist/src/attr.c +677 -0
  66. data/ext/rugged/vendor/libgit2-dist/src/attr.h +56 -0
  67. data/ext/rugged/vendor/libgit2-dist/src/attr_file.c +609 -0
  68. data/ext/rugged/vendor/libgit2-dist/src/attr_file.h +145 -0
  69. data/ext/rugged/vendor/libgit2-dist/src/blob.c +213 -60
  70. data/ext/rugged/vendor/libgit2-dist/src/blob.h +2 -1
  71. data/ext/rugged/vendor/libgit2-dist/src/branch.c +208 -0
  72. data/ext/rugged/vendor/libgit2-dist/src/branch.h +17 -0
  73. data/ext/rugged/vendor/libgit2-dist/src/bswap.h +1 -1
  74. data/ext/rugged/vendor/libgit2-dist/src/buffer.c +395 -46
  75. data/ext/rugged/vendor/libgit2-dist/src/buffer.h +112 -9
  76. data/ext/rugged/vendor/libgit2-dist/src/cache.c +37 -49
  77. data/ext/rugged/vendor/libgit2-dist/src/cache.h +7 -17
  78. data/ext/rugged/vendor/libgit2-dist/src/cc-compat.h +18 -16
  79. data/ext/rugged/vendor/libgit2-dist/src/commit.c +56 -90
  80. data/ext/rugged/vendor/libgit2-dist/src/commit.h +1 -1
  81. data/ext/rugged/vendor/libgit2-dist/src/common.h +12 -5
  82. data/ext/rugged/vendor/libgit2-dist/src/{win32 → compat}/fnmatch.c +1 -1
  83. data/ext/rugged/vendor/libgit2-dist/src/{win32 → compat}/fnmatch.h +3 -3
  84. data/ext/rugged/vendor/libgit2-dist/src/config.c +247 -158
  85. data/ext/rugged/vendor/libgit2-dist/src/config.h +10 -1
  86. data/ext/rugged/vendor/libgit2-dist/src/config_cache.c +94 -0
  87. data/ext/rugged/vendor/libgit2-dist/src/config_file.c +606 -496
  88. data/ext/rugged/vendor/libgit2-dist/src/config_file.h +31 -0
  89. data/ext/rugged/vendor/libgit2-dist/src/crlf.c +228 -0
  90. data/ext/rugged/vendor/libgit2-dist/src/date.c +876 -0
  91. data/ext/rugged/vendor/libgit2-dist/src/delta-apply.c +15 -9
  92. data/ext/rugged/vendor/libgit2-dist/src/delta-apply.h +2 -2
  93. data/ext/rugged/vendor/libgit2-dist/src/diff.c +814 -0
  94. data/ext/rugged/vendor/libgit2-dist/src/diff.h +43 -0
  95. data/ext/rugged/vendor/libgit2-dist/src/diff_output.c +794 -0
  96. data/ext/rugged/vendor/libgit2-dist/src/errors.c +89 -74
  97. data/ext/rugged/vendor/libgit2-dist/src/fetch.c +94 -66
  98. data/ext/rugged/vendor/libgit2-dist/src/fetch.h +5 -4
  99. data/ext/rugged/vendor/libgit2-dist/src/filebuf.c +157 -100
  100. data/ext/rugged/vendor/libgit2-dist/src/filebuf.h +22 -8
  101. data/ext/rugged/vendor/libgit2-dist/src/fileops.c +330 -206
  102. data/ext/rugged/vendor/libgit2-dist/src/fileops.h +82 -51
  103. data/ext/rugged/vendor/libgit2-dist/src/filter.c +165 -0
  104. data/ext/rugged/vendor/libgit2-dist/src/filter.h +119 -0
  105. data/ext/rugged/vendor/libgit2-dist/src/global.c +4 -4
  106. data/ext/rugged/vendor/libgit2-dist/src/global.h +4 -1
  107. data/ext/rugged/vendor/libgit2-dist/src/hash.c +1 -1
  108. data/ext/rugged/vendor/libgit2-dist/src/hash.h +1 -1
  109. data/ext/rugged/vendor/libgit2-dist/src/ignore.c +203 -0
  110. data/ext/rugged/vendor/libgit2-dist/src/ignore.h +38 -0
  111. data/ext/rugged/vendor/libgit2-dist/src/index.c +220 -169
  112. data/ext/rugged/vendor/libgit2-dist/src/index.h +5 -1
  113. data/ext/rugged/vendor/libgit2-dist/src/indexer.c +601 -102
  114. data/ext/rugged/vendor/libgit2-dist/src/iterator.c +748 -0
  115. data/ext/rugged/vendor/libgit2-dist/src/iterator.h +151 -0
  116. data/ext/rugged/vendor/libgit2-dist/src/khash.h +608 -0
  117. data/ext/rugged/vendor/libgit2-dist/src/map.h +6 -1
  118. data/ext/rugged/vendor/libgit2-dist/src/message.c +61 -0
  119. data/ext/rugged/vendor/libgit2-dist/src/message.h +14 -0
  120. data/ext/rugged/vendor/libgit2-dist/src/mwindow.c +27 -29
  121. data/ext/rugged/vendor/libgit2-dist/src/mwindow.h +4 -4
  122. data/ext/rugged/vendor/libgit2-dist/src/netops.c +375 -56
  123. data/ext/rugged/vendor/libgit2-dist/src/netops.h +12 -9
  124. data/ext/rugged/vendor/libgit2-dist/src/notes.c +548 -0
  125. data/ext/rugged/vendor/libgit2-dist/src/notes.h +28 -0
  126. data/ext/rugged/vendor/libgit2-dist/src/object.c +59 -21
  127. data/ext/rugged/vendor/libgit2-dist/src/odb.c +212 -175
  128. data/ext/rugged/vendor/libgit2-dist/src/odb.h +39 -2
  129. data/ext/rugged/vendor/libgit2-dist/src/odb_loose.c +238 -241
  130. data/ext/rugged/vendor/libgit2-dist/src/odb_pack.c +94 -106
  131. data/ext/rugged/vendor/libgit2-dist/src/oid.c +59 -60
  132. data/ext/rugged/vendor/libgit2-dist/src/oidmap.h +42 -0
  133. data/ext/rugged/vendor/libgit2-dist/src/pack.c +198 -170
  134. data/ext/rugged/vendor/libgit2-dist/src/pack.h +16 -9
  135. data/ext/rugged/vendor/libgit2-dist/src/path.c +496 -106
  136. data/ext/rugged/vendor/libgit2-dist/src/path.h +214 -20
  137. data/ext/rugged/vendor/libgit2-dist/src/pkt.c +88 -159
  138. data/ext/rugged/vendor/libgit2-dist/src/pkt.h +9 -5
  139. data/ext/rugged/vendor/libgit2-dist/src/pool.c +294 -0
  140. data/ext/rugged/vendor/libgit2-dist/src/pool.h +125 -0
  141. data/ext/rugged/vendor/libgit2-dist/src/posix.c +38 -16
  142. data/ext/rugged/vendor/libgit2-dist/src/posix.h +20 -2
  143. data/ext/rugged/vendor/libgit2-dist/src/ppc/sha1.c +1 -1
  144. data/ext/rugged/vendor/libgit2-dist/src/ppc/sha1.h +1 -1
  145. data/ext/rugged/vendor/libgit2-dist/src/pqueue.c +7 -7
  146. data/ext/rugged/vendor/libgit2-dist/src/pqueue.h +1 -1
  147. data/ext/rugged/vendor/libgit2-dist/src/protocol.c +21 -13
  148. data/ext/rugged/vendor/libgit2-dist/src/protocol.h +1 -1
  149. data/ext/rugged/vendor/libgit2-dist/src/reflog.c +125 -103
  150. data/ext/rugged/vendor/libgit2-dist/src/reflog.h +1 -1
  151. data/ext/rugged/vendor/libgit2-dist/src/refs.c +713 -640
  152. data/ext/rugged/vendor/libgit2-dist/src/refs.h +27 -3
  153. data/ext/rugged/vendor/libgit2-dist/src/refspec.c +51 -17
  154. data/ext/rugged/vendor/libgit2-dist/src/refspec.h +13 -1
  155. data/ext/rugged/vendor/libgit2-dist/src/remote.c +307 -119
  156. data/ext/rugged/vendor/libgit2-dist/src/remote.h +3 -2
  157. data/ext/rugged/vendor/libgit2-dist/src/repository.c +593 -442
  158. data/ext/rugged/vendor/libgit2-dist/src/repository.h +80 -2
  159. data/ext/rugged/vendor/libgit2-dist/src/reset.c +103 -0
  160. data/ext/rugged/vendor/libgit2-dist/src/revparse.c +753 -0
  161. data/ext/rugged/vendor/libgit2-dist/src/revwalk.c +434 -158
  162. data/ext/rugged/vendor/libgit2-dist/src/sha1.c +3 -3
  163. data/ext/rugged/vendor/libgit2-dist/src/sha1.h +2 -2
  164. data/ext/rugged/vendor/libgit2-dist/src/sha1_lookup.c +3 -2
  165. data/ext/rugged/vendor/libgit2-dist/src/sha1_lookup.h +1 -1
  166. data/ext/rugged/vendor/libgit2-dist/src/signature.c +69 -80
  167. data/ext/rugged/vendor/libgit2-dist/src/signature.h +1 -1
  168. data/ext/rugged/vendor/libgit2-dist/src/status.c +184 -638
  169. data/ext/rugged/vendor/libgit2-dist/src/strmap.h +64 -0
  170. data/ext/rugged/vendor/libgit2-dist/src/submodule.c +387 -0
  171. data/ext/rugged/vendor/libgit2-dist/src/tag.c +162 -137
  172. data/ext/rugged/vendor/libgit2-dist/src/tag.h +2 -1
  173. data/ext/rugged/vendor/libgit2-dist/src/thread-utils.c +1 -1
  174. data/ext/rugged/vendor/libgit2-dist/src/thread-utils.h +8 -8
  175. data/ext/rugged/vendor/libgit2-dist/src/transport.c +31 -19
  176. data/ext/rugged/vendor/libgit2-dist/src/transport.h +31 -11
  177. data/ext/rugged/vendor/libgit2-dist/src/transports/git.c +168 -193
  178. data/ext/rugged/vendor/libgit2-dist/src/transports/http.c +192 -241
  179. data/ext/rugged/vendor/libgit2-dist/src/transports/local.c +92 -86
  180. data/ext/rugged/vendor/libgit2-dist/src/tree-cache.c +32 -49
  181. data/ext/rugged/vendor/libgit2-dist/src/tree-cache.h +1 -1
  182. data/ext/rugged/vendor/libgit2-dist/src/tree.c +172 -145
  183. data/ext/rugged/vendor/libgit2-dist/src/tree.h +16 -2
  184. data/ext/rugged/vendor/libgit2-dist/src/tsort.c +16 -14
  185. data/ext/rugged/vendor/libgit2-dist/src/unix/map.c +8 -24
  186. data/ext/rugged/vendor/libgit2-dist/src/unix/posix.h +9 -3
  187. data/ext/rugged/vendor/libgit2-dist/src/util.c +94 -38
  188. data/ext/rugged/vendor/libgit2-dist/src/util.h +119 -13
  189. data/ext/rugged/vendor/libgit2-dist/src/vector.c +84 -31
  190. data/ext/rugged/vendor/libgit2-dist/src/vector.h +37 -4
  191. data/ext/rugged/vendor/libgit2-dist/src/win32/dir.c +81 -41
  192. data/ext/rugged/vendor/libgit2-dist/src/{dir.h → win32/dir.h} +4 -9
  193. data/ext/rugged/vendor/libgit2-dist/src/win32/map.c +19 -35
  194. data/ext/rugged/vendor/libgit2-dist/src/win32/mingw-compat.h +1 -1
  195. data/ext/rugged/vendor/libgit2-dist/src/win32/msvc-compat.h +5 -1
  196. data/ext/rugged/vendor/libgit2-dist/src/win32/posix.h +10 -8
  197. data/ext/rugged/vendor/libgit2-dist/src/win32/posix_w32.c +262 -118
  198. data/ext/rugged/vendor/libgit2-dist/src/win32/pthread.c +12 -9
  199. data/ext/rugged/vendor/libgit2-dist/src/win32/pthread.h +1 -1
  200. data/ext/rugged/vendor/libgit2-dist/src/win32/utf-conv.c +30 -26
  201. data/ext/rugged/vendor/libgit2-dist/src/win32/utf-conv.h +2 -1
  202. data/ext/rugged/vendor/libgit2-dist/src/xdiff/xdiff.h +135 -0
  203. data/ext/rugged/vendor/libgit2-dist/src/xdiff/xdiffi.c +572 -0
  204. data/ext/rugged/vendor/libgit2-dist/src/xdiff/xdiffi.h +63 -0
  205. data/ext/rugged/vendor/libgit2-dist/src/xdiff/xemit.c +253 -0
  206. data/ext/rugged/vendor/libgit2-dist/src/xdiff/xemit.h +36 -0
  207. data/ext/rugged/vendor/libgit2-dist/src/xdiff/xhistogram.c +371 -0
  208. data/ext/rugged/vendor/libgit2-dist/src/xdiff/xinclude.h +46 -0
  209. data/ext/rugged/vendor/libgit2-dist/src/xdiff/xmacros.h +54 -0
  210. data/ext/rugged/vendor/libgit2-dist/src/xdiff/xmerge.c +619 -0
  211. data/ext/rugged/vendor/libgit2-dist/src/xdiff/xpatience.c +358 -0
  212. data/ext/rugged/vendor/libgit2-dist/src/xdiff/xprepare.c +483 -0
  213. data/ext/rugged/vendor/libgit2-dist/src/xdiff/xprepare.h +34 -0
  214. data/ext/rugged/vendor/libgit2-dist/src/xdiff/xtypes.h +67 -0
  215. data/ext/rugged/vendor/libgit2-dist/src/xdiff/xutils.c +419 -0
  216. data/ext/rugged/vendor/libgit2-dist/src/xdiff/xutils.h +49 -0
  217. data/ext/rugged/vendor/libgit2-dist/tests-clar/attr/attr_expect.h +43 -0
  218. data/ext/rugged/vendor/libgit2-dist/tests-clar/attr/file.c +226 -0
  219. data/ext/rugged/vendor/libgit2-dist/tests-clar/attr/flags.c +108 -0
  220. data/ext/rugged/vendor/libgit2-dist/tests-clar/attr/lookup.c +262 -0
  221. data/ext/rugged/vendor/libgit2-dist/tests-clar/attr/repo.c +273 -0
  222. data/ext/rugged/vendor/libgit2-dist/{tests-clay → tests-clar}/buf/basic.c +5 -5
  223. data/ext/rugged/vendor/libgit2-dist/tests-clar/clar_helpers.c +181 -0
  224. data/ext/rugged/vendor/libgit2-dist/tests-clar/clar_libgit2.h +55 -0
  225. data/ext/rugged/vendor/libgit2-dist/tests-clar/commit/commit.c +44 -0
  226. data/ext/rugged/vendor/libgit2-dist/tests-clar/commit/parse.c +350 -0
  227. data/ext/rugged/vendor/libgit2-dist/tests-clar/commit/signature.c +65 -0
  228. data/ext/rugged/vendor/libgit2-dist/tests-clar/commit/write.c +140 -0
  229. data/ext/rugged/vendor/libgit2-dist/{tests-clay → tests-clar}/config/add.c +3 -3
  230. data/ext/rugged/vendor/libgit2-dist/tests-clar/config/multivar.c +151 -0
  231. data/ext/rugged/vendor/libgit2-dist/{tests-clay → tests-clar}/config/new.c +5 -5
  232. data/ext/rugged/vendor/libgit2-dist/{tests-clay → tests-clar}/config/read.c +44 -32
  233. data/ext/rugged/vendor/libgit2-dist/tests-clar/config/stress.c +61 -0
  234. data/ext/rugged/vendor/libgit2-dist/{tests-clay → tests-clar}/config/write.c +20 -5
  235. data/ext/rugged/vendor/libgit2-dist/tests-clar/core/buffer.c +613 -0
  236. data/ext/rugged/vendor/libgit2-dist/{tests-clay → tests-clar}/core/dirent.c +39 -26
  237. data/ext/rugged/vendor/libgit2-dist/tests-clar/core/env.c +115 -0
  238. data/ext/rugged/vendor/libgit2-dist/tests-clar/core/errors.c +60 -0
  239. data/ext/rugged/vendor/libgit2-dist/{tests-clay → tests-clar}/core/filebuf.c +4 -18
  240. data/ext/rugged/vendor/libgit2-dist/tests-clar/core/hex.c +22 -0
  241. data/ext/rugged/vendor/libgit2-dist/{tests-clay → tests-clar}/core/oid.c +6 -6
  242. data/ext/rugged/vendor/libgit2-dist/tests-clar/core/path.c +420 -0
  243. data/ext/rugged/vendor/libgit2-dist/tests-clar/core/pool.c +85 -0
  244. data/ext/rugged/vendor/libgit2-dist/tests-clar/core/rmdir.c +68 -0
  245. data/ext/rugged/vendor/libgit2-dist/{tests-clay → tests-clar}/core/string.c +1 -1
  246. data/ext/rugged/vendor/libgit2-dist/tests-clar/core/strmap.c +102 -0
  247. data/ext/rugged/vendor/libgit2-dist/{tests-clay → tests-clar}/core/strtol.c +1 -1
  248. data/ext/rugged/vendor/libgit2-dist/tests-clar/core/vector.c +191 -0
  249. data/ext/rugged/vendor/libgit2-dist/tests-clar/date/date.c +15 -0
  250. data/ext/rugged/vendor/libgit2-dist/tests-clar/diff/blob.c +254 -0
  251. data/ext/rugged/vendor/libgit2-dist/tests-clar/diff/diff_helpers.c +104 -0
  252. data/ext/rugged/vendor/libgit2-dist/tests-clar/diff/diff_helpers.h +47 -0
  253. data/ext/rugged/vendor/libgit2-dist/tests-clar/diff/index.c +92 -0
  254. data/ext/rugged/vendor/libgit2-dist/tests-clar/diff/iterator.c +572 -0
  255. data/ext/rugged/vendor/libgit2-dist/tests-clar/diff/patch.c +99 -0
  256. data/ext/rugged/vendor/libgit2-dist/tests-clar/diff/tree.c +210 -0
  257. data/ext/rugged/vendor/libgit2-dist/tests-clar/diff/workdir.c +543 -0
  258. data/ext/rugged/vendor/libgit2-dist/tests-clar/index/read_tree.c +46 -0
  259. data/ext/rugged/vendor/libgit2-dist/{tests-clay → tests-clar}/index/rename.c +2 -12
  260. data/ext/rugged/vendor/libgit2-dist/tests-clar/index/tests.c +246 -0
  261. data/ext/rugged/vendor/libgit2-dist/tests-clar/network/createremotethenload.c +33 -0
  262. data/ext/rugged/vendor/libgit2-dist/tests-clar/network/remotelocal.c +137 -0
  263. data/ext/rugged/vendor/libgit2-dist/tests-clar/network/remotes.c +183 -0
  264. data/ext/rugged/vendor/libgit2-dist/tests-clar/notes/notes.c +133 -0
  265. data/ext/rugged/vendor/libgit2-dist/tests-clar/notes/notesref.c +57 -0
  266. data/ext/rugged/vendor/libgit2-dist/tests-clar/object/blob/filter.c +125 -0
  267. data/ext/rugged/vendor/libgit2-dist/tests-clar/object/blob/fromchunks.c +87 -0
  268. data/ext/rugged/vendor/libgit2-dist/tests-clar/object/blob/write.c +69 -0
  269. data/ext/rugged/vendor/libgit2-dist/tests-clar/object/commit/commitstagedfile.c +126 -0
  270. data/ext/rugged/vendor/libgit2-dist/tests-clar/object/lookup.c +63 -0
  271. data/ext/rugged/vendor/libgit2-dist/tests-clar/object/message.c +171 -0
  272. data/ext/rugged/vendor/libgit2-dist/{tests-clay → tests-clar}/object/raw/chars.c +3 -14
  273. data/ext/rugged/vendor/libgit2-dist/{tests-clay → tests-clar}/object/raw/compare.c +4 -4
  274. data/ext/rugged/vendor/libgit2-dist/{tests-clay → tests-clar}/object/raw/convert.c +10 -10
  275. data/ext/rugged/vendor/libgit2-dist/{tests-clay → tests-clar}/object/raw/data.h +0 -0
  276. data/ext/rugged/vendor/libgit2-dist/{tests-clay → tests-clar}/object/raw/fromstr.c +1 -1
  277. data/ext/rugged/vendor/libgit2-dist/{tests-clay → tests-clar}/object/raw/hash.c +21 -17
  278. data/ext/rugged/vendor/libgit2-dist/{tests-clay → tests-clar}/object/raw/short.c +1 -1
  279. data/ext/rugged/vendor/libgit2-dist/{tests-clay → tests-clar}/object/raw/size.c +1 -1
  280. data/ext/rugged/vendor/libgit2-dist/{tests-clay → tests-clar}/object/raw/type2string.c +14 -14
  281. data/ext/rugged/vendor/libgit2-dist/tests-clar/object/raw/write.c +455 -0
  282. data/ext/rugged/vendor/libgit2-dist/tests-clar/object/tag/peel.c +56 -0
  283. data/ext/rugged/vendor/libgit2-dist/tests-clar/object/tag/read.c +130 -0
  284. data/ext/rugged/vendor/libgit2-dist/tests-clar/object/tag/write.c +192 -0
  285. data/ext/rugged/vendor/libgit2-dist/{tests-clay → tests-clar}/object/tree/frompath.c +22 -16
  286. data/ext/rugged/vendor/libgit2-dist/tests-clar/object/tree/read.c +75 -0
  287. data/ext/rugged/vendor/libgit2-dist/tests-clar/object/tree/write.c +84 -0
  288. data/ext/rugged/vendor/libgit2-dist/{tests-clay → tests-clar}/odb/loose.c +1 -1
  289. data/ext/rugged/vendor/libgit2-dist/{tests-clay → tests-clar}/odb/loose_data.h +0 -0
  290. data/ext/rugged/vendor/libgit2-dist/tests-clar/odb/mixed.c +24 -0
  291. data/ext/rugged/vendor/libgit2-dist/{tests-clay → tests-clar}/odb/pack_data.h +0 -0
  292. data/ext/rugged/vendor/libgit2-dist/{tests-clay → tests-clar}/odb/packed.c +1 -1
  293. data/ext/rugged/vendor/libgit2-dist/{tests-clay → tests-clar}/odb/sorting.c +1 -1
  294. data/ext/rugged/vendor/libgit2-dist/tests-clar/refs/branches/create.c +113 -0
  295. data/ext/rugged/vendor/libgit2-dist/tests-clar/refs/branches/delete.c +91 -0
  296. data/ext/rugged/vendor/libgit2-dist/tests-clar/refs/branches/listall.c +78 -0
  297. data/ext/rugged/vendor/libgit2-dist/tests-clar/refs/branches/move.c +72 -0
  298. data/ext/rugged/vendor/libgit2-dist/tests-clar/refs/crashes.c +17 -0
  299. data/ext/rugged/vendor/libgit2-dist/tests-clar/refs/create.c +149 -0
  300. data/ext/rugged/vendor/libgit2-dist/tests-clar/refs/delete.c +85 -0
  301. data/ext/rugged/vendor/libgit2-dist/tests-clar/refs/list.c +53 -0
  302. data/ext/rugged/vendor/libgit2-dist/tests-clar/refs/listall.c +36 -0
  303. data/ext/rugged/vendor/libgit2-dist/tests-clar/refs/lookup.c +42 -0
  304. data/ext/rugged/vendor/libgit2-dist/tests-clar/refs/normalize.c +200 -0
  305. data/ext/rugged/vendor/libgit2-dist/tests-clar/refs/overwrite.c +136 -0
  306. data/ext/rugged/vendor/libgit2-dist/tests-clar/refs/pack.c +67 -0
  307. data/ext/rugged/vendor/libgit2-dist/tests-clar/refs/read.c +194 -0
  308. data/ext/rugged/vendor/libgit2-dist/tests-clar/refs/reflog.c +123 -0
  309. data/ext/rugged/vendor/libgit2-dist/tests-clar/refs/rename.c +339 -0
  310. data/ext/rugged/vendor/libgit2-dist/tests-clar/refs/revparse.c +174 -0
  311. data/ext/rugged/vendor/libgit2-dist/tests-clar/refs/unicode.c +42 -0
  312. data/ext/rugged/vendor/libgit2-dist/tests-clar/repo/discover.c +142 -0
  313. data/ext/rugged/vendor/libgit2-dist/{tests-clay → tests-clar}/repo/getters.c +19 -1
  314. data/ext/rugged/vendor/libgit2-dist/tests-clar/repo/init.c +235 -0
  315. data/ext/rugged/vendor/libgit2-dist/tests-clar/repo/open.c +282 -0
  316. data/ext/rugged/vendor/libgit2-dist/tests-clar/repo/setters.c +80 -0
  317. data/ext/rugged/vendor/libgit2-dist/tests-clar/reset/mixed.c +47 -0
  318. data/ext/rugged/vendor/libgit2-dist/tests-clar/reset/reset_helpers.c +10 -0
  319. data/ext/rugged/vendor/libgit2-dist/tests-clar/reset/reset_helpers.h +6 -0
  320. data/ext/rugged/vendor/libgit2-dist/tests-clar/reset/soft.c +102 -0
  321. data/ext/rugged/vendor/libgit2-dist/{tests/t05-revwalk.c → tests-clar/revwalk/basic.c} +85 -44
  322. data/ext/rugged/vendor/libgit2-dist/tests-clar/revwalk/mergebase.c +148 -0
  323. data/ext/rugged/vendor/libgit2-dist/tests-clar/status/ignore.c +133 -0
  324. data/ext/rugged/vendor/libgit2-dist/{tests-clay → tests-clar}/status/single.c +2 -11
  325. data/ext/rugged/vendor/libgit2-dist/tests-clar/status/status_data.h +202 -0
  326. data/ext/rugged/vendor/libgit2-dist/tests-clar/status/status_helpers.c +49 -0
  327. data/ext/rugged/vendor/libgit2-dist/tests-clar/status/status_helpers.h +33 -0
  328. data/ext/rugged/vendor/libgit2-dist/tests-clar/status/submodules.c +112 -0
  329. data/ext/rugged/vendor/libgit2-dist/tests-clar/status/worktree.c +649 -0
  330. data/ext/rugged/vendor/libgit2-dist/tests-clar/threads/basic.c +20 -0
  331. data/ext/rugged/vendor/libgit2-dist.tar.gz +0 -0
  332. data/lib/rugged/commit.rb +35 -0
  333. data/lib/rugged/object.rb +7 -0
  334. data/lib/rugged/reference.rb +9 -0
  335. data/lib/rugged/repository.rb +99 -3
  336. data/lib/rugged/tag.rb +22 -0
  337. data/lib/rugged/tree.rb +8 -0
  338. data/lib/rugged/version.rb +1 -1
  339. data/lib/rugged.rb +4 -1
  340. data/test/blob_test.rb +2 -2
  341. data/test/commit_test.rb +27 -13
  342. data/test/config_test.rb +44 -0
  343. data/test/coverage/HEAD.json +1 -1
  344. data/test/fixtures/testrepo.git/config +2 -0
  345. data/test/fixtures/testrepo.git/objects/7f/043268ea43ce18e3540acaabf9e090c91965b0 +0 -0
  346. data/test/lib_test.rb +7 -0
  347. data/test/object_test.rb +3 -3
  348. data/test/reference_test.rb +46 -8
  349. data/test/remote_test.rb +8 -2
  350. data/test/repo_pack_test.rb +3 -3
  351. data/test/repo_test.rb +79 -11
  352. data/test/tag_test.rb +9 -2
  353. data/test/test_helper.rb +21 -0
  354. data/test/tree_test.rb +18 -6
  355. metadata +205 -81
  356. data/ext/rugged/vendor/libgit2-dist/include/git2/zlib.h +0 -40
  357. data/ext/rugged/vendor/libgit2-dist/src/hashtable.c +0 -243
  358. data/ext/rugged/vendor/libgit2-dist/src/hashtable.h +0 -80
  359. data/ext/rugged/vendor/libgit2-dist/tests/t00-core.c +0 -628
  360. data/ext/rugged/vendor/libgit2-dist/tests/t01-data.h +0 -322
  361. data/ext/rugged/vendor/libgit2-dist/tests/t01-rawobj.c +0 -638
  362. data/ext/rugged/vendor/libgit2-dist/tests/t03-data.h +0 -344
  363. data/ext/rugged/vendor/libgit2-dist/tests/t03-objwrite.c +0 -255
  364. data/ext/rugged/vendor/libgit2-dist/tests/t04-commit.c +0 -788
  365. data/ext/rugged/vendor/libgit2-dist/tests/t06-index.c +0 -219
  366. data/ext/rugged/vendor/libgit2-dist/tests/t07-hashtable.c +0 -192
  367. data/ext/rugged/vendor/libgit2-dist/tests/t08-tag.c +0 -357
  368. data/ext/rugged/vendor/libgit2-dist/tests/t09-tree.c +0 -221
  369. data/ext/rugged/vendor/libgit2-dist/tests/t10-refs.c +0 -1294
  370. data/ext/rugged/vendor/libgit2-dist/tests/t12-repo.c +0 -174
  371. data/ext/rugged/vendor/libgit2-dist/tests/t13-threads.c +0 -41
  372. data/ext/rugged/vendor/libgit2-dist/tests/t17-bufs.c +0 -61
  373. data/ext/rugged/vendor/libgit2-dist/tests/t18-status.c +0 -448
  374. data/ext/rugged/vendor/libgit2-dist/tests/test_helpers.c +0 -310
  375. data/ext/rugged/vendor/libgit2-dist/tests/test_helpers.h +0 -83
  376. data/ext/rugged/vendor/libgit2-dist/tests/test_lib.c +0 -198
  377. data/ext/rugged/vendor/libgit2-dist/tests/test_lib.h +0 -54
  378. data/ext/rugged/vendor/libgit2-dist/tests/test_main.c +0 -89
  379. data/ext/rugged/vendor/libgit2-dist/tests-clay/clay.h +0 -187
  380. data/ext/rugged/vendor/libgit2-dist/tests-clay/clay_libgit2.h +0 -28
  381. data/ext/rugged/vendor/libgit2-dist/tests-clay/clay_main.c +0 -1073
  382. data/ext/rugged/vendor/libgit2-dist/tests-clay/config/stress.c +0 -39
  383. data/ext/rugged/vendor/libgit2-dist/tests-clay/core/path.c +0 -139
  384. data/ext/rugged/vendor/libgit2-dist/tests-clay/core/rmdir.c +0 -50
  385. data/ext/rugged/vendor/libgit2-dist/tests-clay/core/vector.c +0 -66
  386. data/ext/rugged/vendor/libgit2-dist/tests-clay/network/remotes.c +0 -50
  387. data/ext/rugged/vendor/libgit2-dist/tests-clay/repo/init.c +0 -104
  388. data/ext/rugged/vendor/libgit2-dist/tests-clay/repo/open.c +0 -54
  389. data/ext/rugged/vendor/libgit2-dist/tests-clay/status/status_data.h +0 -48
  390. data/ext/rugged/vendor/libgit2-dist/tests-clay/status/worktree.c +0 -124
  391. data/lib/rugged/objects.rb +0 -45
  392. data/test/fixtures/testrepo.git/refs/heads/new_name +0 -1
@@ -1,5 +1,5 @@
1
1
  /*
2
- * Copyright (C) 2009-2011 the libgit2 contributors
2
+ * Copyright (C) 2009-2012 the libgit2 contributors
3
3
  *
4
4
  * This file is part of libgit2, distributed under the GNU GPL v2 with
5
5
  * a Linking Exception. For full terms see the included COPYING file.
@@ -8,7 +8,15 @@
8
8
  #define INCLUDE_transport_h__
9
9
 
10
10
  #include "git2/net.h"
11
+ #include "git2/indexer.h"
11
12
  #include "vector.h"
13
+ #include "posix.h"
14
+ #include "common.h"
15
+ #ifdef GIT_SSL
16
+ # include <openssl/ssl.h>
17
+ # include <openssl/err.h>
18
+ #endif
19
+
12
20
 
13
21
  #define GIT_CAP_OFS_DELTA "ofs-delta"
14
22
 
@@ -17,6 +25,14 @@ typedef struct git_transport_caps {
17
25
  ofs_delta:1;
18
26
  } git_transport_caps;
19
27
 
28
+ #ifdef GIT_SSL
29
+ typedef struct gitno_ssl {
30
+ SSL_CTX *ctx;
31
+ SSL *ssl;
32
+ } gitno_ssl;
33
+ #endif
34
+
35
+
20
36
  /*
21
37
  * A day in the life of a network operation
22
38
  * ========================================
@@ -52,7 +68,13 @@ struct git_transport {
52
68
  * Whether we want to push or fetch
53
69
  */
54
70
  int direction : 1, /* 0 fetch, 1 push */
55
- connected : 1;
71
+ connected : 1,
72
+ check_cert: 1,
73
+ encrypt : 1;
74
+ #ifdef GIT_SSL
75
+ struct gitno_ssl ssl;
76
+ #endif
77
+ GIT_SOCKET socket;
56
78
  /**
57
79
  * Connect and store the remote heads
58
80
  */
@@ -65,23 +87,15 @@ struct git_transport {
65
87
  * Push the changes over
66
88
  */
67
89
  int (*push)(struct git_transport *transport);
68
- /**
69
- * Send a 'done' message
70
- */
71
- int (*send_done)(struct git_transport *transport);
72
90
  /**
73
91
  * Negotiate the minimal amount of objects that need to be
74
92
  * retrieved
75
93
  */
76
94
  int (*negotiate_fetch)(struct git_transport *transport, git_repository *repo, const git_vector *wants);
77
- /**
78
- * Send a flush
79
- */
80
- int (*send_flush)(struct git_transport *transport);
81
95
  /**
82
96
  * Download the packfile
83
97
  */
84
- int (*download_pack)(char **out, struct git_transport *transport, git_repository *repo);
98
+ int (*download_pack)(struct git_transport *transport, git_repository *repo, git_off_t *bytes, git_indexer_stats *stats);
85
99
  /**
86
100
  * Fetch the changes
87
101
  */
@@ -101,7 +115,13 @@ int git_transport_new(struct git_transport **transport, const char *url);
101
115
  int git_transport_local(struct git_transport **transport);
102
116
  int git_transport_git(struct git_transport **transport);
103
117
  int git_transport_http(struct git_transport **transport);
118
+ int git_transport_https(struct git_transport **transport);
104
119
  int git_transport_dummy(struct git_transport **transport);
120
+
121
+ /**
122
+ Returns true if the passed URL is valid (a URL with a Git supported scheme,
123
+ or pointing to an existing path)
124
+ */
105
125
  int git_transport_valid_url(const char *url);
106
126
 
107
127
  typedef struct git_transport git_transport;
@@ -1,5 +1,5 @@
1
1
  /*
2
- * Copyright (C) 2009-2011 the libgit2 contributors
2
+ * Copyright (C) 2009-2012 the libgit2 contributors
3
3
  *
4
4
  * This file is part of libgit2, distributed under the GNU GPL v2 with
5
5
  * a Linking Exception. For full terms see the included COPYING file.
@@ -25,7 +25,6 @@
25
25
  typedef struct {
26
26
  git_transport parent;
27
27
  git_protocol proto;
28
- GIT_SOCKET socket;
29
28
  git_vector refs;
30
29
  git_remote_head **heads;
31
30
  git_transport_caps caps;
@@ -46,11 +45,13 @@ static int gen_proto(git_buf *request, const char *cmd, const char *url)
46
45
  char *delim, *repo;
47
46
  char default_command[] = "git-upload-pack";
48
47
  char host[] = "host=";
49
- int len;
48
+ size_t len;
50
49
 
51
50
  delim = strchr(url, '/');
52
- if (delim == NULL)
53
- return git__throw(GIT_EOBJCORRUPTED, "Failed to create proto-request: malformed URL");
51
+ if (delim == NULL) {
52
+ giterr_set(GITERR_NET, "Malformed URL");
53
+ return -1;
54
+ }
54
55
 
55
56
  repo = delim;
56
57
 
@@ -64,23 +65,27 @@ static int gen_proto(git_buf *request, const char *cmd, const char *url)
64
65
  len = 4 + strlen(cmd) + 1 + strlen(repo) + 1 + strlen(host) + (delim - url) + 1;
65
66
 
66
67
  git_buf_grow(request, len);
67
- git_buf_printf(request, "%04x%s %s%c%s", len, cmd, repo, 0, host);
68
+ git_buf_printf(request, "%04x%s %s%c%s",
69
+ (unsigned int)(len & 0x0FFFF), cmd, repo, 0, host);
68
70
  git_buf_put(request, url, delim - url);
69
71
  git_buf_putc(request, '\0');
70
72
 
71
- return git_buf_oom(request);
73
+ if (git_buf_oom(request))
74
+ return -1;
75
+
76
+ return 0;
72
77
  }
73
78
 
74
- static int send_request(GIT_SOCKET s, const char *cmd, const char *url)
79
+ static int send_request(git_transport *t, const char *cmd, const char *url)
75
80
  {
76
81
  int error;
77
82
  git_buf request = GIT_BUF_INIT;
78
83
 
79
84
  error = gen_proto(&request, cmd, url);
80
- if (error < GIT_SUCCESS)
85
+ if (error < 0)
81
86
  goto cleanup;
82
87
 
83
- error = gitno_send(s, request.ptr, request.size, 0);
88
+ error = gitno_send(t, request.ptr, request.size, 0);
84
89
 
85
90
  cleanup:
86
91
  git_buf_free(&request);
@@ -94,32 +99,31 @@ cleanup:
94
99
  */
95
100
  static int do_connect(transport_git *t, const char *url)
96
101
  {
97
- GIT_SOCKET s;
98
102
  char *host, *port;
99
103
  const char prefix[] = "git://";
100
- int error, connected = 0;
101
104
 
102
105
  if (!git__prefixcmp(url, prefix))
103
106
  url += strlen(prefix);
104
107
 
105
- error = gitno_extract_host_and_port(&host, &port, url, GIT_DEFAULT_PORT);
106
- if (error < GIT_SUCCESS)
107
- return error;
108
+ if (gitno_extract_host_and_port(&host, &port, url, GIT_DEFAULT_PORT) < 0)
109
+ return -1;
110
+
111
+ if (gitno_connect((git_transport *)t, host, port) < 0)
112
+ goto on_error;
108
113
 
109
- s = gitno_connect(host, port);
110
- connected = 1;
111
- error = send_request(s, NULL, url);
112
- t->socket = s;
114
+ if (send_request((git_transport *)t, NULL, url) < 0)
115
+ goto on_error;
113
116
 
114
117
  git__free(host);
115
118
  git__free(port);
116
119
 
117
- if (error < GIT_SUCCESS && s > 0)
118
- close(s);
119
- if (!connected)
120
- error = git__throw(GIT_EOSERR, "Failed to connect to any of the addresses");
120
+ return 0;
121
121
 
122
- return error;
122
+ on_error:
123
+ git__free(host);
124
+ git__free(port);
125
+ gitno_close(t->parent.socket);
126
+ return -1;
123
127
  }
124
128
 
125
129
  /*
@@ -128,33 +132,30 @@ static int do_connect(transport_git *t, const char *url)
128
132
  static int store_refs(transport_git *t)
129
133
  {
130
134
  gitno_buffer *buf = &t->buf;
131
- int error = GIT_SUCCESS;
135
+ int ret = 0;
132
136
 
133
137
  while (1) {
134
- error = gitno_recv(buf);
135
- if (error < GIT_SUCCESS)
136
- return git__rethrow(GIT_EOSERR, "Failed to receive data");
137
- if (error == GIT_SUCCESS) /* Orderly shutdown, so exit */
138
- return GIT_SUCCESS;
139
-
140
- error = git_protocol_store_refs(&t->proto, buf->data, buf->offset);
141
- if (error == GIT_ESHORTBUFFER) {
138
+ if ((ret = gitno_recv(buf)) < 0)
139
+ return -1;
140
+ if (ret == 0) /* Orderly shutdown, so exit */
141
+ return 0;
142
+
143
+ ret = git_protocol_store_refs(&t->proto, buf->data, buf->offset);
144
+ if (ret == GIT_EBUFS) {
142
145
  gitno_consume_n(buf, buf->len);
143
146
  continue;
144
147
  }
145
148
 
146
- if (error < GIT_SUCCESS)
147
- return git__rethrow(error, "Failed to store refs");
149
+ if (ret < 0)
150
+ return ret;
148
151
 
149
152
  gitno_consume_n(buf, buf->offset);
150
153
 
151
154
  if (t->proto.flush) { /* No more refs */
152
155
  t->proto.flush = 0;
153
- return GIT_SUCCESS;
156
+ return 0;
154
157
  }
155
158
  }
156
-
157
- return error;
158
159
  }
159
160
 
160
161
  static int detect_caps(transport_git *t)
@@ -167,7 +168,7 @@ static int detect_caps(transport_git *t)
167
168
  pkt = git_vector_get(refs, 0);
168
169
  /* No refs or capabilites, odd but not a problem */
169
170
  if (pkt == NULL || pkt->capabilities == NULL)
170
- return GIT_SUCCESS;
171
+ return 0;
171
172
 
172
173
  ptr = pkt->capabilities;
173
174
  while (ptr != NULL && *ptr != '\0') {
@@ -184,7 +185,7 @@ static int detect_caps(transport_git *t)
184
185
  ptr = strchr(ptr, ' ');
185
186
  }
186
187
 
187
- return GIT_SUCCESS;
188
+ return 0;
188
189
  }
189
190
 
190
191
  /*
@@ -194,36 +195,33 @@ static int detect_caps(transport_git *t)
194
195
  static int git_connect(git_transport *transport, int direction)
195
196
  {
196
197
  transport_git *t = (transport_git *) transport;
197
- int error = GIT_SUCCESS;
198
198
 
199
- if (direction == GIT_DIR_PUSH)
200
- return git__throw(GIT_EINVALIDARGS, "Pushing is not supported with the git protocol");
199
+ if (direction == GIT_DIR_PUSH) {
200
+ giterr_set(GITERR_NET, "Pushing over git:// is not supported");
201
+ return -1;
202
+ }
201
203
 
202
204
  t->parent.direction = direction;
203
- error = git_vector_init(&t->refs, 16, NULL);
204
- if (error < GIT_SUCCESS)
205
- goto cleanup;
205
+ if (git_vector_init(&t->refs, 16, NULL) < 0)
206
+ return -1;
206
207
 
207
208
  /* Connect and ask for the refs */
208
- error = do_connect(t, transport->url);
209
- if (error < GIT_SUCCESS)
210
- return error;
209
+ if (do_connect(t, transport->url) < 0)
210
+ goto cleanup;
211
211
 
212
- gitno_buffer_setup(&t->buf, t->buff, sizeof(t->buff), t->socket);
212
+ gitno_buffer_setup(transport, &t->buf, t->buff, sizeof(t->buff));
213
213
 
214
214
  t->parent.connected = 1;
215
- error = store_refs(t);
216
- if (error < GIT_SUCCESS)
217
- return error;
215
+ if (store_refs(t) < 0)
216
+ goto cleanup;
218
217
 
219
- error = detect_caps(t);
218
+ if (detect_caps(t) < 0)
219
+ goto cleanup;
220
220
 
221
+ return 0;
221
222
  cleanup:
222
- if (error < GIT_SUCCESS) {
223
- git_vector_free(&t->refs);
224
- }
225
-
226
- return error;
223
+ git_vector_free(&t->refs);
224
+ return -1;
227
225
  }
228
226
 
229
227
  static int git_ls(git_transport *transport, git_headlist_cb list_cb, void *opaque)
@@ -241,149 +239,129 @@ static int git_ls(git_transport *transport, git_headlist_cb list_cb, void *opaqu
241
239
 
242
240
  pkt = (git_pkt_ref *)p;
243
241
 
244
- if (list_cb(&pkt->head, opaque) < 0)
245
- return git__throw(GIT_ERROR,
246
- "The user callback returned an error code");
242
+ if (list_cb(&pkt->head, opaque) < 0) {
243
+ giterr_set(GITERR_NET, "User callback returned error");
244
+ return -1;
245
+ }
247
246
  }
248
247
 
249
- return GIT_SUCCESS;
248
+ return 0;
249
+ }
250
+
251
+ /* Wait until we get an ack from the */
252
+ static int recv_pkt(gitno_buffer *buf)
253
+ {
254
+ const char *ptr = buf->data, *line_end;
255
+ git_pkt *pkt;
256
+ int pkt_type, error;
257
+
258
+ do {
259
+ /* Wait for max. 1 second */
260
+ if ((error = gitno_select_in(buf, 1, 0)) < 0) {
261
+ return -1;
262
+ } else if (error == 0) {
263
+ /*
264
+ * Some servers don't respond immediately, so if this
265
+ * happens, we keep sending information until it
266
+ * answers. Pretend we received a NAK to convince higher
267
+ * layers to do so.
268
+ */
269
+ return GIT_PKT_NAK;
270
+ }
271
+
272
+ if ((error = gitno_recv(buf)) < 0)
273
+ return -1;
274
+
275
+ error = git_pkt_parse_line(&pkt, ptr, &line_end, buf->offset);
276
+ if (error == GIT_EBUFS)
277
+ continue;
278
+ if (error < 0)
279
+ return -1;
280
+ } while (error);
281
+
282
+ gitno_consume(buf, line_end);
283
+ pkt_type = pkt->type;
284
+ git__free(pkt);
285
+
286
+ return pkt_type;
250
287
  }
251
288
 
252
289
  static int git_negotiate_fetch(git_transport *transport, git_repository *repo, const git_vector *wants)
253
290
  {
254
291
  transport_git *t = (transport_git *) transport;
255
292
  git_revwalk *walk;
256
- git_reference *ref;
257
- git_strarray refs;
258
293
  git_oid oid;
259
294
  int error;
260
295
  unsigned int i;
296
+ git_buf data = GIT_BUF_INIT;
261
297
  gitno_buffer *buf = &t->buf;
262
298
 
263
- error = git_pkt_send_wants(wants, &t->caps, t->socket);
264
- if (error < GIT_SUCCESS)
265
- return git__rethrow(error, "Failed to send wants list");
266
-
267
- error = git_reference_listall(&refs, repo, GIT_REF_LISTALL);
268
- if (error < GIT_ERROR)
269
- return git__rethrow(error, "Failed to list all references");
299
+ if (git_pkt_buffer_wants(wants, &t->caps, &data) < 0)
300
+ return -1;
270
301
 
271
- error = git_revwalk_new(&walk, repo);
272
- if (error < GIT_ERROR) {
273
- error = git__rethrow(error, "Failed to list all references");
274
- goto cleanup;
275
- }
276
- git_revwalk_sorting(walk, GIT_SORT_TIME);
302
+ if (git_fetch_setup_walk(&walk, repo) < 0)
303
+ goto on_error;
277
304
 
278
- for (i = 0; i < refs.count; ++i) {
279
- /* No tags */
280
- if (!git__prefixcmp(refs.strings[i], GIT_REFS_TAGS_DIR))
281
- continue;
282
-
283
- error = git_reference_lookup(&ref, repo, refs.strings[i]);
284
- if (error < GIT_ERROR) {
285
- error = git__rethrow(error, "Failed to lookup %s", refs.strings[i]);
286
- goto cleanup;
287
- }
288
-
289
- if (git_reference_type(ref) == GIT_REF_SYMBOLIC)
290
- continue;
291
-
292
- error = git_revwalk_push(walk, git_reference_oid(ref));
293
- if (error < GIT_ERROR) {
294
- error = git__rethrow(error, "Failed to push %s", refs.strings[i]);
295
- goto cleanup;
296
- }
297
- }
298
- git_strarray_free(&refs);
305
+ if (gitno_send(transport, data.ptr, data.size, 0) < 0)
306
+ goto on_error;
299
307
 
308
+ git_buf_clear(&data);
300
309
  /*
301
310
  * We don't support any kind of ACK extensions, so the negotiation
302
311
  * boils down to sending what we have and listening for an ACK
303
312
  * every once in a while.
304
313
  */
305
314
  i = 0;
306
- while ((error = git_revwalk_next(&oid, walk)) == GIT_SUCCESS) {
307
- error = git_pkt_send_have(&oid, t->socket);
315
+ while ((error = git_revwalk_next(&oid, walk)) == 0) {
316
+ git_pkt_buffer_have(&oid, &data);
308
317
  i++;
309
318
  if (i % 20 == 0) {
310
- const char *ptr = buf->data, *line_end;
311
- git_pkt *pkt;
312
- git_pkt_send_flush(t->socket);
313
- while (1) {
314
- /* Wait for max. 1 second */
315
- error = gitno_select_in(buf, 1, 0);
316
- if (error < GIT_SUCCESS) {
317
- error = git__throw(GIT_EOSERR, "Error in select");
318
- } else if (error == 0) {
319
- /*
320
- * Some servers don't respond immediately, so if this
321
- * happens, we keep sending information until it
322
- * answers.
323
- */
324
- break;
325
- }
326
-
327
- error = gitno_recv(buf);
328
- if (error < GIT_SUCCESS) {
329
- error = git__rethrow(error, "Error receiving data");
330
- goto cleanup;
331
- }
332
- error = git_pkt_parse_line(&pkt, ptr, &line_end, buf->offset);
333
- if (error == GIT_ESHORTBUFFER)
334
- continue;
335
- if (error < GIT_SUCCESS) {
336
- error = git__rethrow(error, "Failed to get answer");
337
- goto cleanup;
338
- }
339
-
340
- gitno_consume(buf, line_end);
341
-
342
- if (pkt->type == GIT_PKT_ACK) {
343
- git__free(pkt);
344
- error = GIT_SUCCESS;
345
- goto done;
346
- } else if (pkt->type == GIT_PKT_NAK) {
347
- git__free(pkt);
348
- break;
349
- } else {
350
- error = git__throw(GIT_ERROR, "Got unexpected pkt type");
351
- goto cleanup;
352
- }
353
- }
354
- }
355
- }
356
- if (error == GIT_EREVWALKOVER)
357
- error = GIT_SUCCESS;
319
+ int pkt_type;
358
320
 
359
- done:
360
- git_pkt_send_flush(t->socket);
361
- git_pkt_send_done(t->socket);
321
+ git_pkt_buffer_flush(&data);
322
+ if (git_buf_oom(&data))
323
+ goto on_error;
362
324
 
363
- cleanup:
364
- git_revwalk_free(walk);
325
+ if (gitno_send(transport, data.ptr, data.size, 0) < 0)
326
+ goto on_error;
365
327
 
366
- return error;
367
- }
328
+ pkt_type = recv_pkt(buf);
368
329
 
369
- static int git_send_flush(git_transport *transport)
370
- {
371
- transport_git *t = (transport_git *) transport;
330
+ if (pkt_type == GIT_PKT_ACK) {
331
+ break;
332
+ } else if (pkt_type == GIT_PKT_NAK) {
333
+ continue;
334
+ } else {
335
+ giterr_set(GITERR_NET, "Unexpected pkt type");
336
+ goto on_error;
337
+ }
372
338
 
373
- return git_pkt_send_flush(t->socket);
374
- }
339
+ }
340
+ }
341
+ if (error < 0 && error != GIT_REVWALKOVER)
342
+ goto on_error;
375
343
 
376
- static int git_send_done(git_transport *transport)
377
- {
378
- transport_git *t = (transport_git *) transport;
344
+ /* Tell the other end that we're done negotiating */
345
+ git_buf_clear(&data);
346
+ git_pkt_buffer_flush(&data);
347
+ git_pkt_buffer_done(&data);
348
+ if (gitno_send(transport, data.ptr, data.size, 0) < 0)
349
+ goto on_error;
379
350
 
380
- return git_pkt_send_done(t->socket);
351
+ git_buf_free(&data);
352
+ git_revwalk_free(walk);
353
+ return 0;
354
+
355
+ on_error:
356
+ git_buf_free(&data);
357
+ git_revwalk_free(walk);
358
+ return -1;
381
359
  }
382
360
 
383
- static int git_download_pack(char **out, git_transport *transport, git_repository *repo)
361
+ static int git_download_pack(git_transport *transport, git_repository *repo, git_off_t *bytes, git_indexer_stats *stats)
384
362
  {
385
363
  transport_git *t = (transport_git *) transport;
386
- int error = GIT_SUCCESS;
364
+ int error = 0, read_bytes;
387
365
  gitno_buffer *buf = &t->buf;
388
366
  git_pkt *pkt;
389
367
  const char *line_end, *ptr;
@@ -391,7 +369,7 @@ static int git_download_pack(char **out, git_transport *transport, git_repositor
391
369
  /*
392
370
  * For now, we ignore everything and wait for the pack
393
371
  */
394
- while (1) {
372
+ do {
395
373
  ptr = buf->data;
396
374
  /* Whilst we're searching for the pack */
397
375
  while (1) {
@@ -400,15 +378,15 @@ static int git_download_pack(char **out, git_transport *transport, git_repositor
400
378
  }
401
379
 
402
380
  error = git_pkt_parse_line(&pkt, ptr, &line_end, buf->offset);
403
- if (error == GIT_ESHORTBUFFER)
381
+ if (error == GIT_EBUFS)
404
382
  break;
405
383
 
406
- if (error < GIT_SUCCESS)
384
+ if (error < 0)
407
385
  return error;
408
386
 
409
387
  if (pkt->type == GIT_PKT_PACK) {
410
388
  git__free(pkt);
411
- return git_fetch__download_pack(out, buf->data, buf->offset, t->socket, repo);
389
+ return git_fetch__download_pack(buf->data, buf->offset, transport, repo, bytes, stats);
412
390
  }
413
391
 
414
392
  /* For now we don't care about anything */
@@ -416,34 +394,33 @@ static int git_download_pack(char **out, git_transport *transport, git_repositor
416
394
  gitno_consume(buf, line_end);
417
395
  }
418
396
 
419
- error = gitno_recv(buf);
420
- if (error < GIT_SUCCESS)
421
- return git__rethrow(GIT_EOSERR, "Failed to receive data");
422
- if (error == 0) { /* Orderly shutdown */
423
- return GIT_SUCCESS;
424
- }
397
+ read_bytes = gitno_recv(buf);
398
+ } while (read_bytes);
425
399
 
426
- }
400
+ return read_bytes;
427
401
  }
428
402
 
429
-
430
- static int git_close(git_transport *transport)
403
+ static int git_close(git_transport *t)
431
404
  {
432
- transport_git *t = (transport_git*) transport;
433
- int error;
405
+ git_buf buf = GIT_BUF_INIT;
434
406
 
407
+ if (git_pkt_buffer_flush(&buf) < 0)
408
+ return -1;
435
409
  /* Can't do anything if there's an error, so don't bother checking */
436
- git_pkt_send_flush(t->socket);
437
- error = gitno_close(t->socket);
410
+ gitno_send(t, buf.ptr, buf.size, 0);
438
411
 
439
- if (error < 0)
440
- error = git__throw(GIT_EOSERR, "Failed to close socket");
412
+ if (gitno_close(t->socket) < 0) {
413
+ giterr_set(GITERR_NET, "Failed to close socket");
414
+ return -1;
415
+ }
416
+
417
+ t->connected = 0;
441
418
 
442
419
  #ifdef GIT_WIN32
443
420
  WSACleanup();
444
421
  #endif
445
422
 
446
- return error;
423
+ return 0;
447
424
  }
448
425
 
449
426
  static void git_free(git_transport *transport)
@@ -472,16 +449,13 @@ int git_transport_git(git_transport **out)
472
449
  #endif
473
450
 
474
451
  t = git__malloc(sizeof(transport_git));
475
- if (t == NULL)
476
- return GIT_ENOMEM;
452
+ GITERR_CHECK_ALLOC(t);
477
453
 
478
454
  memset(t, 0x0, sizeof(transport_git));
479
455
 
480
456
  t->parent.connect = git_connect;
481
457
  t->parent.ls = git_ls;
482
458
  t->parent.negotiate_fetch = git_negotiate_fetch;
483
- t->parent.send_flush = git_send_flush;
484
- t->parent.send_done = git_send_done;
485
459
  t->parent.download_pack = git_download_pack;
486
460
  t->parent.close = git_close;
487
461
  t->parent.free = git_free;
@@ -494,9 +468,10 @@ int git_transport_git(git_transport **out)
494
468
  ret = WSAStartup(MAKEWORD(2,2), &t->wsd);
495
469
  if (ret != 0) {
496
470
  git_free(*out);
497
- return git__throw(GIT_EOSERR, "Winsock init failed");
471
+ giterr_set(GITERR_NET, "Winsock init failed");
472
+ return -1;
498
473
  }
499
474
  #endif
500
475
 
501
- return GIT_SUCCESS;
476
+ return 0;
502
477
  }