rugged 0.28.3.1 → 0.28.4

Sign up to get free protection for your applications and to get access to all the features.
Files changed (350) hide show
  1. checksums.yaml +4 -4
  2. data/lib/rugged/version.rb +1 -1
  3. data/vendor/libgit2/AUTHORS +1 -0
  4. data/vendor/libgit2/CMakeLists.txt +36 -16
  5. data/vendor/libgit2/COPYING +28 -0
  6. data/vendor/libgit2/cmake/Modules/EnableWarnings.cmake +5 -1
  7. data/vendor/libgit2/cmake/Modules/FindCoreFoundation.cmake +2 -2
  8. data/vendor/libgit2/cmake/Modules/FindGSSAPI.cmake +1 -1
  9. data/vendor/libgit2/cmake/Modules/FindGSSFramework.cmake +28 -0
  10. data/vendor/libgit2/cmake/Modules/FindPCRE.cmake +38 -0
  11. data/vendor/libgit2/cmake/Modules/FindPCRE2.cmake +37 -0
  12. data/vendor/libgit2/cmake/Modules/FindSecurity.cmake +2 -2
  13. data/vendor/libgit2/cmake/Modules/FindStatNsec.cmake +6 -0
  14. data/vendor/libgit2/cmake/Modules/PkgBuildConfig.cmake +110 -0
  15. data/vendor/libgit2/cmake/Modules/SelectGSSAPI.cmake +53 -0
  16. data/vendor/libgit2/cmake/Modules/SelectHTTPSBackend.cmake +124 -0
  17. data/vendor/libgit2/cmake/Modules/SelectHashes.cmake +66 -0
  18. data/vendor/libgit2/deps/http-parser/http_parser.c +11 -6
  19. data/vendor/libgit2/deps/ntlmclient/CMakeLists.txt +21 -0
  20. data/vendor/libgit2/deps/ntlmclient/compat.h +33 -0
  21. data/vendor/libgit2/deps/ntlmclient/crypt.h +64 -0
  22. data/vendor/libgit2/deps/ntlmclient/crypt_commoncrypto.c +120 -0
  23. data/vendor/libgit2/deps/ntlmclient/crypt_commoncrypto.h +18 -0
  24. data/vendor/libgit2/deps/ntlmclient/crypt_mbedtls.c +145 -0
  25. data/vendor/libgit2/deps/ntlmclient/crypt_mbedtls.h +18 -0
  26. data/vendor/libgit2/deps/ntlmclient/crypt_openssl.c +130 -0
  27. data/vendor/libgit2/deps/ntlmclient/crypt_openssl.h +21 -0
  28. data/vendor/libgit2/deps/ntlmclient/ntlm.c +1420 -0
  29. data/vendor/libgit2/deps/ntlmclient/ntlm.h +174 -0
  30. data/vendor/libgit2/deps/ntlmclient/ntlmclient.h +320 -0
  31. data/vendor/libgit2/deps/ntlmclient/unicode.h +36 -0
  32. data/vendor/libgit2/deps/ntlmclient/unicode_builtin.c +445 -0
  33. data/vendor/libgit2/deps/ntlmclient/unicode_iconv.c +201 -0
  34. data/vendor/libgit2/deps/ntlmclient/utf8.h +1257 -0
  35. data/vendor/libgit2/deps/ntlmclient/util.c +21 -0
  36. data/vendor/libgit2/deps/ntlmclient/util.h +14 -0
  37. data/vendor/libgit2/deps/pcre/CMakeLists.txt +140 -0
  38. data/vendor/libgit2/deps/pcre/COPYING +5 -0
  39. data/vendor/libgit2/deps/pcre/cmake/COPYING-CMAKE-SCRIPTS +22 -0
  40. data/vendor/libgit2/deps/pcre/cmake/FindEditline.cmake +17 -0
  41. data/vendor/libgit2/deps/pcre/cmake/FindPackageHandleStandardArgs.cmake +58 -0
  42. data/vendor/libgit2/deps/pcre/cmake/FindReadline.cmake +29 -0
  43. data/vendor/libgit2/deps/pcre/config.h.in +57 -0
  44. data/vendor/libgit2/deps/pcre/pcre.h +641 -0
  45. data/vendor/libgit2/deps/pcre/pcre_byte_order.c +319 -0
  46. data/vendor/libgit2/deps/pcre/pcre_chartables.c +198 -0
  47. data/vendor/libgit2/deps/pcre/pcre_compile.c +9800 -0
  48. data/vendor/libgit2/deps/pcre/pcre_config.c +190 -0
  49. data/vendor/libgit2/deps/pcre/pcre_dfa_exec.c +3676 -0
  50. data/vendor/libgit2/deps/pcre/pcre_exec.c +7173 -0
  51. data/vendor/libgit2/deps/pcre/pcre_fullinfo.c +245 -0
  52. data/vendor/libgit2/deps/pcre/pcre_get.c +669 -0
  53. data/vendor/libgit2/deps/pcre/pcre_globals.c +86 -0
  54. data/vendor/libgit2/deps/pcre/pcre_internal.h +2787 -0
  55. data/vendor/libgit2/deps/pcre/pcre_jit_compile.c +11913 -0
  56. data/vendor/libgit2/deps/pcre/pcre_maketables.c +156 -0
  57. data/vendor/libgit2/deps/pcre/pcre_newline.c +210 -0
  58. data/vendor/libgit2/deps/pcre/pcre_ord2utf8.c +94 -0
  59. data/vendor/libgit2/deps/pcre/pcre_printint.c +834 -0
  60. data/vendor/libgit2/deps/pcre/pcre_refcount.c +92 -0
  61. data/vendor/libgit2/deps/pcre/pcre_string_utils.c +211 -0
  62. data/vendor/libgit2/deps/pcre/pcre_study.c +1686 -0
  63. data/vendor/libgit2/deps/pcre/pcre_tables.c +727 -0
  64. data/vendor/libgit2/deps/pcre/pcre_ucd.c +3644 -0
  65. data/vendor/libgit2/deps/pcre/pcre_valid_utf8.c +301 -0
  66. data/vendor/libgit2/deps/pcre/pcre_version.c +98 -0
  67. data/vendor/libgit2/deps/pcre/pcre_xclass.c +268 -0
  68. data/vendor/libgit2/deps/pcre/pcreposix.c +421 -0
  69. data/vendor/libgit2/deps/pcre/pcreposix.h +117 -0
  70. data/vendor/libgit2/deps/pcre/ucp.h +224 -0
  71. data/vendor/libgit2/deps/zlib/adler32.c +0 -7
  72. data/vendor/libgit2/deps/zlib/crc32.c +0 -7
  73. data/vendor/libgit2/include/git2.h +2 -0
  74. data/vendor/libgit2/include/git2/apply.h +22 -2
  75. data/vendor/libgit2/include/git2/attr.h +19 -12
  76. data/vendor/libgit2/include/git2/blame.h +2 -2
  77. data/vendor/libgit2/include/git2/blob.h +44 -12
  78. data/vendor/libgit2/include/git2/buffer.h +20 -14
  79. data/vendor/libgit2/include/git2/cert.h +135 -0
  80. data/vendor/libgit2/include/git2/checkout.h +46 -14
  81. data/vendor/libgit2/include/git2/cherrypick.h +3 -3
  82. data/vendor/libgit2/include/git2/clone.h +2 -2
  83. data/vendor/libgit2/include/git2/commit.h +23 -1
  84. data/vendor/libgit2/include/git2/common.h +7 -5
  85. data/vendor/libgit2/include/git2/config.h +12 -12
  86. data/vendor/libgit2/include/git2/cred.h +308 -0
  87. data/vendor/libgit2/include/git2/deprecated.h +243 -3
  88. data/vendor/libgit2/include/git2/describe.h +4 -4
  89. data/vendor/libgit2/include/git2/diff.h +16 -14
  90. data/vendor/libgit2/include/git2/filter.h +8 -0
  91. data/vendor/libgit2/include/git2/index.h +2 -1
  92. data/vendor/libgit2/include/git2/indexer.h +48 -4
  93. data/vendor/libgit2/include/git2/merge.h +6 -10
  94. data/vendor/libgit2/include/git2/net.h +0 -5
  95. data/vendor/libgit2/include/git2/object.h +2 -14
  96. data/vendor/libgit2/include/git2/odb.h +3 -2
  97. data/vendor/libgit2/include/git2/odb_backend.h +5 -4
  98. data/vendor/libgit2/include/git2/oid.h +1 -1
  99. data/vendor/libgit2/include/git2/pack.h +12 -1
  100. data/vendor/libgit2/include/git2/proxy.h +5 -3
  101. data/vendor/libgit2/include/git2/rebase.h +46 -2
  102. data/vendor/libgit2/include/git2/refs.h +19 -0
  103. data/vendor/libgit2/include/git2/remote.h +35 -12
  104. data/vendor/libgit2/include/git2/repository.h +24 -2
  105. data/vendor/libgit2/include/git2/revert.h +1 -1
  106. data/vendor/libgit2/include/git2/stash.h +3 -3
  107. data/vendor/libgit2/include/git2/status.h +25 -16
  108. data/vendor/libgit2/include/git2/submodule.h +20 -3
  109. data/vendor/libgit2/include/git2/sys/alloc.h +9 -9
  110. data/vendor/libgit2/include/git2/sys/cred.h +90 -0
  111. data/vendor/libgit2/include/git2/sys/odb_backend.h +48 -4
  112. data/vendor/libgit2/include/git2/sys/refdb_backend.h +57 -21
  113. data/vendor/libgit2/include/git2/sys/repository.h +5 -1
  114. data/vendor/libgit2/include/git2/sys/transport.h +2 -2
  115. data/vendor/libgit2/include/git2/tag.h +11 -2
  116. data/vendor/libgit2/include/git2/trace.h +2 -2
  117. data/vendor/libgit2/include/git2/transport.h +11 -340
  118. data/vendor/libgit2/include/git2/tree.h +1 -1
  119. data/vendor/libgit2/include/git2/types.h +4 -89
  120. data/vendor/libgit2/include/git2/version.h +2 -2
  121. data/vendor/libgit2/include/git2/worktree.h +5 -5
  122. data/vendor/libgit2/src/CMakeLists.txt +88 -222
  123. data/vendor/libgit2/src/alloc.c +2 -14
  124. data/vendor/libgit2/src/{stdalloc.c → allocators/stdalloc.c} +3 -4
  125. data/vendor/libgit2/src/{stdalloc.h → allocators/stdalloc.h} +4 -4
  126. data/vendor/libgit2/src/allocators/win32_crtdbg.c +118 -0
  127. data/vendor/libgit2/src/{transports/cred.h → allocators/win32_crtdbg.h} +5 -4
  128. data/vendor/libgit2/src/apply.c +60 -30
  129. data/vendor/libgit2/src/attr.c +70 -64
  130. data/vendor/libgit2/src/attr_file.c +189 -96
  131. data/vendor/libgit2/src/attr_file.h +9 -9
  132. data/vendor/libgit2/src/attrcache.c +44 -46
  133. data/vendor/libgit2/src/attrcache.h +2 -1
  134. data/vendor/libgit2/src/blame.c +17 -5
  135. data/vendor/libgit2/src/blame.h +1 -1
  136. data/vendor/libgit2/src/blame_git.c +21 -7
  137. data/vendor/libgit2/src/blob.c +81 -17
  138. data/vendor/libgit2/src/blob.h +2 -2
  139. data/vendor/libgit2/src/branch.c +29 -5
  140. data/vendor/libgit2/src/buffer.c +14 -7
  141. data/vendor/libgit2/src/cache.c +26 -33
  142. data/vendor/libgit2/src/cache.h +1 -1
  143. data/vendor/libgit2/src/cc-compat.h +5 -0
  144. data/vendor/libgit2/src/checkout.c +26 -16
  145. data/vendor/libgit2/src/cherrypick.c +9 -3
  146. data/vendor/libgit2/src/clone.c +29 -7
  147. data/vendor/libgit2/src/clone.h +4 -0
  148. data/vendor/libgit2/src/commit.c +69 -21
  149. data/vendor/libgit2/src/commit.h +6 -0
  150. data/vendor/libgit2/src/commit_list.c +28 -76
  151. data/vendor/libgit2/src/commit_list.h +2 -2
  152. data/vendor/libgit2/src/common.h +3 -75
  153. data/vendor/libgit2/src/config.c +31 -40
  154. data/vendor/libgit2/src/config.h +7 -6
  155. data/vendor/libgit2/src/config_backend.h +12 -0
  156. data/vendor/libgit2/src/config_cache.c +39 -39
  157. data/vendor/libgit2/src/config_entries.c +69 -99
  158. data/vendor/libgit2/src/config_entries.h +1 -0
  159. data/vendor/libgit2/src/config_file.c +337 -380
  160. data/vendor/libgit2/src/config_mem.c +12 -16
  161. data/vendor/libgit2/src/config_parse.c +49 -29
  162. data/vendor/libgit2/src/config_parse.h +13 -12
  163. data/vendor/libgit2/src/config_snapshot.c +206 -0
  164. data/vendor/libgit2/src/crlf.c +14 -14
  165. data/vendor/libgit2/src/describe.c +21 -20
  166. data/vendor/libgit2/src/diff.c +43 -58
  167. data/vendor/libgit2/src/diff.h +2 -1
  168. data/vendor/libgit2/src/diff_driver.c +37 -38
  169. data/vendor/libgit2/src/diff_file.c +9 -7
  170. data/vendor/libgit2/src/diff_file.h +1 -1
  171. data/vendor/libgit2/src/diff_generate.c +135 -85
  172. data/vendor/libgit2/src/diff_generate.h +2 -2
  173. data/vendor/libgit2/src/diff_parse.c +1 -1
  174. data/vendor/libgit2/src/diff_print.c +25 -13
  175. data/vendor/libgit2/src/diff_stats.c +1 -1
  176. data/vendor/libgit2/src/diff_tform.c +4 -4
  177. data/vendor/libgit2/src/errors.c +12 -22
  178. data/vendor/libgit2/src/errors.h +81 -0
  179. data/vendor/libgit2/src/features.h.in +9 -2
  180. data/vendor/libgit2/src/fetch.c +7 -2
  181. data/vendor/libgit2/src/fetchhead.c +1 -1
  182. data/vendor/libgit2/src/filebuf.c +6 -10
  183. data/vendor/libgit2/src/filebuf.h +2 -2
  184. data/vendor/libgit2/src/filter.c +16 -8
  185. data/vendor/libgit2/src/{fileops.c → futils.c} +21 -17
  186. data/vendor/libgit2/src/{fileops.h → futils.h} +5 -5
  187. data/vendor/libgit2/src/global.c +12 -40
  188. data/vendor/libgit2/src/global.h +0 -2
  189. data/vendor/libgit2/src/hash.c +61 -0
  190. data/vendor/libgit2/src/hash.h +19 -21
  191. data/vendor/libgit2/src/hash/sha1.h +38 -0
  192. data/vendor/libgit2/src/hash/{hash_collisiondetect.h → sha1/collisiondetect.c} +14 -17
  193. data/vendor/libgit2/src/hash/sha1/collisiondetect.h +19 -0
  194. data/vendor/libgit2/src/hash/{hash_common_crypto.h → sha1/common_crypto.c} +15 -19
  195. data/vendor/libgit2/src/hash/sha1/common_crypto.h +19 -0
  196. data/vendor/libgit2/src/hash/{hash_generic.c → sha1/generic.c} +22 -10
  197. data/vendor/libgit2/src/hash/{hash_generic.h → sha1/generic.h} +4 -14
  198. data/vendor/libgit2/src/hash/{hash_mbedtls.c → sha1/mbedtls.c} +15 -7
  199. data/vendor/libgit2/src/hash/{hash_mbedtls.h → sha1/mbedtls.h} +6 -11
  200. data/vendor/libgit2/src/hash/{hash_openssl.h → sha1/openssl.c} +14 -18
  201. data/vendor/libgit2/src/hash/sha1/openssl.h +19 -0
  202. data/vendor/libgit2/src/hash/{sha1dc → sha1/sha1dc}/sha1.c +14 -3
  203. data/vendor/libgit2/src/hash/{sha1dc → sha1/sha1dc}/sha1.h +0 -0
  204. data/vendor/libgit2/src/hash/{sha1dc → sha1/sha1dc}/ubc_check.c +0 -0
  205. data/vendor/libgit2/src/hash/{sha1dc → sha1/sha1dc}/ubc_check.h +0 -0
  206. data/vendor/libgit2/src/hash/{hash_win32.c → sha1/win32.c} +34 -24
  207. data/vendor/libgit2/src/hash/{hash_win32.h → sha1/win32.h} +6 -19
  208. data/vendor/libgit2/src/hashsig.c +1 -1
  209. data/vendor/libgit2/src/idxmap.c +91 -65
  210. data/vendor/libgit2/src/idxmap.h +151 -15
  211. data/vendor/libgit2/src/ignore.c +32 -38
  212. data/vendor/libgit2/src/index.c +66 -43
  213. data/vendor/libgit2/src/index.h +1 -1
  214. data/vendor/libgit2/src/indexer.c +69 -70
  215. data/vendor/libgit2/src/integer.h +39 -4
  216. data/vendor/libgit2/src/iterator.c +27 -22
  217. data/vendor/libgit2/src/map.h +1 -1
  218. data/vendor/libgit2/src/merge.c +58 -44
  219. data/vendor/libgit2/src/merge_driver.c +4 -4
  220. data/vendor/libgit2/src/merge_file.c +1 -1
  221. data/vendor/libgit2/src/mwindow.c +18 -23
  222. data/vendor/libgit2/src/mwindow.h +4 -4
  223. data/vendor/libgit2/src/net.c +184 -0
  224. data/vendor/libgit2/src/net.h +36 -0
  225. data/vendor/libgit2/src/netops.c +55 -165
  226. data/vendor/libgit2/src/netops.h +3 -25
  227. data/vendor/libgit2/src/notes.c +2 -2
  228. data/vendor/libgit2/src/object.c +2 -2
  229. data/vendor/libgit2/src/object.h +2 -0
  230. data/vendor/libgit2/src/odb.c +41 -23
  231. data/vendor/libgit2/src/odb.h +3 -2
  232. data/vendor/libgit2/src/odb_loose.c +17 -10
  233. data/vendor/libgit2/src/odb_mempack.c +10 -23
  234. data/vendor/libgit2/src/odb_pack.c +4 -4
  235. data/vendor/libgit2/src/offmap.c +43 -55
  236. data/vendor/libgit2/src/offmap.h +102 -24
  237. data/vendor/libgit2/src/oid.c +6 -1
  238. data/vendor/libgit2/src/oidmap.c +39 -57
  239. data/vendor/libgit2/src/oidmap.h +99 -19
  240. data/vendor/libgit2/src/pack-objects.c +25 -32
  241. data/vendor/libgit2/src/pack-objects.h +1 -1
  242. data/vendor/libgit2/src/pack.c +45 -47
  243. data/vendor/libgit2/src/pack.h +12 -14
  244. data/vendor/libgit2/src/parse.c +10 -0
  245. data/vendor/libgit2/src/parse.h +3 -3
  246. data/vendor/libgit2/src/patch.c +1 -1
  247. data/vendor/libgit2/src/patch_generate.c +2 -2
  248. data/vendor/libgit2/src/patch_parse.c +124 -31
  249. data/vendor/libgit2/src/path.c +95 -27
  250. data/vendor/libgit2/src/path.h +2 -0
  251. data/vendor/libgit2/src/pathspec.c +13 -13
  252. data/vendor/libgit2/src/pool.c +26 -22
  253. data/vendor/libgit2/src/pool.h +7 -7
  254. data/vendor/libgit2/src/posix.c +7 -7
  255. data/vendor/libgit2/src/posix.h +12 -1
  256. data/vendor/libgit2/src/proxy.c +7 -2
  257. data/vendor/libgit2/src/push.c +10 -5
  258. data/vendor/libgit2/src/reader.c +2 -2
  259. data/vendor/libgit2/src/rebase.c +66 -7
  260. data/vendor/libgit2/src/refdb.c +12 -0
  261. data/vendor/libgit2/src/refdb_fs.c +214 -165
  262. data/vendor/libgit2/src/reflog.c +11 -13
  263. data/vendor/libgit2/src/refs.c +24 -18
  264. data/vendor/libgit2/src/refspec.c +9 -16
  265. data/vendor/libgit2/src/regexp.c +221 -0
  266. data/vendor/libgit2/src/regexp.h +97 -0
  267. data/vendor/libgit2/src/remote.c +50 -52
  268. data/vendor/libgit2/src/remote.h +2 -2
  269. data/vendor/libgit2/src/repository.c +115 -100
  270. data/vendor/libgit2/src/repository.h +49 -40
  271. data/vendor/libgit2/src/revert.c +8 -3
  272. data/vendor/libgit2/src/revparse.c +18 -19
  273. data/vendor/libgit2/src/revwalk.c +63 -30
  274. data/vendor/libgit2/src/revwalk.h +20 -0
  275. data/vendor/libgit2/src/settings.c +5 -0
  276. data/vendor/libgit2/src/sortedcache.c +12 -26
  277. data/vendor/libgit2/src/sortedcache.h +1 -1
  278. data/vendor/libgit2/src/stash.c +45 -65
  279. data/vendor/libgit2/src/status.c +15 -9
  280. data/vendor/libgit2/src/streams/openssl.c +20 -0
  281. data/vendor/libgit2/src/streams/socket.c +2 -2
  282. data/vendor/libgit2/src/strmap.c +37 -84
  283. data/vendor/libgit2/src/strmap.h +105 -33
  284. data/vendor/libgit2/src/submodule.c +102 -70
  285. data/vendor/libgit2/src/submodule.h +1 -1
  286. data/vendor/libgit2/src/sysdir.c +11 -1
  287. data/vendor/libgit2/src/tag.c +10 -2
  288. data/vendor/libgit2/src/trace.c +1 -1
  289. data/vendor/libgit2/src/trace.h +2 -2
  290. data/vendor/libgit2/src/trailer.c +46 -32
  291. data/vendor/libgit2/src/transaction.c +10 -9
  292. data/vendor/libgit2/src/transports/auth.c +10 -9
  293. data/vendor/libgit2/src/transports/auth.h +11 -4
  294. data/vendor/libgit2/src/transports/auth_negotiate.c +23 -9
  295. data/vendor/libgit2/src/transports/auth_negotiate.h +2 -2
  296. data/vendor/libgit2/src/transports/auth_ntlm.c +223 -0
  297. data/vendor/libgit2/src/transports/auth_ntlm.h +35 -0
  298. data/vendor/libgit2/src/transports/cred.c +6 -6
  299. data/vendor/libgit2/src/transports/git.c +11 -16
  300. data/vendor/libgit2/src/transports/http.c +419 -276
  301. data/vendor/libgit2/src/transports/http.h +1 -1
  302. data/vendor/libgit2/src/transports/local.c +9 -9
  303. data/vendor/libgit2/src/transports/smart.c +17 -17
  304. data/vendor/libgit2/src/transports/smart.h +2 -2
  305. data/vendor/libgit2/src/transports/smart_protocol.c +36 -60
  306. data/vendor/libgit2/src/transports/ssh.c +46 -36
  307. data/vendor/libgit2/src/transports/winhttp.c +231 -207
  308. data/vendor/libgit2/src/tree-cache.c +14 -7
  309. data/vendor/libgit2/src/tree.c +10 -24
  310. data/vendor/libgit2/src/unix/map.c +1 -1
  311. data/vendor/libgit2/src/unix/posix.h +1 -11
  312. data/vendor/libgit2/src/userdiff.h +3 -1
  313. data/vendor/libgit2/src/util.c +51 -53
  314. data/vendor/libgit2/src/util.h +16 -21
  315. data/vendor/libgit2/src/wildmatch.c +320 -0
  316. data/vendor/libgit2/src/wildmatch.h +23 -0
  317. data/vendor/libgit2/src/win32/map.c +3 -5
  318. data/vendor/libgit2/src/win32/path_w32.c +12 -2
  319. data/vendor/libgit2/src/win32/path_w32.h +0 -29
  320. data/vendor/libgit2/src/win32/posix.h +1 -4
  321. data/vendor/libgit2/src/win32/posix_w32.c +40 -5
  322. data/vendor/libgit2/src/win32/precompiled.h +0 -2
  323. data/vendor/libgit2/src/win32/thread.c +5 -10
  324. data/vendor/libgit2/src/win32/w32_buffer.c +7 -3
  325. data/vendor/libgit2/src/win32/w32_common.h +39 -0
  326. data/vendor/libgit2/src/win32/w32_crtdbg_stacktrace.c +0 -93
  327. data/vendor/libgit2/src/win32/w32_crtdbg_stacktrace.h +0 -2
  328. data/vendor/libgit2/src/win32/w32_stack.c +4 -9
  329. data/vendor/libgit2/src/win32/w32_stack.h +3 -3
  330. data/vendor/libgit2/src/win32/w32_util.c +31 -0
  331. data/vendor/libgit2/src/win32/w32_util.h +6 -32
  332. data/vendor/libgit2/src/worktree.c +36 -22
  333. data/vendor/libgit2/src/xdiff/xdiffi.c +1 -1
  334. data/vendor/libgit2/src/xdiff/xmerge.c +12 -0
  335. data/vendor/libgit2/src/xdiff/xpatience.c +3 -0
  336. metadata +98 -34
  337. data/vendor/libgit2/deps/regex/CMakeLists.txt +0 -2
  338. data/vendor/libgit2/deps/regex/COPYING +0 -502
  339. data/vendor/libgit2/deps/regex/config.h +0 -7
  340. data/vendor/libgit2/deps/regex/regcomp.c +0 -3857
  341. data/vendor/libgit2/deps/regex/regex.c +0 -92
  342. data/vendor/libgit2/deps/regex/regex.h +0 -582
  343. data/vendor/libgit2/deps/regex/regex_internal.c +0 -1744
  344. data/vendor/libgit2/deps/regex/regex_internal.h +0 -819
  345. data/vendor/libgit2/deps/regex/regexec.c +0 -4369
  346. data/vendor/libgit2/include/git2/inttypes.h +0 -309
  347. data/vendor/libgit2/include/git2/sys/time.h +0 -31
  348. data/vendor/libgit2/libgit2.pc.in +0 -13
  349. data/vendor/libgit2/src/fnmatch.c +0 -248
  350. data/vendor/libgit2/src/fnmatch.h +0 -48
