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,10 +1,10 @@
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.
6
6
  */
7
- #include "posix.h"
7
+ #include "../posix.h"
8
8
  #include "path.h"
9
9
  #include "utf-conv.h"
10
10
  #include <errno.h>
@@ -17,10 +17,11 @@ int p_unlink(const char *path)
17
17
  int ret = 0;
18
18
  wchar_t* buf;
19
19
 
20
- buf = gitwin_to_utf16(path);
21
- _wchmod(buf, 0666);
22
- ret = _wunlink(buf);
23
- git__free(buf);
20
+ if ((buf = gitwin_to_utf16(path)) != NULL) {
21
+ _wchmod(buf, 0666);
22
+ ret = _wunlink(buf);
23
+ git__free(buf);
24
+ }
24
25
 
25
26
  return ret;
26
27
  }
@@ -60,6 +61,8 @@ static int do_lstat(const char *file_name, struct stat *buf)
60
61
  {
61
62
  WIN32_FILE_ATTRIBUTE_DATA fdata;
62
63
  wchar_t* fbuf = gitwin_to_utf16(file_name);
64
+ if (!fbuf)
65
+ return -1;
63
66
 
64
67
  if (GetFileAttributesExW(fbuf, GetFileExInfoStandard, &fdata)) {
65
68
  int fMode = S_IREAD;
@@ -80,61 +83,50 @@ static int do_lstat(const char *file_name, struct stat *buf)
80
83
  buf->st_uid = 0;
81
84
  buf->st_nlink = 1;
82
85
  buf->st_mode = (mode_t)fMode;
83
- buf->st_size = fdata.nFileSizeLow; /* Can't use nFileSizeHigh, since it's not a stat64 */
86
+ buf->st_size = ((git_off_t)fdata.nFileSizeHigh << 32) + fdata.nFileSizeLow;
84
87
  buf->st_dev = buf->st_rdev = (_getdrive() - 1);
85
88
  buf->st_atime = filetime_to_time_t(&(fdata.ftLastAccessTime));
86
89
  buf->st_mtime = filetime_to_time_t(&(fdata.ftLastWriteTime));
87
90
  buf->st_ctime = filetime_to_time_t(&(fdata.ftCreationTime));
88
91
 
89
92
  git__free(fbuf);
90
- return GIT_SUCCESS;
93
+ return 0;
91
94
  }
92
95
 
93
96
  git__free(fbuf);
94
-
95
- switch (GetLastError()) {
96
- case ERROR_ACCESS_DENIED:
97
- case ERROR_SHARING_VIOLATION:
98
- case ERROR_LOCK_VIOLATION:
99
- case ERROR_SHARING_BUFFER_EXCEEDED:
100
- return GIT_EOSERR;
101
-
102
- case ERROR_BUFFER_OVERFLOW:
103
- case ERROR_NOT_ENOUGH_MEMORY:
104
- return GIT_ENOMEM;
105
-
106
- default:
107
- return GIT_EINVALIDPATH;
108
- }
97
+ return -1;
109
98
  }
110
99
 
111
100
  int p_lstat(const char *file_name, struct stat *buf)
112
101
  {
113
- int namelen, error;
114
- char alt_name[GIT_PATH_MAX];
102
+ int error;
103
+ size_t namelen;
104
+ char *alt_name;
115
105
 
116
- if ((error = do_lstat(file_name, buf)) == GIT_SUCCESS)
117
- return GIT_SUCCESS;
106
+ if (do_lstat(file_name, buf) == 0)
107
+ return 0;
118
108
 
119
109
  /* if file_name ended in a '/', Windows returned ENOENT;
120
110
  * try again without trailing slashes
121
111
  */
122
- if (error != GIT_EINVALIDPATH)
123
- return git__throw(GIT_EOSERR, "Failed to lstat file");
124
-
125
112
  namelen = strlen(file_name);
126
113
  if (namelen && file_name[namelen-1] != '/')
127
- return git__throw(GIT_EOSERR, "Failed to lstat file");
114
+ return -1;
128
115
 
129
116
  while (namelen && file_name[namelen-1] == '/')
130
117
  --namelen;
131
118
 
132
- if (!namelen || namelen >= GIT_PATH_MAX)
133
- return git__throw(GIT_ENOMEM, "Failed to lstat file");
119
+ if (!namelen)
120
+ return -1;
121
+
122
+ alt_name = git__strndup(file_name, namelen);
123
+ if (!alt_name)
124
+ return -1;
134
125
 
135
- memcpy(alt_name, file_name, namelen);
136
- alt_name[namelen] = 0;
137
- return do_lstat(alt_name, buf);
126
+ error = do_lstat(alt_name, buf);
127
+
128
+ git__free(alt_name);
129
+ return error;
138
130
  }
