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.
@@ -15,8 +15,6 @@
15
15
  #define MAX_FILEMODE 0777777
16
16
  #define MAX_FILEMODE_BYTES 6
17
17
 
18
- #define ENTRY_IS_TREE(e) ((e)->attr & 040000)
19
-
20
18
  static int valid_attributes(const int attributes)
21
19
  {
22
20
  return attributes >= 0 && attributes <= MAX_FILEMODE;
@@ -24,7 +22,7 @@ static int valid_attributes(const int attributes)
24
22
 
25
23
  static int valid_entry_name(const char *filename)
26
24
  {
27
- return strlen(filename) > 0 && strchr(filename, '/') == NULL;
25
+ return *filename != '\0' && strchr(filename, '/') == NULL;
28
26
  }
29
27
 
30
28
  static int entry_sort_cmp(const void *a, const void *b)
@@ -32,9 +30,9 @@ static int entry_sort_cmp(const void *a, const void *b)
32
30
  const git_tree_entry *entry_a = (const git_tree_entry *)(a);
33
31
  const git_tree_entry *entry_b = (const git_tree_entry *)(b);
34
32
 
35
- return git_futils_cmp_path(
36
- entry_a->filename, entry_a->filename_len, ENTRY_IS_TREE(entry_a),
37
- entry_b->filename, entry_b->filename_len, ENTRY_IS_TREE(entry_b));
33
+ return git_path_cmp(
34
+ entry_a->filename, entry_a->filename_len, git_tree_entry__is_tree(entry_a),
35
+ entry_b->filename, entry_b->filename_len, git_tree_entry__is_tree(entry_b));
38
36
  }
39
37
 
40
38
 
