rugged 0.27.10 → 0.27.10.1

Sign up to get free protection for your applications and to get access to all the features.
Files changed (420) hide show
  1. checksums.yaml +4 -4
  2. data/lib/rugged/version.rb +1 -1
  3. data/vendor/libgit2/AUTHORS +0 -1
  4. data/vendor/libgit2/CMakeLists.txt +54 -98
  5. data/vendor/libgit2/COPYING +0 -28
  6. data/vendor/libgit2/cmake/Modules/AddCFlagIfSupported.cmake +1 -15
  7. data/vendor/libgit2/cmake/Modules/EnableWarnings.cmake +8 -9
  8. data/vendor/libgit2/cmake/Modules/FindCoreFoundation.cmake +2 -2
  9. data/vendor/libgit2/cmake/Modules/FindGSSAPI.cmake +1 -1
  10. data/vendor/libgit2/cmake/Modules/FindSecurity.cmake +2 -2
  11. data/vendor/libgit2/cmake/Modules/FindStatNsec.cmake +0 -6
  12. data/vendor/libgit2/deps/http-parser/CMakeLists.txt +0 -2
  13. data/vendor/libgit2/deps/http-parser/{COPYING → LICENSE-MIT} +0 -0
  14. data/vendor/libgit2/deps/http-parser/http_parser.c +6 -11
  15. data/vendor/libgit2/deps/regex/CMakeLists.txt +2 -0
  16. data/vendor/libgit2/deps/regex/config.h +7 -0
  17. data/vendor/libgit2/deps/regex/regcomp.c +3857 -0
  18. data/vendor/libgit2/deps/regex/regex.c +92 -0
  19. data/vendor/libgit2/deps/regex/regex.h +582 -0
  20. data/vendor/libgit2/deps/regex/regex_internal.c +1744 -0
  21. data/vendor/libgit2/deps/regex/regex_internal.h +819 -0
  22. data/vendor/libgit2/deps/regex/regexec.c +4369 -0
  23. data/vendor/libgit2/deps/zlib/CMakeLists.txt +0 -1
  24. data/vendor/libgit2/deps/zlib/adler32.c +7 -0
  25. data/vendor/libgit2/deps/zlib/crc32.c +7 -0
  26. data/vendor/libgit2/include/git2.h +0 -5
  27. data/vendor/libgit2/include/git2/annotated_commit.h +0 -9
  28. data/vendor/libgit2/include/git2/attr.h +20 -38
  29. data/vendor/libgit2/include/git2/blame.h +25 -42
  30. data/vendor/libgit2/include/git2/blob.h +13 -45
  31. data/vendor/libgit2/include/git2/branch.h +1 -1
  32. data/vendor/libgit2/include/git2/buffer.h +16 -22
  33. data/vendor/libgit2/include/git2/checkout.h +32 -65
  34. data/vendor/libgit2/include/git2/cherrypick.h +7 -9
  35. data/vendor/libgit2/include/git2/clone.h +10 -12
  36. data/vendor/libgit2/include/git2/commit.h +3 -53
  37. data/vendor/libgit2/include/git2/common.h +8 -60
  38. data/vendor/libgit2/include/git2/config.h +19 -30
  39. data/vendor/libgit2/include/git2/describe.h +9 -32
  40. data/vendor/libgit2/include/git2/diff.h +156 -208
  41. data/vendor/libgit2/include/git2/errors.h +46 -54
  42. data/vendor/libgit2/include/git2/filter.h +0 -8
  43. data/vendor/libgit2/include/git2/ignore.h +2 -2
  44. data/vendor/libgit2/include/git2/index.h +52 -74
  45. data/vendor/libgit2/include/git2/indexer.h +6 -76
  46. data/vendor/libgit2/include/git2/inttypes.h +309 -0
  47. data/vendor/libgit2/include/git2/merge.h +18 -35
  48. data/vendor/libgit2/include/git2/net.h +5 -0
  49. data/vendor/libgit2/include/git2/notes.h +1 -1
  50. data/vendor/libgit2/include/git2/object.h +29 -17
  51. data/vendor/libgit2/include/git2/odb.h +11 -12
  52. data/vendor/libgit2/include/git2/odb_backend.h +9 -10
  53. data/vendor/libgit2/include/git2/oid.h +2 -2
  54. data/vendor/libgit2/include/git2/pack.h +3 -14
  55. data/vendor/libgit2/include/git2/proxy.h +8 -14
  56. data/vendor/libgit2/include/git2/rebase.h +6 -53
  57. data/vendor/libgit2/include/git2/refs.h +15 -33
  58. data/vendor/libgit2/include/git2/refspec.h +0 -17
  59. data/vendor/libgit2/include/git2/remote.h +24 -123
  60. data/vendor/libgit2/include/git2/repository.h +39 -76
  61. data/vendor/libgit2/include/git2/revert.h +4 -6
  62. data/vendor/libgit2/include/git2/revwalk.h +7 -7
  63. data/vendor/libgit2/include/git2/signature.h +2 -2
  64. data/vendor/libgit2/include/git2/stash.h +12 -15
  65. data/vendor/libgit2/include/git2/status.h +20 -33
  66. data/vendor/libgit2/include/git2/submodule.h +12 -30
  67. data/vendor/libgit2/include/git2/sys/commit.h +1 -1
  68. data/vendor/libgit2/include/git2/sys/config.h +13 -13
  69. data/vendor/libgit2/include/git2/sys/filter.h +6 -6
  70. data/vendor/libgit2/include/git2/sys/index.h +0 -3
  71. data/vendor/libgit2/include/git2/sys/mempack.h +35 -35
  72. data/vendor/libgit2/include/git2/sys/merge.h +4 -9
  73. data/vendor/libgit2/include/git2/sys/odb_backend.h +22 -66
  74. data/vendor/libgit2/include/git2/sys/refdb_backend.h +40 -76
  75. data/vendor/libgit2/include/git2/sys/repository.h +1 -5
  76. data/vendor/libgit2/include/git2/sys/stream.h +12 -92
  77. data/vendor/libgit2/include/git2/sys/time.h +31 -0
  78. data/vendor/libgit2/include/git2/sys/transport.h +83 -129
  79. data/vendor/libgit2/include/git2/tag.h +4 -13
  80. data/vendor/libgit2/include/git2/trace.h +2 -2
  81. data/vendor/libgit2/include/git2/transaction.h +0 -1
  82. data/vendor/libgit2/include/git2/transport.h +311 -11
  83. data/vendor/libgit2/include/git2/tree.h +4 -4
  84. data/vendor/libgit2/include/git2/types.h +111 -33
  85. data/vendor/libgit2/include/git2/version.h +4 -4
  86. data/vendor/libgit2/include/git2/worktree.h +13 -48
  87. data/vendor/libgit2/libgit2.pc.in +13 -0
  88. data/vendor/libgit2/src/CMakeLists.txt +164 -96
  89. data/vendor/libgit2/src/annotated_commit.c +8 -15
  90. data/vendor/libgit2/src/apply.c +31 -537
  91. data/vendor/libgit2/src/apply.h +1 -3
  92. data/vendor/libgit2/src/array.h +2 -2
  93. data/vendor/libgit2/src/attr.c +75 -81
  94. data/vendor/libgit2/src/attr_file.c +121 -207
  95. data/vendor/libgit2/src/attr_file.h +9 -9
  96. data/vendor/libgit2/src/attrcache.c +53 -51
  97. data/vendor/libgit2/src/attrcache.h +1 -2
  98. data/vendor/libgit2/src/blame.c +20 -47
  99. data/vendor/libgit2/src/blame.h +1 -2
  100. data/vendor/libgit2/src/blame_git.c +20 -37
  101. data/vendor/libgit2/src/blob.c +42 -128
  102. data/vendor/libgit2/src/blob.h +2 -19
  103. data/vendor/libgit2/src/branch.c +43 -67
  104. data/vendor/libgit2/src/buf_text.c +6 -7
  105. data/vendor/libgit2/src/buffer.c +57 -69
  106. data/vendor/libgit2/src/buffer.h +1 -1
  107. data/vendor/libgit2/src/cache.c +45 -38
  108. data/vendor/libgit2/src/cache.h +3 -3
  109. data/vendor/libgit2/src/cc-compat.h +3 -20
  110. data/vendor/libgit2/src/checkout.c +90 -109
  111. data/vendor/libgit2/src/cherrypick.c +9 -15
  112. data/vendor/libgit2/src/clone.c +27 -49
  113. data/vendor/libgit2/src/clone.h +0 -4
  114. data/vendor/libgit2/src/commit.c +49 -117
  115. data/vendor/libgit2/src/commit.h +0 -7
  116. data/vendor/libgit2/src/commit_list.c +78 -30
  117. data/vendor/libgit2/src/commit_list.h +2 -2
  118. data/vendor/libgit2/src/common.h +91 -27
  119. data/vendor/libgit2/src/config.c +176 -194
  120. data/vendor/libgit2/src/config.h +20 -8
  121. data/vendor/libgit2/src/config_cache.c +35 -41
  122. data/vendor/libgit2/src/config_file.c +753 -439
  123. data/vendor/libgit2/src/config_file.h +73 -0
  124. data/vendor/libgit2/src/config_parse.c +63 -114
  125. data/vendor/libgit2/src/config_parse.h +16 -17
  126. data/vendor/libgit2/src/crlf.c +190 -219
  127. data/vendor/libgit2/src/delta.c +18 -25
  128. data/vendor/libgit2/src/describe.c +41 -42
  129. data/vendor/libgit2/src/diff.c +68 -53
  130. data/vendor/libgit2/src/diff.h +1 -2
  131. data/vendor/libgit2/src/diff_driver.c +49 -47
  132. data/vendor/libgit2/src/diff_file.c +17 -19
  133. data/vendor/libgit2/src/diff_file.h +1 -1
  134. data/vendor/libgit2/src/diff_generate.c +106 -162
  135. data/vendor/libgit2/src/diff_generate.h +3 -3
  136. data/vendor/libgit2/src/diff_parse.c +4 -4
  137. data/vendor/libgit2/src/diff_print.c +30 -42
  138. data/vendor/libgit2/src/diff_stats.c +7 -22
  139. data/vendor/libgit2/src/diff_tform.c +16 -16
  140. data/vendor/libgit2/src/diff_xdiff.c +3 -15
  141. data/vendor/libgit2/src/errors.c +39 -51
  142. data/vendor/libgit2/src/features.h.in +3 -11
  143. data/vendor/libgit2/src/fetch.c +5 -10
  144. data/vendor/libgit2/src/fetchhead.c +17 -17
  145. data/vendor/libgit2/src/filebuf.c +36 -32
  146. data/vendor/libgit2/src/filebuf.h +2 -2
  147. data/vendor/libgit2/src/{futils.c → fileops.c} +73 -80
  148. data/vendor/libgit2/src/{futils.h → fileops.h} +6 -6
  149. data/vendor/libgit2/src/filter.c +38 -46
  150. data/vendor/libgit2/src/filter.h +10 -0
  151. data/vendor/libgit2/src/fnmatch.c +248 -0
  152. data/vendor/libgit2/src/fnmatch.h +48 -0
  153. data/vendor/libgit2/src/global.c +63 -48
  154. data/vendor/libgit2/src/global.h +2 -0
  155. data/vendor/libgit2/src/hash.c +0 -61
  156. data/vendor/libgit2/src/hash.h +19 -20
  157. data/vendor/libgit2/src/hash/hash_collisiondetect.h +47 -0
  158. data/vendor/libgit2/src/hash/{sha1/common_crypto.c → hash_common_crypto.h} +17 -17
  159. data/vendor/libgit2/src/hash/{sha1/generic.c → hash_generic.c} +10 -22
  160. data/vendor/libgit2/src/hash/{sha1/generic.h → hash_generic.h} +10 -4
  161. data/vendor/libgit2/src/hash/hash_openssl.h +59 -0
  162. data/vendor/libgit2/src/hash/{sha1/win32.c → hash_win32.c} +37 -47
  163. data/vendor/libgit2/src/hash/{sha1/win32.h → hash_win32.h} +19 -6
  164. data/vendor/libgit2/src/hash/{sha1/sha1dc → sha1dc}/sha1.c +3 -14
  165. data/vendor/libgit2/src/hash/{sha1/sha1dc → sha1dc}/sha1.h +0 -0
  166. data/vendor/libgit2/src/hash/{sha1/sha1dc → sha1dc}/ubc_check.c +0 -0
  167. data/vendor/libgit2/src/hash/{sha1/sha1dc → sha1dc}/ubc_check.h +0 -0
  168. data/vendor/libgit2/src/hashsig.c +5 -5
  169. data/vendor/libgit2/src/idxmap.c +61 -107
  170. data/vendor/libgit2/src/idxmap.h +31 -153
  171. data/vendor/libgit2/src/ignore.c +47 -43
  172. data/vendor/libgit2/src/index.c +232 -337
  173. data/vendor/libgit2/src/index.h +1 -17
  174. data/vendor/libgit2/src/indexer.c +175 -346
  175. data/vendor/libgit2/src/integer.h +26 -71
  176. data/vendor/libgit2/src/iterator.c +70 -142
  177. data/vendor/libgit2/src/iterator.h +0 -15
  178. data/vendor/libgit2/src/khash.h +1 -3
  179. data/vendor/libgit2/src/map.h +1 -1
  180. data/vendor/libgit2/src/merge.c +100 -144
  181. data/vendor/libgit2/src/merge_driver.c +11 -11
  182. data/vendor/libgit2/src/merge_file.c +2 -2
  183. data/vendor/libgit2/src/mwindow.c +29 -24
  184. data/vendor/libgit2/src/mwindow.h +4 -4
  185. data/vendor/libgit2/src/netops.c +156 -55
  186. data/vendor/libgit2/src/netops.h +23 -3
  187. data/vendor/libgit2/src/notes.c +11 -16
  188. data/vendor/libgit2/src/object.c +69 -120
  189. data/vendor/libgit2/src/object.h +9 -22
  190. data/vendor/libgit2/src/object_api.c +8 -8
  191. data/vendor/libgit2/src/odb.c +93 -116
  192. data/vendor/libgit2/src/odb.h +7 -8
  193. data/vendor/libgit2/src/odb_loose.c +55 -62
  194. data/vendor/libgit2/src/odb_mempack.c +34 -21
  195. data/vendor/libgit2/src/odb_pack.c +14 -18
  196. data/vendor/libgit2/src/offmap.c +35 -53
  197. data/vendor/libgit2/src/offmap.h +21 -108
  198. data/vendor/libgit2/src/oid.c +7 -12
  199. data/vendor/libgit2/src/oidmap.c +47 -49
  200. data/vendor/libgit2/src/oidmap.h +24 -101
  201. data/vendor/libgit2/src/pack-objects.c +87 -88
  202. data/vendor/libgit2/src/pack-objects.h +8 -2
  203. data/vendor/libgit2/src/pack.c +101 -99
  204. data/vendor/libgit2/src/pack.h +19 -17
  205. data/vendor/libgit2/src/parse.c +0 -10
  206. data/vendor/libgit2/src/parse.h +3 -3
  207. data/vendor/libgit2/src/patch.c +4 -4
  208. data/vendor/libgit2/src/patch_generate.c +20 -20
  209. data/vendor/libgit2/src/patch_parse.c +63 -151
  210. data/vendor/libgit2/src/path.c +104 -117
  211. data/vendor/libgit2/src/path.h +71 -3
  212. data/vendor/libgit2/src/pathspec.c +19 -19
  213. data/vendor/libgit2/src/pool.c +22 -26
  214. data/vendor/libgit2/src/pool.h +7 -7
  215. data/vendor/libgit2/src/posix.c +10 -10
  216. data/vendor/libgit2/src/posix.h +1 -12
  217. data/vendor/libgit2/src/proxy.c +3 -8
  218. data/vendor/libgit2/src/push.c +31 -37
  219. data/vendor/libgit2/src/push.h +1 -2
  220. data/vendor/libgit2/src/rebase.c +59 -115
  221. data/vendor/libgit2/src/refdb.c +3 -15
  222. data/vendor/libgit2/src/refdb_fs.c +254 -381
  223. data/vendor/libgit2/src/reflog.c +15 -13
  224. data/vendor/libgit2/src/refs.c +88 -118
  225. data/vendor/libgit2/src/refs.h +3 -5
  226. data/vendor/libgit2/src/refspec.c +37 -56
  227. data/vendor/libgit2/src/refspec.h +1 -1
  228. data/vendor/libgit2/src/remote.c +215 -266
  229. data/vendor/libgit2/src/remote.h +2 -11
  230. data/vendor/libgit2/src/repository.c +225 -280
  231. data/vendor/libgit2/src/repository.h +40 -52
  232. data/vendor/libgit2/src/reset.c +8 -8
  233. data/vendor/libgit2/src/revert.c +9 -14
  234. data/vendor/libgit2/src/revparse.c +48 -47
  235. data/vendor/libgit2/src/revwalk.c +57 -120
  236. data/vendor/libgit2/src/revwalk.h +1 -22
  237. data/vendor/libgit2/src/settings.c +10 -47
  238. data/vendor/libgit2/src/signature.c +11 -11
  239. data/vendor/libgit2/src/sortedcache.c +36 -22
  240. data/vendor/libgit2/src/sortedcache.h +1 -1
  241. data/vendor/libgit2/src/stash.c +99 -125
  242. data/vendor/libgit2/src/status.c +22 -28
  243. data/vendor/libgit2/src/stream.h +2 -17
  244. data/vendor/libgit2/src/streams/curl.c +385 -0
  245. data/vendor/libgit2/src/{allocators/stdalloc.h → streams/curl.h} +5 -5
  246. data/vendor/libgit2/src/streams/openssl.c +114 -224
  247. data/vendor/libgit2/src/streams/openssl.h +108 -4
  248. data/vendor/libgit2/src/streams/socket.c +30 -55
  249. data/vendor/libgit2/src/streams/stransport.c +32 -57
  250. data/vendor/libgit2/src/streams/stransport.h +0 -5
  251. data/vendor/libgit2/src/streams/tls.c +19 -50
  252. data/vendor/libgit2/src/streams/tls.h +4 -12
  253. data/vendor/libgit2/src/strmap.c +74 -47
  254. data/vendor/libgit2/src/strmap.h +33 -108
  255. data/vendor/libgit2/src/submodule.c +216 -272
  256. data/vendor/libgit2/src/submodule.h +1 -1
  257. data/vendor/libgit2/src/sysdir.c +19 -29
  258. data/vendor/libgit2/src/tag.c +28 -41
  259. data/vendor/libgit2/src/tag.h +1 -2
  260. data/vendor/libgit2/src/trace.c +2 -2
  261. data/vendor/libgit2/src/trace.h +3 -3
  262. data/vendor/libgit2/src/trailer.c +38 -52
  263. data/vendor/libgit2/src/transaction.c +29 -30
  264. data/vendor/libgit2/src/transport.c +5 -5
  265. data/vendor/libgit2/src/transports/auth.c +11 -15
  266. data/vendor/libgit2/src/transports/auth.h +3 -10
  267. data/vendor/libgit2/src/transports/auth_negotiate.c +18 -33
  268. data/vendor/libgit2/src/transports/auth_negotiate.h +2 -2
  269. data/vendor/libgit2/src/transports/cred.c +24 -24
  270. data/vendor/libgit2/src/{allocators/win32_crtdbg.h → transports/cred.h} +4 -5
  271. data/vendor/libgit2/src/transports/git.c +31 -26
  272. data/vendor/libgit2/src/transports/http.c +348 -881
  273. data/vendor/libgit2/src/transports/http.h +0 -2
  274. data/vendor/libgit2/src/transports/local.c +35 -35
  275. data/vendor/libgit2/src/transports/smart.c +47 -70
  276. data/vendor/libgit2/src/transports/smart.h +4 -3
  277. data/vendor/libgit2/src/transports/smart_pkt.c +40 -43
  278. data/vendor/libgit2/src/transports/smart_protocol.c +116 -96
  279. data/vendor/libgit2/src/transports/ssh.c +66 -77
  280. data/vendor/libgit2/src/transports/winhttp.c +314 -318
  281. data/vendor/libgit2/src/tree-cache.c +12 -19
  282. data/vendor/libgit2/src/tree.c +142 -103
  283. data/vendor/libgit2/src/tree.h +12 -1
  284. data/vendor/libgit2/src/unix/map.c +3 -3
  285. data/vendor/libgit2/src/unix/posix.h +11 -1
  286. data/vendor/libgit2/src/userdiff.h +1 -3
  287. data/vendor/libgit2/src/util.c +56 -70
  288. data/vendor/libgit2/src/util.h +156 -28
  289. data/vendor/libgit2/src/vector.c +4 -4
  290. data/vendor/libgit2/src/win32/dir.c +3 -3
  291. data/vendor/libgit2/src/win32/findfile.c +3 -3
  292. data/vendor/libgit2/src/win32/map.c +11 -9
  293. data/vendor/libgit2/src/win32/msvc-compat.h +0 -6
  294. data/vendor/libgit2/src/win32/path_w32.c +9 -113
  295. data/vendor/libgit2/src/win32/path_w32.h +29 -18
  296. data/vendor/libgit2/src/win32/posix.h +4 -1
  297. data/vendor/libgit2/src/win32/posix_w32.c +45 -70
  298. data/vendor/libgit2/src/win32/precompiled.h +2 -0
  299. data/vendor/libgit2/src/win32/thread.c +10 -5
  300. data/vendor/libgit2/src/win32/w32_buffer.c +5 -9
  301. data/vendor/libgit2/src/win32/w32_crtdbg_stacktrace.c +2 -3
  302. data/vendor/libgit2/src/win32/w32_crtdbg_stacktrace.h +75 -26
  303. data/vendor/libgit2/src/win32/w32_stack.c +11 -6
  304. data/vendor/libgit2/src/win32/w32_stack.h +3 -3
  305. data/vendor/libgit2/src/win32/w32_util.c +64 -27
  306. data/vendor/libgit2/src/win32/w32_util.h +49 -5
  307. data/vendor/libgit2/src/worktree.c +60 -95
  308. data/vendor/libgit2/src/worktree.h +0 -2
  309. data/vendor/libgit2/src/xdiff/xdiffi.c +5 -7
  310. data/vendor/libgit2/src/xdiff/xhistogram.c +1 -1
  311. data/vendor/libgit2/src/xdiff/xmerge.c +15 -27
  312. data/vendor/libgit2/src/xdiff/xpatience.c +0 -3
  313. data/vendor/libgit2/src/zstream.c +4 -4
  314. metadata +33 -122
  315. data/vendor/libgit2/cmake/Modules/FindGSSFramework.cmake +0 -28
  316. data/vendor/libgit2/cmake/Modules/FindPCRE.cmake +0 -38
  317. data/vendor/libgit2/cmake/Modules/FindPCRE2.cmake +0 -37
  318. data/vendor/libgit2/cmake/Modules/FindmbedTLS.cmake +0 -93
  319. data/vendor/libgit2/cmake/Modules/PkgBuildConfig.cmake +0 -110
  320. data/vendor/libgit2/cmake/Modules/SelectGSSAPI.cmake +0 -53
  321. data/vendor/libgit2/cmake/Modules/SelectHTTPSBackend.cmake +0 -124
  322. data/vendor/libgit2/cmake/Modules/SelectHashes.cmake +0 -66
  323. data/vendor/libgit2/deps/ntlmclient/CMakeLists.txt +0 -21
  324. data/vendor/libgit2/deps/ntlmclient/compat.h +0 -33
  325. data/vendor/libgit2/deps/ntlmclient/crypt.h +0 -64
  326. data/vendor/libgit2/deps/ntlmclient/crypt_commoncrypto.c +0 -120
  327. data/vendor/libgit2/deps/ntlmclient/crypt_commoncrypto.h +0 -18
  328. data/vendor/libgit2/deps/ntlmclient/crypt_mbedtls.c +0 -145
  329. data/vendor/libgit2/deps/ntlmclient/crypt_mbedtls.h +0 -18
  330. data/vendor/libgit2/deps/ntlmclient/crypt_openssl.c +0 -130
  331. data/vendor/libgit2/deps/ntlmclient/crypt_openssl.h +0 -21
  332. data/vendor/libgit2/deps/ntlmclient/ntlm.c +0 -1420
  333. data/vendor/libgit2/deps/ntlmclient/ntlm.h +0 -174
  334. data/vendor/libgit2/deps/ntlmclient/ntlmclient.h +0 -320
  335. data/vendor/libgit2/deps/ntlmclient/unicode.h +0 -36
  336. data/vendor/libgit2/deps/ntlmclient/unicode_builtin.c +0 -445
  337. data/vendor/libgit2/deps/ntlmclient/unicode_iconv.c +0 -201
  338. data/vendor/libgit2/deps/ntlmclient/utf8.h +0 -1257
  339. data/vendor/libgit2/deps/ntlmclient/util.c +0 -21
  340. data/vendor/libgit2/deps/ntlmclient/util.h +0 -14
  341. data/vendor/libgit2/deps/pcre/CMakeLists.txt +0 -140
  342. data/vendor/libgit2/deps/pcre/COPYING +0 -5
  343. data/vendor/libgit2/deps/pcre/cmake/COPYING-CMAKE-SCRIPTS +0 -22
  344. data/vendor/libgit2/deps/pcre/cmake/FindEditline.cmake +0 -17
  345. data/vendor/libgit2/deps/pcre/cmake/FindPackageHandleStandardArgs.cmake +0 -58
  346. data/vendor/libgit2/deps/pcre/cmake/FindReadline.cmake +0 -29
  347. data/vendor/libgit2/deps/pcre/config.h.in +0 -57
  348. data/vendor/libgit2/deps/pcre/pcre.h +0 -641
  349. data/vendor/libgit2/deps/pcre/pcre_byte_order.c +0 -319
  350. data/vendor/libgit2/deps/pcre/pcre_chartables.c +0 -198
  351. data/vendor/libgit2/deps/pcre/pcre_compile.c +0 -9800
  352. data/vendor/libgit2/deps/pcre/pcre_config.c +0 -190
  353. data/vendor/libgit2/deps/pcre/pcre_dfa_exec.c +0 -3676
  354. data/vendor/libgit2/deps/pcre/pcre_exec.c +0 -7173
  355. data/vendor/libgit2/deps/pcre/pcre_fullinfo.c +0 -245
  356. data/vendor/libgit2/deps/pcre/pcre_get.c +0 -669
  357. data/vendor/libgit2/deps/pcre/pcre_globals.c +0 -86
  358. data/vendor/libgit2/deps/pcre/pcre_internal.h +0 -2787
  359. data/vendor/libgit2/deps/pcre/pcre_jit_compile.c +0 -11913
  360. data/vendor/libgit2/deps/pcre/pcre_maketables.c +0 -156
  361. data/vendor/libgit2/deps/pcre/pcre_newline.c +0 -210
  362. data/vendor/libgit2/deps/pcre/pcre_ord2utf8.c +0 -94
  363. data/vendor/libgit2/deps/pcre/pcre_printint.c +0 -834
  364. data/vendor/libgit2/deps/pcre/pcre_refcount.c +0 -92
  365. data/vendor/libgit2/deps/pcre/pcre_string_utils.c +0 -211
  366. data/vendor/libgit2/deps/pcre/pcre_study.c +0 -1686
  367. data/vendor/libgit2/deps/pcre/pcre_tables.c +0 -727
  368. data/vendor/libgit2/deps/pcre/pcre_ucd.c +0 -3644
  369. data/vendor/libgit2/deps/pcre/pcre_valid_utf8.c +0 -301
  370. data/vendor/libgit2/deps/pcre/pcre_version.c +0 -98
  371. data/vendor/libgit2/deps/pcre/pcre_xclass.c +0 -268
  372. data/vendor/libgit2/deps/pcre/pcreposix.c +0 -421
  373. data/vendor/libgit2/deps/pcre/pcreposix.h +0 -117
  374. data/vendor/libgit2/deps/pcre/ucp.h +0 -224
  375. data/vendor/libgit2/deps/winhttp/COPYING.GPL +0 -993
  376. data/vendor/libgit2/deps/winhttp/COPYING.LGPL +0 -502
  377. data/vendor/libgit2/deps/zlib/COPYING +0 -27
  378. data/vendor/libgit2/include/git2/apply.h +0 -149
  379. data/vendor/libgit2/include/git2/cert.h +0 -135
  380. data/vendor/libgit2/include/git2/cred.h +0 -308
  381. data/vendor/libgit2/include/git2/deprecated.h +0 -493
  382. data/vendor/libgit2/include/git2/mailmap.h +0 -115
  383. data/vendor/libgit2/include/git2/sys/alloc.h +0 -101
  384. data/vendor/libgit2/include/git2/sys/cred.h +0 -90
  385. data/vendor/libgit2/include/git2/sys/path.h +0 -64
  386. data/vendor/libgit2/src/alloc.c +0 -43
  387. data/vendor/libgit2/src/alloc.h +0 -40
  388. data/vendor/libgit2/src/allocators/stdalloc.c +0 -119
  389. data/vendor/libgit2/src/allocators/win32_crtdbg.c +0 -118
  390. data/vendor/libgit2/src/config_backend.h +0 -96
  391. data/vendor/libgit2/src/config_entries.c +0 -229
  392. data/vendor/libgit2/src/config_entries.h +0 -24
  393. data/vendor/libgit2/src/config_mem.c +0 -220
  394. data/vendor/libgit2/src/config_snapshot.c +0 -206
  395. data/vendor/libgit2/src/errors.h +0 -81
  396. data/vendor/libgit2/src/hash/sha1.h +0 -38
  397. data/vendor/libgit2/src/hash/sha1/collisiondetect.c +0 -48
  398. data/vendor/libgit2/src/hash/sha1/collisiondetect.h +0 -19
  399. data/vendor/libgit2/src/hash/sha1/common_crypto.h +0 -19
  400. data/vendor/libgit2/src/hash/sha1/mbedtls.c +0 -46
  401. data/vendor/libgit2/src/hash/sha1/mbedtls.h +0 -19
  402. data/vendor/libgit2/src/hash/sha1/openssl.c +0 -59
  403. data/vendor/libgit2/src/hash/sha1/openssl.h +0 -19
  404. data/vendor/libgit2/src/mailmap.c +0 -485
  405. data/vendor/libgit2/src/mailmap.h +0 -35
  406. data/vendor/libgit2/src/net.c +0 -184
  407. data/vendor/libgit2/src/net.h +0 -36
  408. data/vendor/libgit2/src/reader.c +0 -265
  409. data/vendor/libgit2/src/reader.h +0 -107
  410. data/vendor/libgit2/src/regexp.c +0 -221
  411. data/vendor/libgit2/src/regexp.h +0 -97
  412. data/vendor/libgit2/src/streams/mbedtls.c +0 -483
  413. data/vendor/libgit2/src/streams/mbedtls.h +0 -23
  414. data/vendor/libgit2/src/streams/registry.c +0 -118
  415. data/vendor/libgit2/src/streams/registry.h +0 -19
  416. data/vendor/libgit2/src/transports/auth_ntlm.c +0 -223
  417. data/vendor/libgit2/src/transports/auth_ntlm.h +0 -35
  418. data/vendor/libgit2/src/wildmatch.c +0 -320
  419. data/vendor/libgit2/src/wildmatch.h +0 -23
  420. data/vendor/libgit2/src/win32/w32_common.h +0 -39