139
131
 
140
132
  int p_readlink(const char *link, char *target, size_t target_len)
@@ -145,6 +137,9 @@ int p_readlink(const char *link, char *target, size_t target_len)
145
137
  DWORD dwRet;
146
138
  wchar_t* link_w;
147
139
  wchar_t* target_w;
140
+ int error = 0;
141
+
142
+ assert(link && target && target_len > 0);
148
143
 
149
144
  /*
150
145
  * Try to load the pointer to pGetFinalPath dynamically, because
@@ -156,12 +151,15 @@ int p_readlink(const char *link, char *target, size_t target_len)
156
151
  if (library != NULL)
157
152
  pGetFinalPath = (fpath_func)GetProcAddress(library, "GetFinalPathNameByHandleW");
158
153
 
159
- if (pGetFinalPath == NULL)
160
- return git__throw(GIT_EOSERR,
154
+ if (pGetFinalPath == NULL) {
155
+ giterr_set(GITERR_OS,
161
156
  "'GetFinalPathNameByHandleW' is not available in this platform");
157
+ return -1;
158
+ }
162
159
  }
163
160
 
164
161
  link_w = gitwin_to_utf16(link);
162
+ GITERR_CHECK_ALLOC(link_w);
165
163
 
166
164
  hFile = CreateFileW(link_w, // file to open
167
165
  GENERIC_READ, // open for reading
@@ -173,58 +171,72 @@ int p_readlink(const char *link, char *target, size_t target_len)
173
171
 
174
172
  git__free(link_w);
175
173
 
176
- if (hFile == INVALID_HANDLE_VALUE)
177
- return GIT_EOSERR;
178
-
179
- if (target_len <= 0) {
180
- return GIT_EINVALIDARGS;
174
+ if (hFile == INVALID_HANDLE_VALUE) {
175
+ giterr_set(GITERR_OS, "Cannot open '%s' for reading", link);
176
+ return -1;
181
177
  }
182
178
 
183
179
  target_w = (wchar_t*)git__malloc(target_len * sizeof(wchar_t));
180
+ GITERR_CHECK_ALLOC(target_w);
184
181
 
185
- dwRet = pGetFinalPath(hFile, target_w, target_len, 0x0);
186
- if (dwRet >= target_len) {
187
- git__free(target_w);
188
- CloseHandle(hFile);
189
- return GIT_ENOMEM;
190
- }
191
-
192
- if (!WideCharToMultiByte(CP_UTF8, 0, target_w, -1, target, target_len * sizeof(char), NULL, NULL)) {
193
- git__free(target_w);
194
- return GIT_EOSERR;
195
- }
182
+ dwRet = pGetFinalPath(hFile, target_w, (DWORD)target_len, 0x0);
183
+ if (dwRet == 0 ||
184
+ dwRet >= target_len ||
185
+ !WideCharToMultiByte(CP_UTF8, 0, target_w, -1, target,
186
+ (int)(target_len * sizeof(char)), NULL, NULL))
187
+ error = -1;
196
188
 
197
189
  git__free(target_w);
198
190
  CloseHandle(hFile);
199
191
 
200
- if (dwRet > 4) {
201
- /* Skip first 4 characters if they are "\\?\" */
202
- if (target[0] == '\\' && target[1] == '\\' && target[2] == '?' && target[3] == '\\') {
203
- char tmp[GIT_PATH_MAX];
204
- unsigned int offset = 4;
205
- dwRet -= 4;
206
-
207
- /* \??\UNC\ */
208
- if (dwRet > 7 && target[4] == 'U' && target[5] == 'N' && target[6] == 'C') {
209
- offset += 2;
210
- dwRet -= 2;
211
- target[offset] = '\\';
212
- }
213
-
214
- memcpy(tmp, target + offset, dwRet);
215
- memcpy(target, tmp, dwRet);
192
+ if (error)
193
+ return error;
194
+
195
+ /* Skip first 4 characters if they are "\\?\" */
196
+ if (dwRet > 4 &&
197
+ target[0] == '\\' && target[1] == '\\' &&
198
+ target[2] == '?' && target[3] == '\\')
199
+ {
200
+ unsigned int offset = 4;
201
+ dwRet -= 4;
202
+
203
+ /* \??\UNC\ */
204
+ if (dwRet > 7 &&
205
+ target[4] == 'U' && target[5] == 'N' && target[6] == 'C')
206
+ {
207
+ offset += 2;
208
+ dwRet -= 2;
209
+ target[offset] = '\\';
216
210
  }
211
+
212
+ memmove(target, target + offset, dwRet);
217
213
  }
218
214
 
219
215
  target[dwRet] = '\0';
216
+
220
217
  return dwRet;
221
218
  }