@@ -99,7 +97,7 @@ static int tree_key_search(git_vector *entries, const char *filename)
99
97
  for (i = homing; i < (int)entries->length; ++i) {
100
98
  entry = entries->contents[i];
101
99
 
102
- if (homing_search_cmp(&ksearch, entry) != 0)
100
+ if (homing_search_cmp(&ksearch, entry) < 0)
103
101
  break;
104
102
 
105
103
  if (strcmp(filename, entry->filename) == 0)
@@ -111,7 +109,7 @@ static int tree_key_search(git_vector *entries, const char *filename)
111
109
  for (i = homing - 1; i >= 0; --i) {
112
110
  entry = entries->contents[i];
113
111
 
114
- if (homing_search_cmp(&ksearch, entry) != 0)
112
+ if (homing_search_cmp(&ksearch, entry) > 0)
115
113
  break;
116
114
 
117
115
  if (strcmp(filename, entry->filename) == 0)
@@ -172,7 +170,10 @@ git_otype git_tree_entry_type(const git_tree_entry *entry)
172
170
  return GIT_OBJ_BLOB;
173
171
  }
174
172
 
175
- int git_tree_entry_2object(git_object **object_out, git_repository *repo, const git_tree_entry *entry)
173
+ int git_tree_entry_to_object(
174
+ git_object **object_out,
175
+ git_repository *repo,
176
+ const git_tree_entry *entry)
176
177
  {
177
178
  assert(entry && object_out);
178
179
  return git_object_lookup(object_out, repo, &entry->oid, GIT_OBJ_ANY);
@@ -197,47 +198,71 @@ const git_tree_entry *git_tree_entry_byindex(git_tree *tree, unsigned int idx)
197
198
  return git_vector_get(&tree->entries, idx);
198
199
  }
199
200
 
201
+ int git_tree__prefix_position(git_tree *tree, const char *path)
202
+ {
203
+ git_vector *entries = &tree->entries;
204
+ struct tree_key_search ksearch;
205
+ unsigned int at_pos;
206
+
207
+ ksearch.filename = path;
208
+ ksearch.filename_len = strlen(path);
209
+
210
+ /* Find tree entry with appropriate prefix */
211
+ git_vector_bsearch3(&at_pos, entries, &homing_search_cmp, &ksearch);
212
+
213
+ for (; at_pos < entries->length; ++at_pos) {
214
+ const git_tree_entry *entry = entries->contents[at_pos];
215
+ if (homing_search_cmp(&ksearch, entry) < 0)
216
+ break;
217
+ }
218
+
219
+ for (; at_pos > 0; --at_pos) {
220
+ const git_tree_entry *entry = entries->contents[at_pos - 1];
221
+ if (homing_search_cmp(&ksearch, entry) > 0)
222
+ break;
223
+ }
224
+
225
+ return at_pos;
226
+ }
227
+
200
228
  unsigned int git_tree_entrycount(git_tree *tree)
201
229
  {
202
230
  assert(tree);
203
231
  return tree->entries.length;
204
232
  }
205
233
 
206
- static int tree_parse_buffer(git_tree *tree, const char *buffer, const char *buffer_end)
234
+ static int tree_error(const char *str)
207
235
  {
208
- int error = GIT_SUCCESS;
236
+ giterr_set(GITERR_TREE, "%s", str);
237
+ return -1;
238
+ }
209
239
 
210
- if (git_vector_init(&tree->entries, DEFAULT_TREE_SIZE, entry_sort_cmp) < GIT_SUCCESS)
211
- return GIT_ENOMEM;
240
+ static int tree_parse_buffer(git_tree *tree, const char *buffer, const char *buffer_end)
241
+ {
242
+ if (git_vector_init(&tree->entries, DEFAULT_TREE_SIZE, entry_sort_cmp) < 0)
243
+ return -1;
212
244
 
213
245
  while (buffer < buffer_end) {
214
246
  git_tree_entry *entry;
215
247
  int tmp;
216
248
 
217
249
  entry = git__calloc(1, sizeof(git_tree_entry));
218
- if (entry == NULL) {
219
- error = GIT_ENOMEM;
220
- break;
221
- }
250
+ GITERR_CHECK_ALLOC(entry);
222
251
 
223
- if (git_vector_insert(&tree->entries, entry) < GIT_SUCCESS)
224
- return GIT_ENOMEM;
252
+ if (git_vector_insert(&tree->entries, entry) < 0)
253
+ return -1;
225
254
 
226
- if (git__strtol32(&tmp, buffer, &buffer, 8) < GIT_SUCCESS ||
255
+ if (git__strtol32(&tmp, buffer, &buffer, 8) < 0 ||
227
256
  !buffer || !valid_attributes(tmp))
228
- return git__throw(GIT_EOBJCORRUPTED, "Failed to parse tree. Can't parse attributes");
257
+ return tree_error("Failed to parse tree. Can't parse attributes");
229
258
 
230
259
  entry->attr = tmp;
231
260
 
232
- if (*buffer++ != ' ') {
233
- error = git__throw(GIT_EOBJCORRUPTED, "Failed to parse tree. Object it corrupted");
234
- break;
235
- }
261
+ if (*buffer++ != ' ')
262
+ return tree_error("Failed to parse tree. Object is corrupted");
236
263
 
237
- if (memchr(buffer, 0, buffer_end - buffer) == NULL) {
238
- error = git__throw(GIT_EOBJCORRUPTED, "Failed to parse tree. Object it corrupted");
239
- break;
240
- }
264
+ if (memchr(buffer, 0, buffer_end - buffer) == NULL)
265
+ return tree_error("Failed to parse tree. Object is corrupted");
241
266
 
242
267
  entry->filename = git__strdup(buffer);
243
268
  entry->filename_len = strlen(buffer);
@@ -251,7 +276,7 @@ static int tree_parse_buffer(git_tree *tree, const char *buffer, const char *buf
251
276
  buffer += GIT_OID_RAWSZ;
252
277
  }
253
278
 
254
- return error == GIT_SUCCESS ? GIT_SUCCESS : git__rethrow(error, "Failed to parse buffer");
279
+ return 0;
255
280
  }
256
281
 
257
282
  int git_tree__parse(git_tree *tree, git_odb_object *obj)
@@ -282,22 +307,19 @@ static int append_entry(git_treebuilder *bld, const char *filename, const git_oi
282
307
  {
283
308
  git_tree_entry *entry;
284
309
 
285
- if ((entry = git__malloc(sizeof(git_tree_entry))) == NULL)
286
- return GIT_ENOMEM;
310
+ entry = git__calloc(1, sizeof(git_tree_entry));
311
+ GITERR_CHECK_ALLOC(entry);
287
312
 
288
- memset(entry, 0x0, sizeof(git_tree_entry));
289
313
  entry->filename = git__strdup(filename);
290
314
  entry->filename_len = strlen(entry->filename);
291
315
 
292
- bld->entry_count++;
293
-
294
316
  git_oid_cpy(&entry->oid, id);
295
317
  entry->attr = attributes;
296
318
 
297
319
  if (git_vector_insert(&bld->entries, entry) < 0)
298
- return GIT_ENOMEM;
320
+ return -1;
299
321
 
300
- return GIT_SUCCESS;
322
+ return 0;
301
323
  }
302
324
 
303
325
  static int write_tree(
@@ -322,7 +344,7 @@ static int write_tree(
322
344
 
323
345
  error = git_treebuilder_create(&bld, NULL);
324
346
  if (bld == NULL) {
325
- return GIT_ENOMEM;
347
+ return -1;
326
348
  }
327
349
 
328
350
  /*
@@ -358,15 +380,13 @@ static int write_tree(
358
380
  char *subdir, *last_comp;
359
381
 
360
382
  subdir = git__strndup(entry->path, next_slash - entry->path);
361
- if (subdir == NULL) {
362
- error = GIT_ENOMEM;
363
- goto cleanup;
364
- }
383
+ GITERR_CHECK_ALLOC(subdir);
365
384
 
366
385
  /* Write out the subtree */
367
386
  written = write_tree(&sub_oid, repo, index, subdir, i);
368
387
  if (written < 0) {
369
- error = git__rethrow(written, "Failed to write subtree %s", subdir);
388
+ tree_error("Failed to write subtree");
389
+ goto on_error;
370
390
  } else {
371
391
  i = written - 1; /* -1 because of the loop increment */
372
392
  }
@@ -385,51 +405,49 @@ static int write_tree(
385
405
  }
386
406
  error = append_entry(bld, last_comp, &sub_oid, S_IFDIR);
387
407
  git__free(subdir);
388
- if (error < GIT_SUCCESS) {
389
- error = git__rethrow(error, "Failed to insert dir");
390
- goto cleanup;
408
+ if (error < 0) {
409
+ tree_error("Failed to insert dir");
410
+ goto on_error;
391
411
  }
392
412
  } else {
393
413
  error = append_entry(bld, filename, &entry->oid, entry->mode);
394
- if (error < GIT_SUCCESS) {
395
- error = git__rethrow(error, "Failed to insert file");
414
+ if (error < 0) {
415
+ tree_error("Failed to insert file");
416
+ goto on_error;
396
417
  }
397
418
  }
398
419
  }
399
420
 
400
- error = git_treebuilder_write(oid, repo, bld);
401
- if (error < GIT_SUCCESS)
402
- error = git__rethrow(error, "Failed to write tree to db");
421
+ if (git_treebuilder_write(oid, repo, bld) < 0)
422
+ goto on_error;
403
423
 
404
- cleanup:
405
424
  git_treebuilder_free(bld);
425
+ return i;
406
426
 
407
- if (error < GIT_SUCCESS)
408
- return error;
409
- else
410
- return i;
427
+ on_error:
428
+ git_treebuilder_free(bld);
429
+ return -1;
411
430
  }
412
431
 
413
432
  int git_tree_create_fromindex(git_oid *oid, git_index *index)
414
433
  {
434
+ int ret;
415
435
  git_repository *repo;
416
- int error;
417
436
 
418
437
  repo = (git_repository *)GIT_REFCOUNT_OWNER(index);
419
438
 
420
439
  if (repo == NULL)
421
- return git__throw(GIT_EBAREINDEX,
422
- "Failed to create tree. "
423
- "The index file is not backed up by an existing repository");
440
+ return tree_error("Failed to create tree. "
441
+ "The index file is not backed up by an existing repository");
424
442
 
425
443
  if (index->tree != NULL && index->tree->entries >= 0) {
426
444
  git_oid_cpy(oid, &index->tree->oid);
427
- return GIT_SUCCESS;
445
+ return 0;
428
446
  }
429
447
 
430
448
  /* The tree cache didn't help us */
431
- error = write_tree(oid, repo, index, "", 0);
432
- return (error < GIT_SUCCESS) ? git__rethrow(error, "Failed to create tree") : GIT_SUCCESS;
449
+ ret = write_tree(oid, repo, index, "", 0);
450
+ return ret < 0 ? ret : 0;
433
451
  }
434
452
 
435
453
  static void sort_entries(git_treebuilder *bld)
@@ -445,30 +463,29 @@ int git_treebuilder_create(git_treebuilder **builder_p, const git_tree *source)
445
463
  assert(builder_p);
446
464
 
447
465
  bld = git__calloc(1, sizeof(git_treebuilder));
448
- if (bld == NULL)
449
- return GIT_ENOMEM;
466
+ GITERR_CHECK_ALLOC(bld);
450
467
 
451
468
  if (source != NULL)
452
469
  source_entries = source->entries.length;
453
470
 
454
- if (git_vector_init(&bld->entries, source_entries, entry_sort_cmp) < GIT_SUCCESS) {
455
- git__free(bld);
456
- return GIT_ENOMEM;
457
- }
471
+ if (git_vector_init(&bld->entries, source_entries, entry_sort_cmp) < 0)
472
+ goto on_error;
458
473
 
459
474
  if (source != NULL) {
460
475
  for (i = 0; i < source->entries.length; ++i) {
461
476
  git_tree_entry *entry_src = source->entries.contents[i];
462
477
 
463
- if (append_entry(bld, entry_src->filename, &entry_src->oid, entry_src->attr) < 0) {
464
- git_treebuilder_free(bld);
465
- return GIT_ENOMEM;
466
- }
478
+ if (append_entry(bld, entry_src->filename, &entry_src->oid, entry_src->attr) < 0)
479
+ goto on_error;
467
480
  }
468
481
  }
469
482
 
470
483
  *builder_p = bld;
471
- return GIT_SUCCESS;
484
+ return 0;
485
+
486
+ on_error:
487
+ git_treebuilder_free(bld);
488
+ return -1;
472
489
  }
473
490
 
474
491
  int git_treebuilder_insert(git_tree_entry **entry_out, git_treebuilder *bld, const char *filename, const git_oid *id, unsigned int attributes)
@@ -479,28 +496,23 @@ int git_treebuilder_insert(git_tree_entry **entry_out, git_treebuilder *bld, con
479
496
  assert(bld && id && filename);
480
497
 
481
498
  if (!valid_attributes(attributes))
482
- return git__throw(GIT_ERROR, "Failed to insert entry. Invalid attributes");
499
+ return tree_error("Failed to insert entry. Invalid attributes");
483
500
 
484
501
  if (!valid_entry_name(filename))
485
- return git__throw(GIT_ERROR, "Failed to insert entry. Invalid name for a tree entry");
502
+ return tree_error("Failed to insert entry. Invalid name for a tree entry");
486
503
 
487
504
  pos = tree_key_search(&bld->entries, filename);
488
505
 
489
506
  if (pos >= 0) {
490
507
  entry = git_vector_get(&bld->entries, pos);
491
- if (entry->removed) {
508
+ if (entry->removed)
492
509
  entry->removed = 0;
493
- bld->entry_count++;
494
- }
495
510
  } else {
496
- if ((entry = git__malloc(sizeof(git_tree_entry))) == NULL)
497
- return GIT_ENOMEM;
511
+ entry = git__calloc(1, sizeof(git_tree_entry));
512
+ GITERR_CHECK_ALLOC(entry);
498
513
 
499
- memset(entry, 0x0, sizeof(git_tree_entry));
500
514
  entry->filename = git__strdup(filename);
501
515
  entry->filename_len = strlen(entry->filename);
502
-
503
- bld->entry_count++;
504
516
  }
505
517
 
506
518
  git_oid_cpy(&entry->oid, id);
@@ -508,13 +520,13 @@ int git_treebuilder_insert(git_tree_entry **entry_out, git_treebuilder *bld, con
508
520
 
509
521
  if (pos == GIT_ENOTFOUND) {
510
522
  if (git_vector_insert(&bld->entries, entry) < 0)
511
- return GIT_ENOMEM;
523
+ return -1;
512
524
  }
513
525
 
514
526
  if (entry_out != NULL)
515
527
  *entry_out = entry;
516
528
 
517
- return GIT_SUCCESS;
529
+ return 0;
518
530
  }
519
531
 
520
532
  static git_tree_entry *treebuilder_get(git_treebuilder *bld, const char *filename)
@@ -545,17 +557,15 @@ int git_treebuilder_remove(git_treebuilder *bld, const char *filename)
545
557
  git_tree_entry *remove_ptr = treebuilder_get(bld, filename);
546
558
 
547
559
  if (remove_ptr == NULL || remove_ptr->removed)
548
- return git__throw(GIT_ENOTFOUND, "Failed to remove entry. File isn't in the tree");
560
+ return tree_error("Failed to remove entry. File isn't in the tree");
549
561
 
550
562
  remove_ptr->removed = 1;
551
- bld->entry_count--;
552
- return GIT_SUCCESS;
563
+ return 0;
553
564
  }
554
565
 
555
566
  int git_treebuilder_write(git_oid *oid, git_repository *repo, git_treebuilder *bld)
556
567
  {
557
568
  unsigned int i;
558
- int error;
559
569
  git_buf tree = GIT_BUF_INIT;
560
570
  git_odb *odb;
561
571
 
@@ -577,21 +587,22 @@ int git_treebuilder_write(git_oid *oid, git_repository *repo, git_treebuilder *b
577
587
  git_buf_put(&tree, (char *)entry->oid.id, GIT_OID_RAWSZ);
578
588
  }
579
589
 
580
- if (git_buf_oom(&tree)) {
581
- git_buf_free(&tree);
582
- return git__throw(GIT_ENOMEM, "Not enough memory to build the tree data");
583
- }
590
+ if (git_buf_oom(&tree))
591
+ goto on_error;
592
+
593
+ if (git_repository_odb__weakptr(&odb, repo) < 0)
594
+ goto on_error;
584
595
 
585
- error = git_repository_odb__weakptr(&odb, repo);
586
- if (error < GIT_SUCCESS) {
587
- git_buf_free(&tree);
588
- return error;
589
- }
590
596
 
591
- error = git_odb_write(oid, odb, tree.ptr, tree.size, GIT_OBJ_TREE);
597
+ if (git_odb_write(oid, odb, tree.ptr, tree.size, GIT_OBJ_TREE) < 0)
598
+ goto on_error;
599
+
592
600
  git_buf_free(&tree);
601
+ return 0;
593
602
 
594
- return error == GIT_SUCCESS ? GIT_SUCCESS : git__rethrow(error, "Failed to write tree");
603
+ on_error:
604
+ git_buf_free(&tree);
605
+ return -1;
595
606
  }
596
607
 
597
608
  void git_treebuilder_filter(git_treebuilder *bld, int (*filter)(const git_tree_entry *, void *), void *payload)
@@ -631,19 +642,21 @@ void git_treebuilder_free(git_treebuilder *bld)
631
642
  static int tree_frompath(
632
643
  git_tree **parent_out,
633
644
  git_tree *root,
634
- const char *treeentry_path,
635
- int offset)
645
+ git_buf *treeentry_path,
646
+ size_t offset)
636
647
  {
637
648
  char *slash_pos = NULL;
638
649
  const git_tree_entry* entry;
639
- int error = GIT_SUCCESS;
650
+ int error = 0;
640
651
  git_tree *subtree;
641
652
 
642
- if (!*(treeentry_path + offset))
643
- return git__rethrow(GIT_EINVALIDPATH,
644
- "Invalid relative path to a tree entry '%s'.", treeentry_path);
653
+ if (!*(treeentry_path->ptr + offset)) {
654
+ giterr_set(GITERR_INVALID,
655
+ "Invalid relative path to a tree entry '%s'.", treeentry_path->ptr);
656
+ return -1;
657
+ }
645
658
 
646
- slash_pos = (char *)strchr(treeentry_path + offset, '/');
659
+ slash_pos = (char *)strchr(treeentry_path->ptr + offset, '/');
647
660
 
648
661
  if (slash_pos == NULL)
649
662
  return git_tree_lookup(
@@ -652,32 +665,35 @@ static int tree_frompath(
652
665
  git_object_id((const git_object *)root)
653
666
  );
654
667
 
655
- if (slash_pos == treeentry_path + offset)
656
- return git__rethrow(GIT_EINVALIDPATH,
657
- "Invalid relative path to a tree entry '%s'.", treeentry_path);
668
+ if (slash_pos == treeentry_path->ptr + offset) {
669
+ giterr_set(GITERR_INVALID,
670
+ "Invalid relative path to a tree entry '%s'.", treeentry_path->ptr);
671
+ return -1;
672
+ }
658
673
 
659
674
  *slash_pos = '\0';
660
675
 
661
- entry = git_tree_entry_byname(root, treeentry_path + offset);
676
+ entry = git_tree_entry_byname(root, treeentry_path->ptr + offset);
662
677
 
663
678
  if (slash_pos != NULL)
664
679
  *slash_pos = '/';
665
680
 
666
- if (entry == NULL)
667
- return git__rethrow(GIT_ENOTFOUND,
681
+ if (entry == NULL) {
682
+ giterr_set(GITERR_TREE,
668
683
  "No tree entry can be found from "
669
- "the given tree and relative path '%s'.", treeentry_path);
684
+ "the given tree and relative path '%s'.", treeentry_path->ptr);
685
+ return GIT_ENOTFOUND;
686
+ }
670
687
 
671
688
 
672
- error = git_tree_lookup(&subtree, root->object.repo, &entry->oid);
673
- if (error < GIT_SUCCESS)
689
+ if (git_tree_lookup(&subtree, root->object.repo, &entry->oid) < 0)
674
690
  return error;
675
691
 
676
692
  error = tree_frompath(
677
693
  parent_out,
678
694
  subtree,
679
695
  treeentry_path,
680
- slash_pos - treeentry_path + 1
696
+ (slash_pos - treeentry_path->ptr) + 1
681
697
  );
682
698
 
683
699
  git_tree_free(subtree);
@@ -689,70 +705,81 @@ int git_tree_get_subtree(
689
705
  git_tree *root,
690
706
  const char *subtree_path)
691
707
  {
692
- char buffer[GIT_PATH_MAX];
708
+ int error;
709
+ git_buf buffer = GIT_BUF_INIT;
693
710
 
694
711
  assert(subtree && root && subtree_path);
695
712
 
696
- strncpy(buffer, subtree_path, GIT_PATH_MAX);
697
- return tree_frompath(subtree, root, buffer, 0);
713
+ if ((error = git_buf_sets(&buffer, subtree_path)) == 0)
714
+ error = tree_frompath(subtree, root, &buffer, 0);
715
+
716
+ git_buf_free(&buffer);
717
+
718
+ return error;
698
719
  }
699
720
 
700
721
  static int tree_walk_post(
701
722
  git_tree *tree,
702
723
  git_treewalk_cb callback,
703
- char *root,
704
- size_t root_len,
724
+ git_buf *path,
705
725
  void *payload)
706
726
  {
707
- int error;
727
+ int error = 0;
708
728
  unsigned int i;
709
729
 
710
730
  for (i = 0; i < tree->entries.length; ++i) {
711
731
  git_tree_entry *entry = tree->entries.contents[i];
712
732
 
713
- root[root_len] = '\0';
714
-
715
- if (callback(root, entry, payload) < 0)
733
+ if (callback(path->ptr, entry, payload) < 0)
716
734
  continue;
717
735
 
718
- if (ENTRY_IS_TREE(entry)) {
736
+ if (git_tree_entry__is_tree(entry)) {
719
737
  git_tree *subtree;
738
+ size_t path_len = git_buf_len(path);
720
739
 
721
740
  if ((error = git_tree_lookup(
722
741
  &subtree, tree->object.repo, &entry->oid)) < 0)
723
- return error;
742
+ break;
743
+
744
+ /* append the next entry to the path */
745
+ git_buf_puts(path, entry->filename);
746
+ git_buf_putc(path, '/');
724
747
 
725
- strcpy(root + root_len, entry->filename);
726
- root[root_len + entry->filename_len] = '/';
748
+ if (git_buf_oom(path))
749
+ return -1;
727
750
 
728
- tree_walk_post(subtree,
729
- callback, root,
730
- root_len + entry->filename_len + 1,
731
- payload
732
- );
751
+ if (tree_walk_post(subtree, callback, path, payload) < 0)
752
+ return -1;
733
753
 
754
+ git_buf_truncate(path, path_len);
734
755
  git_tree_free(subtree);
735
756
  }
736
757
  }
737
758
 
738
- return GIT_SUCCESS;
759
+ return 0;
739
760
  }
740
761
 
741
762
  int git_tree_walk(git_tree *tree, git_treewalk_cb callback, int mode, void *payload)
742
763
  {
743
- char root_path[GIT_PATH_MAX];
764
+ int error = 0;
765
+ git_buf root_path = GIT_BUF_INIT;
744
766
 
745
- root_path[0] = '\0';
746
767
  switch (mode) {
747
768
  case GIT_TREEWALK_POST:
748
- return tree_walk_post(tree, callback, root_path, 0, payload);
769
+ error = tree_walk_post(tree, callback, &root_path, payload);
770
+ break;
749
771
 
750
772
  case GIT_TREEWALK_PRE:
751
- return git__throw(GIT_ENOTIMPLEMENTED,
752
- "Preorder tree walking is still not implemented");
773
+ tree_error("Preorder tree walking is still not implemented");
774
+ return -1;
753
775
 
754
776
  default:
755
- return git__throw(GIT_EINVALIDARGS,
756
- "Invalid walking mode for tree walk");
777
+ giterr_set(GITERR_INVALID, "Invalid walking mode for tree walk");
778
+ return -1;
757
779
  }
780
+
781
+ git_buf_free(&root_path);
782
+
783
+ return error;
758
784
  }
785
+
@@ -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.
@@ -27,11 +27,25 @@ struct git_tree {
27
27
 
28
28
  struct git_treebuilder {
29
29
  git_vector entries;
30
- size_t entry_count;
31
30
  };
32
31
 
33
32
 
33
+ GIT_INLINE(bool) git_tree_entry__is_tree(const struct git_tree_entry *e)
34
+ {
35
+ return (S_ISDIR(e->attr) && !S_ISGITLINK(e->attr));
36
+ }
37
+
34
38
  void git_tree__free(git_tree *tree);
35
39
  int git_tree__parse(git_tree *tree, git_odb_object *obj);
36
40
 
41
+ /**
42
+ * Lookup the first position in the tree with a given prefix.
43
+ *
44
+ * @param tree a previously loaded tree.
45
+ * @param prefix the beginning of a path to find in the tree.
46
+ * @return index of the first item at or after the given prefix.
47
+ */
48
+ int git_tree__prefix_position(git_tree *tree, const char *prefix);
49
+
50
+
37
51
  #endif