@@ -181,7 +181,7 @@ static int merge_driver_registry_insert(
181
181
  git_merge_driver_entry *entry;
182
182
 
183
183
  entry = git__calloc(1, sizeof(git_merge_driver_entry) + strlen(name) + 1);
184
- GIT_ERROR_CHECK_ALLOC(entry);
184
+ GITERR_CHECK_ALLOC(entry);
185
185
 
186
186
  strcpy(entry->name, name);
187
187
  entry->driver = driver;
@@ -265,12 +265,12 @@ int git_merge_driver_register(const char *name, git_merge_driver *driver)
265
265
  assert(name && driver);
266
266
 
267
267
  if (git_rwlock_wrlock(&merge_driver_registry.lock) < 0) {
268
- git_error_set(GIT_ERROR_OS, "failed to lock merge driver registry");
268
+ giterr_set(GITERR_OS, "failed to lock merge driver registry");
269
269
  return -1;
270
270
  }
271
271
 
272
272
  if (!merge_driver_registry_find(NULL, name)) {
273
- git_error_set(GIT_ERROR_MERGE, "attempt to reregister existing driver '%s'",
273
+ giterr_set(GITERR_MERGE, "attempt to reregister existing driver '%s'",
274
274
  name);
275
275
  error = GIT_EEXISTS;
276
276
  goto done;
@@ -290,12 +290,12 @@ int git_merge_driver_unregister(const char *name)
290
290
  int error = 0;
291
291
 
292
292
  if (git_rwlock_wrlock(&merge_driver_registry.lock) < 0) {
293
- git_error_set(GIT_ERROR_OS, "failed to lock merge driver registry");
293
+ giterr_set(GITERR_OS, "failed to lock merge driver registry");
294
294
  return -1;
295
295
  }
296
296
 
297
297
  if ((entry = merge_driver_registry_lookup(&pos, name)) == NULL) {
298
- git_error_set(GIT_ERROR_MERGE, "cannot find merge driver '%s' to unregister",
298
+ giterr_set(GITERR_MERGE, "cannot find merge driver '%s' to unregister",
299
299
  name);
300
300
  error = GIT_ENOTFOUND;
301
301
  goto done;
@@ -332,7 +332,7 @@ git_merge_driver *git_merge_driver_lookup(const char *name)
332
332
  return &git_merge_driver__binary;
333
333
 
334
334
  if (git_rwlock_rdlock(&merge_driver_registry.lock) < 0) {
335
- git_error_set(GIT_ERROR_OS, "failed to lock merge driver registry");
335
+ giterr_set(GITERR_OS, "failed to lock merge driver registry");
336
336
  return NULL;
337
337
  }
338
338
 
@@ -341,7 +341,7 @@ git_merge_driver *git_merge_driver_lookup(const char *name)
341
341
  git_rwlock_rdunlock(&merge_driver_registry.lock);
342
342
 
343
343
  if (entry == NULL) {
344
- git_error_set(GIT_ERROR_MERGE, "cannot use an unregistered filter");
344
+ giterr_set(GITERR_MERGE, "cannot use an unregistered filter");
345
345
  return NULL;
346
346
  }
347
347
 
@@ -371,17 +371,17 @@ static int merge_driver_name_for_path(
371
371
  return error;
372
372
 
373
373
  /* set: use the built-in 3-way merge driver ("text") */
374
- if (GIT_ATTR_IS_TRUE(value))
374
+ if (GIT_ATTR_TRUE(value))
375
375
  *out = merge_driver_name__text;
376
376
 
377
377
  /* unset: do not merge ("binary") */
378
- else if (GIT_ATTR_IS_FALSE(value))
378
+ else if (GIT_ATTR_FALSE(value))
379
379
  *out = merge_driver_name__binary;
380
380
 
381
- else if (GIT_ATTR_IS_UNSPECIFIED(value) && default_driver)
381
+ else if (GIT_ATTR_UNSPECIFIED(value) && default_driver)
382
382
  *out = default_driver;
383
383
 
384
- else if (GIT_ATTR_IS_UNSPECIFIED(value))
384
+ else if (GIT_ATTR_UNSPECIFIED(value))
385
385
  *out = merge_driver_name__text;
386
386
 
387
387
  else
@@ -9,7 +9,7 @@
9
9
 
10
10
  #include "repository.h"
11
11
  #include "posix.h"
12
- #include "futils.h"
12
+ #include "fileops.h"
13
13
  #include "index.h"
14
14
  #include "diff_xdiff.h"
15
15
  #include "merge.h"
@@ -130,7 +130,7 @@ static int merge_file__xdiff(
130
130
 
131
131
  if ((xdl_result = xdl_merge(&ancestor_mmfile, &our_mmfile,
132
132
  &their_mmfile, &xmparam, &mmbuffer)) < 0) {
133
- git_error_set(GIT_ERROR_MERGE, "failed to merge files");
133
+ giterr_set(GITERR_MERGE, "failed to merge files");
134
134
  error = -1;
135
135
  goto done;
136
136
  }
@@ -8,7 +8,7 @@
8
8
  #include "mwindow.h"
9
9
 
10
10
  #include "vector.h"
11
- #include "futils.h"
11
+ #include "fileops.h"
12
12
  #include "map.h"
13
13
  #include "global.h"
14
14
  #include "strmap.h"
@@ -44,28 +44,31 @@ int git_mwindow_global_init(void)
44
44
  assert(!git__pack_cache);
45
45
 
46
46
  git__on_shutdown(git_mwindow_files_free);
47
- return git_strmap_new(&git__pack_cache);
47
+ return git_strmap_alloc(&git__pack_cache);
48
48
  }
49
49
 
50
50
  int git_mwindow_get_pack(struct git_pack_file **out, const char *path)
51
51
  {
52
- struct git_pack_file *pack;
53
- char *packname;
54
52
  int error;
53
+ char *packname;
54
+ git_strmap_iter pos;
55
+ struct git_pack_file *pack;
55
56
 
56
57
  if ((error = git_packfile__name(&packname, path)) < 0)
57
58
  return error;
58
59
 
59
60
  if (git_mutex_lock(&git__mwindow_mutex) < 0) {
60
- git_error_set(GIT_ERROR_OS, "failed to lock mwindow mutex");
61
+ giterr_set(GITERR_OS, "failed to lock mwindow mutex");
61
62
  return -1;
62
63
  }
63
64
 
64
- pack = git_strmap_get(git__pack_cache, packname);
65
+ pos = git_strmap_lookup_index(git__pack_cache, packname);
65
66
  git__free(packname);
66
67
 
67
- if (pack != NULL) {
68
+ if (git_strmap_valid_index(git__pack_cache, pos)) {
69
+ pack = git_strmap_value_at(git__pack_cache, pos);
68
70
  git_atomic_inc(&pack->refcount);
71
+
69
72
  git_mutex_unlock(&git__mwindow_mutex);
70
73
  *out = pack;
71
74
  return 0;
@@ -79,7 +82,7 @@ int git_mwindow_get_pack(struct git_pack_file **out, const char *path)
79
82
 
80
83
  git_atomic_inc(&pack->refcount);
81
84
 
82
- error = git_strmap_set(git__pack_cache, pack->pack_name, pack);
85
+ git_strmap_insert(git__pack_cache, pack->pack_name, pack, &error);
83
86
  git_mutex_unlock(&git__mwindow_mutex);
84
87
 
85
88
  if (error < 0) {
@@ -94,6 +97,7 @@ int git_mwindow_get_pack(struct git_pack_file **out, const char *path)
94
97
  void git_mwindow_put_pack(struct git_pack_file *pack)
95
98
  {
96
99
  int count;
100
+ git_strmap_iter pos;
97
101
 
98
102
  if (git_mutex_lock(&git__mwindow_mutex) < 0)
99
103
  return;
@@ -101,12 +105,13 @@ void git_mwindow_put_pack(struct git_pack_file *pack)
101
105
  /* put before get would be a corrupted state */
102
106
  assert(git__pack_cache);
103
107
 
108
+ pos = git_strmap_lookup_index(git__pack_cache, pack->pack_name);
104
109
  /* if we cannot find it, the state is corrupted */
105
- assert(git_strmap_exists(git__pack_cache, pack->pack_name));
110
+ assert(git_strmap_valid_index(git__pack_cache, pos));
106
111
 
107
112
  count = git_atomic_dec(&pack->refcount);
108
113
  if (count == 0) {
109
- git_strmap_delete(git__pack_cache, pack->pack_name);
114
+ git_strmap_delete_at(git__pack_cache, pos);
110
115
  git_packfile_free(pack);
111
116
  }
112
117
 
@@ -117,7 +122,7 @@ void git_mwindow_put_pack(struct git_pack_file *pack)
117
122
  void git_mwindow_free_all(git_mwindow_file *mwf)
118
123
  {
119
124
  if (git_mutex_lock(&git__mwindow_mutex)) {
120
- git_error_set(GIT_ERROR_THREAD, "unable to lock mwindow mutex");
125
+ giterr_set(GITERR_THREAD, "unable to lock mwindow mutex");
121
126
  return;
122
127
  }
123
128
 
@@ -167,11 +172,11 @@ void git_mwindow_free_all_locked(git_mwindow_file *mwf)
167
172
  /*
168
173
  * Check if a window 'win' contains the address 'offset'
169
174
  */
170
- int git_mwindow_contains(git_mwindow *win, off64_t offset)
175
+ int git_mwindow_contains(git_mwindow *win, git_off_t offset)
171
176
  {
172
- off64_t win_off = win->offset;
177
+ git_off_t win_off = win->offset;
173
178
  return win_off <= offset
174
- && offset <= (off64_t)(win_off + win->window_map.len);
179
+ && offset <= (git_off_t)(win_off + win->window_map.len);
175
180
  }
176
181
 
177
182
  /*
@@ -224,7 +229,7 @@ static int git_mwindow_close_lru(git_mwindow_file *mwf)
224
229
  }
225
230
 
226
231
  if (!lru_w) {
227
- git_error_set(GIT_ERROR_OS, "failed to close memory window; couldn't find LRU");
232
+ giterr_set(GITERR_OS, "failed to close memory window; couldn't find LRU");
228
233
  return -1;
229
234
  }
230
235
 
@@ -246,12 +251,12 @@ static int git_mwindow_close_lru(git_mwindow_file *mwf)
246
251
  static git_mwindow *new_window(
247
252
  git_mwindow_file *mwf,
248
253
  git_file fd,
249
- off64_t size,
250
- off64_t offset)
254
+ git_off_t size,
255
+ git_off_t offset)
251
256
  {
252
257
  git_mwindow_ctl *ctl = &mem_ctl;
253
258
  size_t walign = git_mwindow__window_size / 2;
254
- off64_t len;
259
+ git_off_t len;
255
260
  git_mwindow *w;
256
261
 
257
262
  w = git__malloc(sizeof(*w));
@@ -263,8 +268,8 @@ static git_mwindow *new_window(
263
268
  w->offset = (offset / walign) * walign;
264
269
 
265
270
  len = size - w->offset;
266
- if (len > (off64_t)git_mwindow__window_size)
267
- len = (off64_t)git_mwindow__window_size;
271
+ if (len > (git_off_t)git_mwindow__window_size)
272
+ len = (git_off_t)git_mwindow__window_size;
268
273
 
269
274
  ctl->mapped += (size_t)len;
270
275
 
@@ -311,7 +316,7 @@ static git_mwindow *new_window(
311
316
  unsigned char *git_mwindow_open(
312
317
  git_mwindow_file *mwf,
313
318
  git_mwindow **cursor,
314
- off64_t offset,
319
+ git_off_t offset,
315
320
  size_t extra,
316
321
  unsigned int *left)
317
322
  {
@@ -319,7 +324,7 @@ unsigned char *git_mwindow_open(
319
324
  git_mwindow *w = *cursor;
320
325
 
321
326
  if (git_mutex_lock(&git__mwindow_mutex)) {
322
- git_error_set(GIT_ERROR_THREAD, "unable to lock mwindow mutex");
327
+ giterr_set(GITERR_THREAD, "unable to lock mwindow mutex");
323
328
  return NULL;
324
329
  }
325
330
 
@@ -371,7 +376,7 @@ int git_mwindow_file_register(git_mwindow_file *mwf)
371
376
  int ret;
372
377
 
373
378
  if (git_mutex_lock(&git__mwindow_mutex)) {
374
- git_error_set(GIT_ERROR_THREAD, "unable to lock mwindow mutex");
379
+ giterr_set(GITERR_THREAD, "unable to lock mwindow mutex");
375
380
  return -1;
376
381
  }
377
382
 
@@ -411,7 +416,7 @@ void git_mwindow_close(git_mwindow **window)
411
416
  git_mwindow *w = *window;
412
417
  if (w) {
413
418
  if (git_mutex_lock(&git__mwindow_mutex)) {
414
- git_error_set(GIT_ERROR_THREAD, "unable to lock mwindow mutex");
419
+ giterr_set(GITERR_THREAD, "unable to lock mwindow mutex");
415
420
  return;
416
421
  }
417
422
 
@@ -16,7 +16,7 @@
16
16
  typedef struct git_mwindow {
17
17
  struct git_mwindow *next;
18
18
  git_map window_map;
19
- off64_t offset;
19
+ git_off_t offset;
20
20
  size_t last_used;
21
21
  size_t inuse_cnt;
22
22
  } git_mwindow;
@@ -24,7 +24,7 @@ typedef struct git_mwindow {
24
24
  typedef struct git_mwindow_file {
25
25
  git_mwindow *windows;
26
26
  int fd;
27
- off64_t size;
27
+ git_off_t size;
28
28
  } git_mwindow_file;
29
29
 
30
30
  typedef struct git_mwindow_ctl {
@@ -37,10 +37,10 @@ typedef struct git_mwindow_ctl {
37
37
  git_vector windowfiles;
38
38
  } git_mwindow_ctl;
39
39
 
40
- int git_mwindow_contains(git_mwindow *win, off64_t offset);
40
+ int git_mwindow_contains(git_mwindow *win, git_off_t offset);
41
41
  void git_mwindow_free_all(git_mwindow_file *mwf); /* locks */
42
42
  void git_mwindow_free_all_locked(git_mwindow_file *mwf); /* run under lock */
43
- unsigned char *git_mwindow_open(git_mwindow_file *mwf, git_mwindow **cursor, off64_t offset, size_t extra, unsigned int *left);
43
+ unsigned char *git_mwindow_open(git_mwindow_file *mwf, git_mwindow **cursor, git_off_t offset, size_t extra, unsigned int *left);
44
44
  int git_mwindow_file_register(git_mwindow_file *mwf);
45
45
  void git_mwindow_file_deregister(git_mwindow_file *mwf);
46
46
  void git_mwindow_close(git_mwindow **w_cursor);
@@ -37,17 +37,14 @@ void gitno_buffer_setup_callback(
37
37
  static int recv_stream(gitno_buffer *buf)
38
38
  {
39
39
  git_stream *io = (git_stream *) buf->cb_data;
40
- size_t readlen = buf->len - buf->offset;
41
- ssize_t ret;
40
+ int ret;
42
41
 
43
- readlen = min(readlen, INT_MAX);
44
-
45
- ret = git_stream_read(io, buf->data + buf->offset, (int)readlen);
42
+ ret = git_stream_read(io, buf->data + buf->offset, buf->len - buf->offset);
46
43
  if (ret < 0)
47
44
  return -1;
48
45
 
49
46
  buf->offset += ret;
50
- return (int)ret;
47
+ return ret;
51
48
  }
52
49
 
53
50
  void gitno_buffer_setup_fromstream(git_stream *st, gitno_buffer *buf, char *data, size_t len)
@@ -122,79 +119,183 @@ int gitno__match_host(const char *pattern, const char *host)
122
119
  return -1;
123
120
  }
124
121
 
125
- int gitno_connection_data_handle_redirect(
126
- git_net_url *url,
127
- const char *redirect_str,
122
+ static const char *prefix_http = "http://";
123
+ static const char *prefix_https = "https://";
124
+
125
+ int gitno_connection_data_from_url(
126
+ gitno_connection_data *data,
127
+ const char *url,
128
128
  const char *service_suffix)
129
129
  {
130
- git_net_url tmp = GIT_NET_URL_INIT;
131
- int error = 0;
130
+ int error = -1;
131
+ const char *default_port = NULL, *path_search_start = NULL;
132
+ char *original_host = NULL;
132
133
 
133
- assert(url && redirect_str);
134
+ /* service_suffix is optional */
135
+ assert(data && url);
134
136
 
135
- if (redirect_str[0] == '/') {
136
- git__free(url->path);
137
+ /* Save these for comparison later */
138
+ original_host = data->host;
139
+ data->host = NULL;
140
+ gitno_connection_data_free_ptrs(data);
137
141
 
138
- if ((url->path = git__strdup(redirect_str)) == NULL) {
139
- error = -1;
140
- goto done;
142
+ if (!git__prefixcmp(url, prefix_http)) {
143
+ path_search_start = url + strlen(prefix_http);
144
+ default_port = "80";
145
+
146
+ if (data->use_ssl) {
147
+ giterr_set(GITERR_NET, "redirect from HTTPS to HTTP is not allowed");
148
+ goto cleanup;
141
149
  }
142
- } else {
143
- git_net_url *original = url;
150
+ } else if (!git__prefixcmp(url, prefix_https)) {
151
+ path_search_start = url + strlen(prefix_https);
152
+ default_port = "443";
153
+ data->use_ssl = true;
154
+ } else if (url[0] == '/')
155
+ default_port = data->use_ssl ? "443" : "80";
156
+
157
+ if (!default_port) {
158
+ giterr_set(GITERR_NET, "unrecognized URL prefix");
159
+ goto cleanup;
160
+ }
144
161
 
145
- if ((error = git_net_url_parse(&tmp, redirect_str)) < 0)
146
- goto done;
162
+ error = gitno_extract_url_parts(
163
+ &data->host, &data->port, &data->path, &data->user, &data->pass,
164
+ url, default_port);
147
165
 
148
- /* Validate that this is a legal redirection */
166
+ if (url[0] == '/') {
167
+ /* Relative redirect; reuse original host name and port */
168
+ path_search_start = url;
169
+ git__free(data->host);
170
+ data->host = original_host;
171
+ original_host = NULL;
172
+ }
149
173
 
150
- if (original->scheme &&
151
- strcmp(original->scheme, tmp.scheme) != 0 &&
152
- strcmp(tmp.scheme, "https") != 0) {
153
- git_error_set(GIT_ERROR_NET, "cannot redirect from '%s' to '%s'",
154
- original->scheme, tmp.scheme);
174
+ if (!error) {
175
+ const char *path = strchr(path_search_start, '/');
176
+ size_t pathlen = strlen(path);
177
+ size_t suffixlen = service_suffix ? strlen(service_suffix) : 0;
178
+
179
+ if (suffixlen &&
180
+ !memcmp(path + pathlen - suffixlen, service_suffix, suffixlen)) {
181
+ git__free(data->path);
182
+ data->path = git__strndup(path, pathlen - suffixlen);
183
+ } else {
184
+ git__free(data->path);
185
+ data->path = git__strdup(path);
186
+ }
155
187
 
188
+ /* Check for errors in the resulting data */
189
+ if (original_host && url[0] != '/' && strcmp(original_host, data->host)) {
190
+ giterr_set(GITERR_NET, "cross host redirect not allowed");
156
191
  error = -1;
157
- goto done;
158
192
  }
193
+ }
159
194
 
160
- if (original->host &&
161
- git__strcasecmp(original->host, tmp.host) != 0) {
162
- git_error_set(GIT_ERROR_NET, "cannot redirect from '%s' to '%s'",
163
- original->host, tmp.host);
195
+ cleanup:
196
+ if (original_host) git__free(original_host);
197
+ return error;
198
+ }
164
199
 
165
- error = -1;
166
- goto done;
167
- }
200
+ void gitno_connection_data_free_ptrs(gitno_connection_data *d)
201
+ {
202
+ git__free(d->host); d->host = NULL;
203
+ git__free(d->port); d->port = NULL;
204
+ git__free(d->path); d->path = NULL;
205
+ git__free(d->user); d->user = NULL;
206
+ git__free(d->pass); d->pass = NULL;
207
+ }
168
208
 
169
- git_net_url_swap(url, &tmp);
209
+ int gitno_extract_url_parts(
210
+ char **host_out,
211
+ char **port_out,
212
+ char **path_out,
213
+ char **username_out,
214
+ char **password_out,
215
+ const char *url,
216
+ const char *default_port)
217
+ {
218
+ struct http_parser_url u = {0};
219
+ bool has_host, has_port, has_path, has_userinfo;
220
+ git_buf host = GIT_BUF_INIT,
221
+ port = GIT_BUF_INIT,
222
+ path = GIT_BUF_INIT,
223
+ username = GIT_BUF_INIT,
224
+ password = GIT_BUF_INIT;
225
+ int error = 0;
226
+
227
+ if (http_parser_parse_url(url, strlen(url), false, &u)) {
228
+ giterr_set(GITERR_NET, "malformed URL '%s'", url);
229
+ error = GIT_EINVALIDSPEC;
230
+ goto done;
170
231
  }
171
232
 
172
- /* Remove the service suffix if it was given to us */
173
- if (service_suffix) {
174
- const char *service_query = strchr(service_suffix, '?');
175
- size_t suffix_len = service_query ?
176
- (size_t)(service_query - service_suffix) : strlen(service_suffix);
177
- size_t path_len = strlen(url->path);
233
+ has_host = !!(u.field_set & (1 << UF_HOST));
234
+ has_port = !!(u.field_set & (1 << UF_PORT));
235
+ has_path = !!(u.field_set & (1 << UF_PATH));
236
+ has_userinfo = !!(u.field_set & (1 << UF_USERINFO));
178
237
 
179
- if (suffix_len && path_len >= suffix_len) {
180
- size_t suffix_offset = path_len - suffix_len;
238
+ if (has_host) {
239
+ const char *url_host = url + u.field_data[UF_HOST].off;
240
+ size_t url_host_len = u.field_data[UF_HOST].len;
241
+ git_buf_decode_percent(&host, url_host, url_host_len);
242
+ }
181
243
 
182
- if (git__strncmp(url->path + suffix_offset, service_suffix, suffix_len) == 0 &&
183
- (!service_query || git__strcmp(url->query, service_query + 1) == 0)) {
184
- /* Ensure we leave a minimum of '/' as the path */
185
- if (suffix_offset == 0)
186
- suffix_offset++;
244
+ if (has_port) {
245
+ const char *url_port = url + u.field_data[UF_PORT].off;
246
+ size_t url_port_len = u.field_data[UF_PORT].len;
247
+ git_buf_put(&port, url_port, url_port_len);
248
+ } else {
249
+ git_buf_puts(&port, default_port);
250
+ }
187
251
 
188
- url->path[suffix_offset] = '\0';
252
+ if (has_path && path_out) {
253
+ const char *url_path = url + u.field_data[UF_PATH].off;
254
+ size_t url_path_len = u.field_data[UF_PATH].len;
255
+ git_buf_decode_percent(&path, url_path, url_path_len);
256
+ } else if (path_out) {
257
+ giterr_set(GITERR_NET, "invalid url, missing path");
258
+ error = GIT_EINVALIDSPEC;
259
+ goto done;
260
+ }
189
261
 
190
- git__free(url->query);
191
- url->query = NULL;
192
- }
262
+ if (has_userinfo) {
263
+ const char *url_userinfo = url + u.field_data[UF_USERINFO].off;
264
+ size_t url_userinfo_len = u.field_data[UF_USERINFO].len;
265
+ const char *colon = memchr(url_userinfo, ':', url_userinfo_len);
266
+
267
+ if (colon) {
268
+ const char *url_username = url_userinfo;
269
+ size_t url_username_len = colon - url_userinfo;
270
+ const char *url_password = colon + 1;
271
+ size_t url_password_len = url_userinfo_len - (url_username_len + 1);
272
+
273
+ git_buf_decode_percent(&username, url_username, url_username_len);
274
+ git_buf_decode_percent(&password, url_password, url_password_len);
275
+ } else {
276
+ git_buf_decode_percent(&username, url_userinfo, url_userinfo_len);
193
277
  }
194
278
  }
195
279
 
280
+ if (git_buf_oom(&host) ||
281
+ git_buf_oom(&port) ||
282
+ git_buf_oom(&path) ||
283
+ git_buf_oom(&username) ||
284
+ git_buf_oom(&password))
285
+ return -1;
286
+
287
+ *host_out = git_buf_detach(&host);
288
+ *port_out = git_buf_detach(&port);
289
+ if (path_out)
290
+ *path_out = git_buf_detach(&path);
291
+ *username_out = git_buf_detach(&username);
292
+ *password_out = git_buf_detach(&password);
293
+
196
294
  done:
197
- git_net_url_dispose(&tmp);
295
+ git_buf_free(&host);
296
+ git_buf_free(&port);
297
+ git_buf_free(&path);
298
+ git_buf_free(&username);
299
+ git_buf_free(&password);
198
300
  return error;
199
301
  }
200
-