222
219
 
223
- int p_open(const char *path, int flags)
220
+ int p_open(const char *path, int flags, ...)
224
221
  {
225
222
  int fd;
226
- wchar_t* buf = gitwin_to_utf16(path);
227
- fd = _wopen(buf, flags | _O_BINARY);
223
+ wchar_t* buf;
224
+ mode_t mode = 0;
225
+
226
+ buf = gitwin_to_utf16(path);
227
+ if (!buf)
228
+ return -1;
229
+
230
+ if (flags & O_CREAT)
231
+ {
232
+ va_list arg_list;
233
+
234
+ va_start(arg_list, flags);
235
+ mode = va_arg(arg_list, mode_t);
236
+ va_end(arg_list);
237
+ }
238
+
239
+ fd = _wopen(buf, flags | _O_BINARY, mode);
228
240
 
229
241
  git__free(buf);
230
242
  return fd;
@@ -234,24 +246,31 @@ int p_creat(const char *path, mode_t mode)
234
246
  {
235
247
  int fd;
236
248
  wchar_t* buf = gitwin_to_utf16(path);
249
+ if (!buf)
250
+ return -1;
237
251
  fd = _wopen(buf, _O_WRONLY | _O_CREAT | _O_TRUNC | _O_BINARY, mode);
238
-
239
252
  git__free(buf);
240
253
  return fd;
241
254
  }
242
255
 
243
256
  int p_getcwd(char *buffer_out, size_t size)
244
257
  {
245
- wchar_t* buf = (wchar_t*)git__malloc(sizeof(wchar_t) * (int)size);
258
+ int ret;
259
+ wchar_t* buf;
260
+
261
+ if ((size_t)((int)size) != size)
262
+ return -1;
263
+
264
+ buf = (wchar_t*)git__malloc(sizeof(wchar_t) * (int)size);
265
+ GITERR_CHECK_ALLOC(buf);
266
+
246
267
  _wgetcwd(buf, (int)size);
247
268
 
248
- if (!WideCharToMultiByte(CP_UTF8, 0, buf, -1, buffer_out, size, NULL, NULL)) {
249
- git__free(buf);
250
- return GIT_EOSERR;
251
- }
269
+ ret = WideCharToMultiByte(
270
+ CP_UTF8, 0, buf, -1, buffer_out, (int)size, NULL, NULL);
252
271
 
253
272
  git__free(buf);
254
- return GIT_SUCCESS;
273
+ return !ret ? -1 : 0;
255
274
  }
256
275
 
257
276
  int p_stat(const char* path, struct stat* buf)
@@ -262,8 +281,10 @@ int p_stat(const char* path, struct stat* buf)
262
281
  int p_chdir(const char* path)
263
282
  {
264
283
  wchar_t* buf = gitwin_to_utf16(path);
265
- int ret = _wchdir(buf);
266
-
284
+ int ret;
285
+ if (!buf)
286
+ return -1;
287
+ ret = _wchdir(buf);
267
288
  git__free(buf);
268
289
  return ret;
269
290
  }
@@ -271,8 +292,10 @@ int p_chdir(const char* path)
271
292
  int p_chmod(const char* path, mode_t mode)
272
293
  {
273
294
  wchar_t* buf = gitwin_to_utf16(path);
274
- int ret = _wchmod(buf, mode);
275
-
295
+ int ret;
296
+ if (!buf)
297
+ return -1;
298
+ ret = _wchmod(buf, mode);
276
299
  git__free(buf);
277
300
  return ret;
278
301
  }
@@ -280,64 +303,88 @@ int p_chmod(const char* path, mode_t mode)
280
303
  int p_rmdir(const char* path)
281
304
  {
282
305
  wchar_t* buf = gitwin_to_utf16(path);
283
- int ret = _wrmdir(buf);
284
-
306
+ int ret;
307
+ if (!buf)
308
+ return -1;
309
+ ret = _wrmdir(buf);
285
310
  git__free(buf);
286
311
  return ret;
287
312
  }
288
313
 
289
314
  int p_hide_directory__w32(const char *path)
290
315
  {
291
- int error;
316
+ int res;
292
317
  wchar_t* buf = gitwin_to_utf16(path);
318
+ if (!buf)
319
+ return -1;
293
320
 
294
- error = SetFileAttributesW(buf, FILE_ATTRIBUTE_HIDDEN) != 0 ?
295
- GIT_SUCCESS : GIT_ERROR; /* MSDN states a "non zero" value indicates a success */
296
-
321
+ res = SetFileAttributesW(buf, FILE_ATTRIBUTE_HIDDEN);
297
322
  git__free(buf);
298
323
 
299
- if (error < GIT_SUCCESS)
300
- error = git__throw(GIT_EOSERR, "Failed to hide directory '%s'", path);
301
-
302
- return error;
324
+ return (res != 0) ? 0 : -1; /* MSDN states a "non zero" value indicates a success */
303
325
  }
304
326
 
305
327
  char *p_realpath(const char *orig_path, char *buffer)
306
328
  {
307
- int ret, alloc = 0;
329
+ int ret, buffer_sz = 0;
308
330
  wchar_t* orig_path_w = gitwin_to_utf16(orig_path);
309
331
  wchar_t* buffer_w = (wchar_t*)git__malloc(GIT_PATH_MAX * sizeof(wchar_t));
310
332
 
311
- if (buffer == NULL) {
312
- buffer = (char *)git__malloc(GIT_PATH_MAX);
313
- alloc = 1;
314
- }
333
+ if (!orig_path_w || !buffer_w)
334
+ return NULL;
315
335
 
316
336
  ret = GetFullPathNameW(orig_path_w, GIT_PATH_MAX, buffer_w, NULL);
317
337
  git__free(orig_path_w);
318
338
 
319
- if (!ret || ret > GIT_PATH_MAX) {
320
- git__free(buffer_w);
321
- if (alloc) git__free(buffer);
339
+ /* According to MSDN, a return value equals to zero means a failure. */
340
+ if (ret == 0 || ret > GIT_PATH_MAX) {
341
+ buffer = NULL;
342
+ goto done;
343
+ }
322
344
 
323
- return NULL;
345
+ if (buffer == NULL) {
346
+ buffer_sz = WideCharToMultiByte(CP_UTF8, 0, buffer_w, -1, NULL, 0, NULL, NULL);
347
+
348
+ if (!buffer_sz ||
349
+ !(buffer = (char *)git__malloc(buffer_sz)) ||
350
+ !WideCharToMultiByte(CP_UTF8, 0, buffer_w, -1, buffer, buffer_sz, NULL, NULL))
351
+ {
352
+ git__free(buffer);
353
+ buffer = NULL;
354
+ goto done;
355
+ }
356
+ } else {
357
+ if (!WideCharToMultiByte(CP_UTF8, 0, buffer_w, -1, buffer, GIT_PATH_MAX, NULL, NULL)) {
358
+ buffer = NULL;
359
+ goto done;
360
+ }
324
361
  }
325
362
 
326
- if (!WideCharToMultiByte(CP_UTF8, 0, buffer_w, -1, buffer, GIT_PATH_MAX, NULL, NULL)) {
327
- git__free(buffer_w);
328
- if (alloc) git__free(buffer);
363
+ if (!git_path_exists(buffer))
364
+ {
365
+ if (buffer_sz > 0)
366
+ git__free(buffer);
367
+
368
+ buffer = NULL;
369
+ errno = ENOENT;
329
370
  }
330
-
371
+
372
+ done:
331
373
  git__free(buffer_w);
332
- git_path_mkposix(buffer);
374
+ if (buffer)
375
+ git_path_mkposix(buffer);
333
376
  return buffer;
334
377
  }
335
378
 
336
379
  int p_vsnprintf(char *buffer, size_t count, const char *format, va_list argptr)
337
380
  {
338
381
  #ifdef _MSC_VER
339
- int len = _vsnprintf(buffer, count, format, argptr);
340
- return (len < 0) ? _vscprintf(format, argptr) : len;
382
+ int len;
383
+
384
+ if (count == 0 || (len = _vsnprintf(buffer, count, format, argptr)) < 0)
385
+ return _vscprintf(format, argptr);
386
+
387
+ return len;
341
388
  #else /* MinGW */
342
389
  return vsnprintf(buffer, count, format, argptr);
343
390
  #endif
@@ -360,28 +407,30 @@ extern int p_creat(const char *path, mode_t mode);
360
407
  int p_mkstemp(char *tmp_path)
361
408
  {
362
409
  #if defined(_MSC_VER)
363
- if (_mktemp_s(tmp_path, GIT_PATH_MAX) != 0)
364
- return GIT_EOSERR;
410
+ if (_mktemp_s(tmp_path, strlen(tmp_path) + 1) != 0)
411
+ return -1;
365
412
  #else
366
413
  if (_mktemp(tmp_path) == NULL)
367
- return GIT_EOSERR;
414
+ return -1;
368
415
  #endif
369
416
 
370
- return p_creat(tmp_path, 0744);
417
+ return p_creat(tmp_path, 0744); //-V536
371
418
  }
372
419
 
373
420
  int p_setenv(const char* name, const char* value, int overwrite)
374
421
  {
375
422
  if (overwrite != 1)
376
- return EINVAL;
423
+ return -1;
377
424
 
378
- return (SetEnvironmentVariableA(name, value) == 0 ? GIT_EOSERR : GIT_SUCCESS);
425
+ return (SetEnvironmentVariableA(name, value) == 0 ? -1 : 0);
379
426
  }
380
427
 
381
428
  int p_access(const char* path, mode_t mode)
382
429
  {
383
430
  wchar_t *buf = gitwin_to_utf16(path);
384
431
  int ret;
432
+ if (!buf)
433
+ return -1;
385
434
 
386
435
  ret = _waccess(buf, mode);
387
436
  git__free(buf);
@@ -389,16 +438,111 @@ int p_access(const char* path, mode_t mode)
389
438
  return ret;
390
439
  }
391
440
 
392
- extern int p_rename(const char *from, const char *to)
441
+ int p_rename(const char *from, const char *to)
393
442
  {
394
443
  wchar_t *wfrom = gitwin_to_utf16(from);
395
444
  wchar_t *wto = gitwin_to_utf16(to);
396
445
  int ret;
397
446
 
398
- ret = MoveFileExW(wfrom, wto, MOVEFILE_REPLACE_EXISTING | MOVEFILE_COPY_ALLOWED) ? GIT_SUCCESS : GIT_EOSERR;
447
+ if (!wfrom || !wto)
448
+ return -1;
449
+
450
+ ret = MoveFileExW(wfrom, wto, MOVEFILE_REPLACE_EXISTING | MOVEFILE_COPY_ALLOWED) ? 0 : -1;
399
451
 
400
452
  git__free(wfrom);
401
453
  git__free(wto);
402
454
 
403
455
  return ret;
404
456
  }
457
+
458
+ int p_recv(GIT_SOCKET socket, void *buffer, size_t length, int flags)
459
+ {
460
+ if ((size_t)((int)length) != length)
461
+ return -1; /* giterr_set will be done by caller */
462
+
463
+ return recv(socket, buffer, (int)length, flags);
464
+ }
465
+
466
+ int p_send(GIT_SOCKET socket, const void *buffer, size_t length, int flags)
467
+ {
468
+ if ((size_t)((int)length) != length)
469
+ return -1; /* giterr_set will be done by caller */
470
+
471
+ return send(socket, buffer, (int)length, flags);
472
+ }
473
+
474
+ /**
475
+ * Borrowed from http://old.nabble.com/Porting-localtime_r-and-gmtime_r-td15282276.html
476
+ * On Win32, `gmtime_r` doesn't exist but `gmtime` is threadsafe, so we can use that
477
+ */
478
+ struct tm *
479
+ p_localtime_r (const time_t *timer, struct tm *result)
480
+ {
481
+ struct tm *local_result;
482
+ local_result = localtime (timer);
483
+
484
+ if (local_result == NULL || result == NULL)
485
+ return NULL;
486
+
487
+ memcpy (result, local_result, sizeof (struct tm));
488
+ return result;
489
+ }
490
+ struct tm *
491
+ p_gmtime_r (const time_t *timer, struct tm *result)
492
+ {
493
+ struct tm *local_result;
494
+ local_result = gmtime (timer);
495
+
496
+ if (local_result == NULL || result == NULL)
497
+ return NULL;
498
+
499
+ memcpy (result, local_result, sizeof (struct tm));
500
+ return result;
501
+ }
502
+
503
+ #if defined(_MSC_VER) || defined(_MSC_EXTENSIONS)
504
+ #define DELTA_EPOCH_IN_MICROSECS 11644473600000000Ui64
505
+ #else
506
+ #define DELTA_EPOCH_IN_MICROSECS 11644473600000000ULL
507
+ #endif
508
+
509
+ struct timezone
510
+ {
511
+ int tz_minuteswest; /* minutes W of Greenwich */
512
+ int tz_dsttime; /* type of dst correction */
513
+ };
514
+
515
+ int p_gettimeofday(struct timeval *tv, struct timezone *tz)
516
+ {
517
+ FILETIME ft;
518
+ unsigned __int64 tmpres = 0;
519
+ static int tzflag;
520
+
521
+ if (NULL != tv)
522
+ {
523
+ GetSystemTimeAsFileTime(&ft);
524
+
525
+ tmpres |= ft.dwHighDateTime;
526
+ tmpres <<= 32;
527
+ tmpres |= ft.dwLowDateTime;
528
+
529
+ /*converting file time to unix epoch*/
530
+ tmpres /= 10; /*convert into microseconds*/
531
+ tmpres -= DELTA_EPOCH_IN_MICROSECS;
532
+ tv->tv_sec = (long)(tmpres / 1000000UL);
533
+ tv->tv_usec = (long)(tmpres % 1000000UL);
534
+ }
535
+
536
+ if (NULL != tz)
537
+ {
538
+ if (!tzflag)
539
+ {
540
+ _tzset();
541
+ tzflag++;
542
+ }
543
+ tz->tz_minuteswest = _timezone / 60;
544
+ tz->tz_dsttime = _daylight;
545
+ }
546
+
547
+ return 0;
548
+ }
@@ -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.
@@ -7,13 +7,16 @@
7
7
 
8
8
  #include "pthread.h"
9
9
 
10
- int pthread_create(pthread_t *GIT_RESTRICT thread,
11
- const pthread_attr_t *GIT_RESTRICT GIT_UNUSED(attr),
12
- void *(*start_routine)(void*), void *GIT_RESTRICT arg)
10
+ int pthread_create(
11
+ pthread_t *GIT_RESTRICT thread,
12
+ const pthread_attr_t *GIT_RESTRICT attr,
13
+ void *(*start_routine)(void*),
14
+ void *GIT_RESTRICT arg)
13
15
  {
14
- GIT_UNUSED_ARG(attr);
15
- *thread = (pthread_t) CreateThread(NULL, 0, (LPTHREAD_START_ROUTINE)start_routine, arg, 0, NULL);
16
- return *thread ? GIT_SUCCESS : git__throw(GIT_EOSERR, "Failed to create pthread");
16
+ GIT_UNUSED(attr);
17
+ *thread = (pthread_t) CreateThread(
18
+ NULL, 0, (LPTHREAD_START_ROUTINE)start_routine, arg, 0, NULL);
19
+ return *thread ? 0 : -1;
17
20
  }
18
21
 
19
22
  int pthread_join(pthread_t thread, void **value_ptr)
@@ -26,9 +29,9 @@ int pthread_join(pthread_t thread, void **value_ptr)
26
29
  }
27
30
 
28
31
  int pthread_mutex_init(pthread_mutex_t *GIT_RESTRICT mutex,
29
- const pthread_mutexattr_t *GIT_RESTRICT GIT_UNUSED(mutexattr))
32
+ const pthread_mutexattr_t *GIT_RESTRICT mutexattr)
30
33
  {
31
- GIT_UNUSED_ARG(mutexattr);
34
+ GIT_UNUSED(mutexattr);
32
35
  InitializeCriticalSection(mutex);
33
36
  return 0;
34
37
  }
@@ -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.