@@ -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_TRUE(value))
374
+ if (GIT_ATTR_IS_TRUE(value))
375
375
  *out = merge_driver_name__text;
376
376
 
377
377
  /* unset: do not merge ("binary") */
378
- else if (GIT_ATTR_FALSE(value))
378
+ else if (GIT_ATTR_IS_FALSE(value))
379
379
  *out = merge_driver_name__binary;
380
380
 
381
- else if (GIT_ATTR_UNSPECIFIED(value) && default_driver)
381
+ else if (GIT_ATTR_IS_UNSPECIFIED(value) && default_driver)
382
382
  *out = default_driver;
383
383
 
384
- else if (GIT_ATTR_UNSPECIFIED(value))
384
+ else if (GIT_ATTR_IS_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 "fileops.h"
12
+ #include "futils.h"
13
13
  #include "index.h"
14
14
  #include "diff_xdiff.h"
15
15
  #include "merge.h"
@@ -8,7 +8,7 @@
8
8
  #include "mwindow.h"
9
9
 
10
10
  #include "vector.h"
11
- #include "fileops.h"
11
+ #include "futils.h"
12
12
  #include "map.h"
13
13
  #include "global.h"
14
14
  #include "strmap.h"
@@ -44,15 +44,14 @@ 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_alloc(&git__pack_cache);
47
+ return git_strmap_new(&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
- int error;
53
- char *packname;
54
- size_t pos;
55
52
  struct git_pack_file *pack;
53
+ char *packname;
54
+ int error;
56
55
 
57
56
  if ((error = git_packfile__name(&packname, path)) < 0)
58
57
  return error;
@@ -62,13 +61,11 @@ int git_mwindow_get_pack(struct git_pack_file **out, const char *path)
62
61
  return -1;
63
62
  }
64
63
 
65
- pos = git_strmap_lookup_index(git__pack_cache, packname);
64
+ pack = git_strmap_get(git__pack_cache, packname);
66
65
  git__free(packname);
67
66
 
68
- if (git_strmap_valid_index(git__pack_cache, pos)) {
69
- pack = git_strmap_value_at(git__pack_cache, pos);
67
+ if (pack != NULL) {
70
68
  git_atomic_inc(&pack->refcount);
71
-
72
69
  git_mutex_unlock(&git__mwindow_mutex);
73
70
  *out = pack;
74
71
  return 0;
@@ -82,7 +79,7 @@ int git_mwindow_get_pack(struct git_pack_file **out, const char *path)
82
79
 
83
80
  git_atomic_inc(&pack->refcount);
84
81
 
85
- git_strmap_insert(git__pack_cache, pack->pack_name, pack, &error);
82
+ error = git_strmap_set(git__pack_cache, pack->pack_name, pack);
86
83
  git_mutex_unlock(&git__mwindow_mutex);
87
84
 
88
85
  if (error < 0) {
@@ -97,7 +94,6 @@ int git_mwindow_get_pack(struct git_pack_file **out, const char *path)
97
94
  void git_mwindow_put_pack(struct git_pack_file *pack)
98
95
  {
99
96
  int count;
100
- size_t pos;
101
97
 
102
98
  if (git_mutex_lock(&git__mwindow_mutex) < 0)
103
99
  return;
@@ -105,13 +101,12 @@ void git_mwindow_put_pack(struct git_pack_file *pack)
105
101
  /* put before get would be a corrupted state */
106
102
  assert(git__pack_cache);
107
103
 
108
- pos = git_strmap_lookup_index(git__pack_cache, pack->pack_name);
109
104
  /* if we cannot find it, the state is corrupted */
110
- assert(git_strmap_valid_index(git__pack_cache, pos));
105
+ assert(git_strmap_exists(git__pack_cache, pack->pack_name));
111
106
 
112
107
  count = git_atomic_dec(&pack->refcount);
113
108
  if (count == 0) {
114
- git_strmap_delete_at(git__pack_cache, pos);
109
+ git_strmap_delete(git__pack_cache, pack->pack_name);
115
110
  git_packfile_free(pack);
116
111
  }
117
112
 
@@ -172,11 +167,11 @@ void git_mwindow_free_all_locked(git_mwindow_file *mwf)
172
167
  /*
173
168
  * Check if a window 'win' contains the address 'offset'
174
169
  */
175
- int git_mwindow_contains(git_mwindow *win, git_off_t offset)
170
+ int git_mwindow_contains(git_mwindow *win, off64_t offset)
176
171
  {
177
- git_off_t win_off = win->offset;
172
+ off64_t win_off = win->offset;
178
173
  return win_off <= offset
179
- && offset <= (git_off_t)(win_off + win->window_map.len);
174
+ && offset <= (off64_t)(win_off + win->window_map.len);
180
175
  }
181
176
 
182
177
  /*
@@ -251,12 +246,12 @@ static int git_mwindow_close_lru(git_mwindow_file *mwf)
251
246
  static git_mwindow *new_window(
252
247
  git_mwindow_file *mwf,
253
248
  git_file fd,
254
- git_off_t size,
255
- git_off_t offset)
249
+ off64_t size,
250
+ off64_t offset)
256
251
  {
257
252
  git_mwindow_ctl *ctl = &mem_ctl;
258
253
  size_t walign = git_mwindow__window_size / 2;
259
- git_off_t len;
254
+ off64_t len;
260
255
  git_mwindow *w;
261
256
 
262
257
  w = git__malloc(sizeof(*w));
@@ -268,8 +263,8 @@ static git_mwindow *new_window(
268
263
  w->offset = (offset / walign) * walign;
269
264
 
270
265
  len = size - w->offset;
271
- if (len > (git_off_t)git_mwindow__window_size)
272
- len = (git_off_t)git_mwindow__window_size;
266
+ if (len > (off64_t)git_mwindow__window_size)
267
+ len = (off64_t)git_mwindow__window_size;
273
268
 
274
269
  ctl->mapped += (size_t)len;
275
270
 
@@ -316,7 +311,7 @@ static git_mwindow *new_window(
316
311
  unsigned char *git_mwindow_open(
317
312
  git_mwindow_file *mwf,
318
313
  git_mwindow **cursor,
319
- git_off_t offset,
314
+ off64_t offset,
320
315
  size_t extra,
321
316
  unsigned int *left)
322
317
  {
@@ -16,7 +16,7 @@
16
16
  typedef struct git_mwindow {
17
17
  struct git_mwindow *next;
18
18
  git_map window_map;
19
- git_off_t offset;
19
+ off64_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
- git_off_t size;
27
+ off64_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, git_off_t offset);
40
+ int git_mwindow_contains(git_mwindow *win, off64_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, git_off_t offset, size_t extra, unsigned int *left);
43
+ unsigned char *git_mwindow_open(git_mwindow_file *mwf, git_mwindow **cursor, off64_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);
@@ -0,0 +1,184 @@
1
+ /*
2
+ * Copyright (C) the libgit2 contributors. All rights reserved.
3
+ *
4
+ * This file is part of libgit2, distributed under the GNU GPL v2 with
5
+ * a Linking Exception. For full terms see the included COPYING file.
6
+ */
7
+
8
+ #include "net.h"
9
+ #include "netops.h"
10
+
11
+ #include <ctype.h>
12
+ #include "git2/errors.h"
13
+
14
+ #include "posix.h"
15
+ #include "buffer.h"
16
+ #include "http_parser.h"
17
+ #include "global.h"
18
+
19
+ #define DEFAULT_PORT_HTTP "80"
20
+ #define DEFAULT_PORT_HTTPS "443"
21
+ #define DEFAULT_PORT_GIT "9418"
22
+ #define DEFAULT_PORT_SSH "22"
23
+
24
+ static const char *default_port_for_scheme(const char *scheme)
25
+ {
26
+ if (strcmp(scheme, "http") == 0)
27
+ return DEFAULT_PORT_HTTP;
28
+ else if (strcmp(scheme, "https") == 0)
29
+ return DEFAULT_PORT_HTTPS;
30
+ else if (strcmp(scheme, "git") == 0)
31
+ return DEFAULT_PORT_GIT;
32
+ else if (strcmp(scheme, "ssh") == 0)
33
+ return DEFAULT_PORT_SSH;
34
+
35
+ return NULL;
36
+ }
37
+
38
+ int git_net_url_parse(git_net_url *url, const char *given)
39
+ {
40
+ struct http_parser_url u = {0};
41
+ bool has_scheme, has_host, has_port, has_path, has_query, has_userinfo;
42
+ git_buf scheme = GIT_BUF_INIT,
43
+ host = GIT_BUF_INIT,
44
+ port = GIT_BUF_INIT,
45
+ path = GIT_BUF_INIT,
46
+ username = GIT_BUF_INIT,
47
+ password = GIT_BUF_INIT,
48
+ query = GIT_BUF_INIT;
49
+ int error = GIT_EINVALIDSPEC;
50
+
51
+ if (http_parser_parse_url(given, strlen(given), false, &u)) {
52
+ git_error_set(GIT_ERROR_NET, "malformed URL '%s'", given);
53
+ goto done;
54
+ }
55
+
56
+ has_scheme = !!(u.field_set & (1 << UF_SCHEMA));
57
+ has_host = !!(u.field_set & (1 << UF_HOST));
58
+ has_port = !!(u.field_set & (1 << UF_PORT));
59
+ has_path = !!(u.field_set & (1 << UF_PATH));
60
+ has_query = !!(u.field_set & (1 << UF_QUERY));
61
+ has_userinfo = !!(u.field_set & (1 << UF_USERINFO));
62
+
63
+ if (has_scheme) {
64
+ const char *url_scheme = given + u.field_data[UF_SCHEMA].off;
65
+ size_t url_scheme_len = u.field_data[UF_SCHEMA].len;
66
+ git_buf_put(&scheme, url_scheme, url_scheme_len);
67
+ git__strntolower(scheme.ptr, scheme.size);
68
+ } else {
69
+ git_error_set(GIT_ERROR_NET, "malformed URL '%s'", given);
70
+ goto done;
71
+ }
72
+
73
+ if (has_host) {
74
+ const char *url_host = given + u.field_data[UF_HOST].off;
75
+ size_t url_host_len = u.field_data[UF_HOST].len;
76
+ git_buf_decode_percent(&host, url_host, url_host_len);
77
+ }
78
+
79
+ if (has_port) {
80
+ const char *url_port = given + u.field_data[UF_PORT].off;
81
+ size_t url_port_len = u.field_data[UF_PORT].len;
82
+ git_buf_put(&port, url_port, url_port_len);
83
+ } else {
84
+ const char *default_port = default_port_for_scheme(scheme.ptr);
85
+
86
+ if (default_port == NULL) {
87
+ git_error_set(GIT_ERROR_NET, "unknown scheme for URL '%s'", given);
88
+ goto done;
89
+ }
90
+
91
+ git_buf_puts(&port, default_port);
92
+ }
93
+
94
+ if (has_path) {
95
+ const char *url_path = given + u.field_data[UF_PATH].off;
96
+ size_t url_path_len = u.field_data[UF_PATH].len;
97
+ git_buf_put(&path, url_path, url_path_len);
98
+ } else {
99
+ git_buf_puts(&path, "/");
100
+ }
101
+
102
+ if (has_query) {
103
+ const char *url_query = given + u.field_data[UF_QUERY].off;
104
+ size_t url_query_len = u.field_data[UF_QUERY].len;
105
+ git_buf_decode_percent(&query, url_query, url_query_len);
106
+ }
107
+
108
+ if (has_userinfo) {
109
+ const char *url_userinfo = given + u.field_data[UF_USERINFO].off;
110
+ size_t url_userinfo_len = u.field_data[UF_USERINFO].len;
111
+ const char *colon = memchr(url_userinfo, ':', url_userinfo_len);
112
+
113
+ if (colon) {
114
+ const char *url_username = url_userinfo;
115
+ size_t url_username_len = colon - url_userinfo;
116
+ const char *url_password = colon + 1;
117
+ size_t url_password_len = url_userinfo_len - (url_username_len + 1);
118
+
119
+ git_buf_decode_percent(&username, url_username, url_username_len);
120
+ git_buf_decode_percent(&password, url_password, url_password_len);
121
+ } else {
122
+ git_buf_decode_percent(&username, url_userinfo, url_userinfo_len);
123
+ }
124
+ }
125
+
126
+ if (git_buf_oom(&scheme) ||
127
+ git_buf_oom(&host) ||
128
+ git_buf_oom(&port) ||
129
+ git_buf_oom(&path) ||
130
+ git_buf_oom(&query) ||
131
+ git_buf_oom(&username) ||
132
+ git_buf_oom(&password))
133
+ return -1;
134
+
135
+ url->scheme = git_buf_detach(&scheme);
136
+ url->host = git_buf_detach(&host);
137
+ url->port = git_buf_detach(&port);
138
+ url->path = git_buf_detach(&path);
139
+ url->query = git_buf_detach(&query);
140
+ url->username = git_buf_detach(&username);
141
+ url->password = git_buf_detach(&password);
142
+
143
+ error = 0;
144
+
145
+ done:
146
+ git_buf_dispose(&scheme);
147
+ git_buf_dispose(&host);
148
+ git_buf_dispose(&port);
149
+ git_buf_dispose(&path);
150
+ git_buf_dispose(&query);
151
+ git_buf_dispose(&username);
152
+ git_buf_dispose(&password);
153
+ return error;
154
+ }
155
+
156
+ int git_net_url_is_default_port(git_net_url *url)
157
+ {
158
+ return (strcmp(url->port, default_port_for_scheme(url->scheme)) == 0);
159
+ }
160
+
161
+ void git_net_url_swap(git_net_url *a, git_net_url *b)
162
+ {
163
+ git_net_url tmp = GIT_NET_URL_INIT;
164
+
165
+ memcpy(&tmp, a, sizeof(git_net_url));
166
+ memcpy(a, b, sizeof(git_net_url));
167
+ memcpy(b, &tmp, sizeof(git_net_url));
168
+ }
169
+
170
+ void git_net_url_dispose(git_net_url *url)
171
+ {
172
+ if (url->username)
173
+ git__memzero(url->username, strlen(url->username));
174
+
175
+ if (url->password)
176
+ git__memzero(url->password, strlen(url->password));
177
+
178
+ git__free(url->scheme); url->scheme = NULL;
179
+ git__free(url->host); url->host = NULL;
180
+ git__free(url->port); url->port = NULL;
181
+ git__free(url->path); url->path = NULL;
182
+ git__free(url->username); url->username = NULL;
183
+ git__free(url->password); url->password = NULL;
184
+ }
@@ -0,0 +1,36 @@
1
+ /*
2
+ * Copyright (C) the libgit2 contributors. All rights reserved.
3
+ *
4
+ * This file is part of libgit2, distributed under the GNU GPL v2 with
5
+ * a Linking Exception. For full terms see the included COPYING file.
6
+ */
7
+ #ifndef INCLUDE_net_h__
8
+ #define INCLUDE_net_h__
9
+
10
+ #include "common.h"
11
+
12
+ typedef struct git_net_url {
13
+ char *scheme;
14
+ char *host;
15
+ char *port;
16
+ char *path;
17
+ char *query;
18
+ char *username;
19
+ char *password;
20
+ } git_net_url;
21
+
22
+ #define GIT_NET_URL_INIT { NULL }
23
+
24
+ /** Parses a string containing a URL into a structure. */
25
+ int git_net_url_parse(git_net_url *url, const char *str);
26
+
27
+ /** Returns nonzero if the URL is on the default port. */
28
+ int git_net_url_is_default_port(git_net_url *url);
29
+
30
+ /** Swaps the contents of one URL for another. */
31
+ void git_net_url_swap(git_net_url *a, git_net_url *b);
32
+
33
+ /** Disposes the contents of the structure. */
34
+ void git_net_url_dispose(git_net_url *url);
35
+
36
+ #endif
@@ -37,14 +37,17 @@ 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
- int ret;
40
+ size_t readlen = buf->len - buf->offset;
41
+ ssize_t ret;
41
42
 
42
- ret = git_stream_read(io, buf->data + buf->offset, buf->len - buf->offset);
43
+ readlen = min(readlen, INT_MAX);
44
+
45
+ ret = git_stream_read(io, buf->data + buf->offset, (int)readlen);
43
46
  if (ret < 0)
44
47
  return -1;
45
48
 
46
49
  buf->offset += ret;
47
- return ret;
50
+ return (int)ret;
48
51
  }
49
52
 
50
53
  void gitno_buffer_setup_fromstream(git_stream *st, gitno_buffer *buf, char *data, size_t len)
@@ -119,192 +122,79 @@ int gitno__match_host(const char *pattern, const char *host)
119
122
  return -1;
120
123
  }
121
124
 
122
- static const char *default_port_http = "80";
123
- static const char *default_port_https = "443";
124
-
125
- const char *gitno__default_port(
126
- gitno_connection_data *data)
127
- {
128
- return data->use_ssl ? default_port_https : default_port_http;
129
- }
130
-
131
- static const char *prefix_http = "http://";
132
- static const char *prefix_https = "https://";
133
-
134
- int gitno_connection_data_from_url(
135
- gitno_connection_data *data,
136
- const char *url,
125
+ int gitno_connection_data_handle_redirect(
126
+ git_net_url *url,
127
+ const char *redirect_str,
137
128
  const char *service_suffix)
138
129
  {
139
- int error = -1;
140
- const char *default_port = NULL, *path_search_start = NULL;
141
- char *original_host = NULL;
142
-
143
- /* service_suffix is optional */
144
- assert(data && url);
130
+ git_net_url tmp = GIT_NET_URL_INIT;
131
+ int error = 0;
145
132
 
146
- /* Save these for comparison later */
147
- original_host = data->host;
148
- data->host = NULL;
149
- gitno_connection_data_free_ptrs(data);
133
+ assert(url && redirect_str);
150
134
 
151
- if (!git__prefixcmp(url, prefix_http)) {
152
- path_search_start = url + strlen(prefix_http);
153
- default_port = default_port_http;
135
+ if (redirect_str[0] == '/') {
136
+ git__free(url->path);
154
137
 
155
- if (data->use_ssl) {
156
- git_error_set(GIT_ERROR_NET, "redirect from HTTPS to HTTP is not allowed");
157
- goto cleanup;
138
+ if ((url->path = git__strdup(redirect_str)) == NULL) {
139
+ error = -1;
140
+ goto done;
158
141
  }
159
- } else if (!git__prefixcmp(url, prefix_https)) {
160
- path_search_start = url + strlen(prefix_https);
161
- default_port = default_port_https;
162
- data->use_ssl = true;
163
- } else if (url[0] == '/')
164
- default_port = gitno__default_port(data);
165
-
166
- if (!default_port) {
167
- git_error_set(GIT_ERROR_NET, "unrecognized URL prefix");
168
- goto cleanup;
169
- }
142
+ } else {
143
+ git_net_url *original = url;
170
144
 
171
- error = gitno_extract_url_parts(
172
- &data->host, &data->port, &data->path, &data->user, &data->pass,
173
- url, default_port);
145
+ if ((error = git_net_url_parse(&tmp, redirect_str)) < 0)
146
+ goto done;
174
147
 
175
- if (url[0] == '/') {
176
- /* Relative redirect; reuse original host name and port */
177
- path_search_start = url;
178
- git__free(data->host);
179
- data->host = original_host;
180
- original_host = NULL;
181
- }
148
+ /* Validate that this is a legal redirection */
182
149
 
183
- if (!error) {
184
- const char *path = strchr(path_search_start, '/');
185
- size_t pathlen = strlen(path);
186
- size_t suffixlen = service_suffix ? strlen(service_suffix) : 0;
187
-
188
- if (suffixlen &&
189
- !memcmp(path + pathlen - suffixlen, service_suffix, suffixlen)) {
190
- git__free(data->path);
191
- data->path = git__strndup(path, pathlen - suffixlen);
192
- } else {
193
- git__free(data->path);
194
- data->path = git__strdup(path);
195
- }
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);
196
155
 
197
- /* Check for errors in the resulting data */
198
- if (original_host && url[0] != '/' && strcmp(original_host, data->host)) {
199
- git_error_set(GIT_ERROR_NET, "cross host redirect not allowed");
200
156
  error = -1;
157
+ goto done;
201
158
  }
202
- }
203
-
204
- cleanup:
205
- if (original_host) git__free(original_host);
206
- return error;
207
- }
208
159
 
209
- void gitno_connection_data_free_ptrs(gitno_connection_data *d)
210
- {
211
- git__free(d->host); d->host = NULL;
212
- git__free(d->port); d->port = NULL;
213
- git__free(d->path); d->path = NULL;
214
- git__free(d->user); d->user = NULL;
215
- git__free(d->pass); d->pass = NULL;
216
- }
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);
217
164
 
218
- int gitno_extract_url_parts(
219
- char **host_out,
220
- char **port_out,
221
- char **path_out,
222
- char **username_out,
223
- char **password_out,
224
- const char *url,
225
- const char *default_port)
226
- {
227
- struct http_parser_url u = {0};
228
- bool has_host, has_port, has_path, has_userinfo;
229
- git_buf host = GIT_BUF_INIT,
230
- port = GIT_BUF_INIT,
231
- path = GIT_BUF_INIT,
232
- username = GIT_BUF_INIT,
233
- password = GIT_BUF_INIT;
234
- int error = 0;
165
+ error = -1;
166
+ goto done;
167
+ }
235
168
 
236
- if (http_parser_parse_url(url, strlen(url), false, &u)) {
237
- git_error_set(GIT_ERROR_NET, "malformed URL '%s'", url);
238
- error = GIT_EINVALIDSPEC;
239
- goto done;
169
+ git_net_url_swap(url, &tmp);
240
170
  }
241
171
 
242
- has_host = !!(u.field_set & (1 << UF_HOST));
243
- has_port = !!(u.field_set & (1 << UF_PORT));
244
- has_path = !!(u.field_set & (1 << UF_PATH));
245
- has_userinfo = !!(u.field_set & (1 << UF_USERINFO));
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);
246
178
 
247
- if (has_host) {
248
- const char *url_host = url + u.field_data[UF_HOST].off;
249
- size_t url_host_len = u.field_data[UF_HOST].len;
250
- git_buf_decode_percent(&host, url_host, url_host_len);
251
- }
179
+ if (suffix_len && path_len >= suffix_len) {
180
+ size_t suffix_offset = path_len - suffix_len;
252
181
 
253
- if (has_port) {
254
- const char *url_port = url + u.field_data[UF_PORT].off;
255
- size_t url_port_len = u.field_data[UF_PORT].len;
256
- git_buf_put(&port, url_port, url_port_len);
257
- } else {
258
- git_buf_puts(&port, default_port);
259
- }
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++;
260
187
 
261
- if (has_path && path_out) {
262
- const char *url_path = url + u.field_data[UF_PATH].off;
263
- size_t url_path_len = u.field_data[UF_PATH].len;
264
- git_buf_decode_percent(&path, url_path, url_path_len);
265
- } else if (path_out) {
266
- git_error_set(GIT_ERROR_NET, "invalid url, missing path");
267
- error = GIT_EINVALIDSPEC;
268
- goto done;
269
- }
188
+ url->path[suffix_offset] = '\0';
270
189
 
271
- if (has_userinfo) {
272
- const char *url_userinfo = url + u.field_data[UF_USERINFO].off;
273
- size_t url_userinfo_len = u.field_data[UF_USERINFO].len;
274
- const char *colon = memchr(url_userinfo, ':', url_userinfo_len);
275
-
276
- if (colon) {
277
- const char *url_username = url_userinfo;
278
- size_t url_username_len = colon - url_userinfo;
279
- const char *url_password = colon + 1;
280
- size_t url_password_len = url_userinfo_len - (url_username_len + 1);
281
-
282
- git_buf_decode_percent(&username, url_username, url_username_len);
283
- git_buf_decode_percent(&password, url_password, url_password_len);
284
- } else {
285
- git_buf_decode_percent(&username, url_userinfo, url_userinfo_len);
190
+ git__free(url->query);
191
+ url->query = NULL;
192
+ }
286
193
  }
287
194
  }
288
195
 
289
- if (git_buf_oom(&host) ||
290
- git_buf_oom(&port) ||
291
- git_buf_oom(&path) ||
292
- git_buf_oom(&username) ||
293
- git_buf_oom(&password))
294
- return -1;
295
-
296
- *host_out = git_buf_detach(&host);
297
- *port_out = git_buf_detach(&port);
298
- if (path_out)
299
- *path_out = git_buf_detach(&path);
300
- *username_out = git_buf_detach(&username);
301
- *password_out = git_buf_detach(&password);
302
-
303
196
  done:
304
- git_buf_dispose(&host);
305
- git_buf_dispose(&port);
306
- git_buf_dispose(&path);
307
- git_buf_dispose(&username);
308
- git_buf_dispose(&password);
197
+ git_net_url_dispose(&tmp);
309
198
  return error;
310
199
  }
200
+