rugged 0.28.4.1 → 1.0.1

Sign up to get free protection for your applications and to get access to all the features.
Files changed (391) hide show
  1. checksums.yaml +4 -4
  2. data/README.md +2 -2
  3. data/ext/rugged/extconf.rb +3 -1
  4. data/ext/rugged/rugged.c +35 -31
  5. data/ext/rugged/rugged.h +13 -0
  6. data/ext/rugged/rugged_blob.c +11 -9
  7. data/ext/rugged/rugged_commit.c +17 -15
  8. data/ext/rugged/rugged_config.c +1 -1
  9. data/ext/rugged/rugged_diff.c +4 -26
  10. data/ext/rugged/rugged_index.c +4 -2
  11. data/ext/rugged/rugged_note.c +5 -3
  12. data/ext/rugged/rugged_object.c +57 -10
  13. data/ext/rugged/rugged_rebase.c +3 -1
  14. data/ext/rugged/rugged_remote.c +32 -8
  15. data/ext/rugged/rugged_repo.c +232 -17
  16. data/ext/rugged/rugged_tag.c +8 -6
  17. data/ext/rugged/rugged_tree.c +18 -16
  18. data/lib/rugged/commit.rb +1 -2
  19. data/lib/rugged/repository.rb +5 -6
  20. data/lib/rugged/submodule_collection.rb +4 -4
  21. data/lib/rugged/version.rb +1 -1
  22. data/vendor/libgit2/AUTHORS +1 -0
  23. data/vendor/libgit2/CMakeLists.txt +39 -19
  24. data/vendor/libgit2/COPYING +28 -0
  25. data/vendor/libgit2/cmake/Modules/EnableWarnings.cmake +5 -1
  26. data/vendor/libgit2/cmake/Modules/FindCoreFoundation.cmake +2 -2
  27. data/vendor/libgit2/cmake/Modules/FindGSSAPI.cmake +1 -1
  28. data/vendor/libgit2/cmake/Modules/FindGSSFramework.cmake +28 -0
  29. data/vendor/libgit2/cmake/Modules/FindPCRE.cmake +38 -0
  30. data/vendor/libgit2/cmake/Modules/FindPCRE2.cmake +37 -0
  31. data/vendor/libgit2/cmake/Modules/FindSecurity.cmake +2 -2
  32. data/vendor/libgit2/cmake/Modules/FindStatNsec.cmake +6 -0
  33. data/vendor/libgit2/cmake/Modules/PkgBuildConfig.cmake +77 -0
  34. data/vendor/libgit2/cmake/Modules/SanitizeBool.cmake +20 -0
  35. data/vendor/libgit2/cmake/Modules/SelectGSSAPI.cmake +56 -0
  36. data/vendor/libgit2/cmake/Modules/SelectHTTPSBackend.cmake +127 -0
  37. data/vendor/libgit2/cmake/Modules/SelectHashes.cmake +69 -0
  38. data/vendor/libgit2/deps/http-parser/http_parser.c +11 -6
  39. data/vendor/libgit2/deps/ntlmclient/CMakeLists.txt +23 -0
  40. data/vendor/libgit2/deps/ntlmclient/compat.h +55 -0
  41. data/vendor/libgit2/deps/ntlmclient/crypt.h +64 -0
  42. data/vendor/libgit2/deps/ntlmclient/crypt_commoncrypto.c +120 -0
  43. data/vendor/libgit2/deps/ntlmclient/crypt_commoncrypto.h +18 -0
  44. data/vendor/libgit2/deps/ntlmclient/crypt_mbedtls.c +145 -0
  45. data/vendor/libgit2/deps/ntlmclient/crypt_mbedtls.h +18 -0
  46. data/vendor/libgit2/deps/ntlmclient/crypt_openssl.c +130 -0
  47. data/vendor/libgit2/deps/ntlmclient/crypt_openssl.h +21 -0
  48. data/vendor/libgit2/deps/ntlmclient/ntlm.c +1422 -0
  49. data/vendor/libgit2/deps/ntlmclient/ntlm.h +174 -0
  50. data/vendor/libgit2/deps/ntlmclient/ntlmclient.h +320 -0
  51. data/vendor/libgit2/deps/ntlmclient/unicode.h +36 -0
  52. data/vendor/libgit2/deps/ntlmclient/unicode_builtin.c +445 -0
  53. data/vendor/libgit2/deps/ntlmclient/unicode_iconv.c +201 -0
  54. data/vendor/libgit2/deps/ntlmclient/utf8.h +1257 -0
  55. data/vendor/libgit2/deps/ntlmclient/util.c +21 -0
  56. data/vendor/libgit2/deps/ntlmclient/util.h +14 -0
  57. data/vendor/libgit2/deps/pcre/CMakeLists.txt +140 -0
  58. data/vendor/libgit2/deps/pcre/COPYING +5 -0
  59. data/vendor/libgit2/deps/pcre/cmake/COPYING-CMAKE-SCRIPTS +22 -0
  60. data/vendor/libgit2/deps/pcre/cmake/FindEditline.cmake +17 -0
  61. data/vendor/libgit2/deps/pcre/cmake/FindPackageHandleStandardArgs.cmake +58 -0
  62. data/vendor/libgit2/deps/pcre/cmake/FindReadline.cmake +29 -0
  63. data/vendor/libgit2/deps/pcre/config.h.in +57 -0
  64. data/vendor/libgit2/deps/pcre/pcre.h +641 -0
  65. data/vendor/libgit2/deps/pcre/pcre_byte_order.c +319 -0
  66. data/vendor/libgit2/deps/pcre/pcre_chartables.c +198 -0
  67. data/vendor/libgit2/deps/pcre/pcre_compile.c +9800 -0
  68. data/vendor/libgit2/deps/pcre/pcre_config.c +190 -0
  69. data/vendor/libgit2/deps/pcre/pcre_dfa_exec.c +3676 -0
  70. data/vendor/libgit2/deps/pcre/pcre_exec.c +7173 -0
  71. data/vendor/libgit2/deps/pcre/pcre_fullinfo.c +245 -0
  72. data/vendor/libgit2/deps/pcre/pcre_get.c +669 -0
  73. data/vendor/libgit2/deps/pcre/pcre_globals.c +86 -0
  74. data/vendor/libgit2/deps/pcre/pcre_internal.h +2787 -0
  75. data/vendor/libgit2/deps/pcre/pcre_jit_compile.c +11913 -0
  76. data/vendor/libgit2/deps/pcre/pcre_maketables.c +156 -0
  77. data/vendor/libgit2/deps/pcre/pcre_newline.c +210 -0
  78. data/vendor/libgit2/deps/pcre/pcre_ord2utf8.c +94 -0
  79. data/vendor/libgit2/deps/pcre/pcre_printint.c +834 -0
  80. data/vendor/libgit2/deps/pcre/pcre_refcount.c +92 -0
  81. data/vendor/libgit2/deps/pcre/pcre_string_utils.c +211 -0
  82. data/vendor/libgit2/deps/pcre/pcre_study.c +1686 -0
  83. data/vendor/libgit2/deps/pcre/pcre_tables.c +727 -0
  84. data/vendor/libgit2/deps/pcre/pcre_ucd.c +3644 -0
  85. data/vendor/libgit2/deps/pcre/pcre_valid_utf8.c +301 -0
  86. data/vendor/libgit2/deps/pcre/pcre_version.c +98 -0
  87. data/vendor/libgit2/deps/pcre/pcre_xclass.c +268 -0
  88. data/vendor/libgit2/deps/pcre/pcreposix.c +421 -0
  89. data/vendor/libgit2/deps/pcre/pcreposix.h +117 -0
  90. data/vendor/libgit2/deps/pcre/ucp.h +224 -0
  91. data/vendor/libgit2/deps/zlib/adler32.c +0 -7
  92. data/vendor/libgit2/deps/zlib/crc32.c +0 -7
  93. data/vendor/libgit2/include/git2.h +2 -0
  94. data/vendor/libgit2/include/git2/apply.h +22 -2
  95. data/vendor/libgit2/include/git2/attr.h +23 -13
  96. data/vendor/libgit2/include/git2/blame.h +2 -2
  97. data/vendor/libgit2/include/git2/blob.h +44 -12
  98. data/vendor/libgit2/include/git2/branch.h +74 -57
  99. data/vendor/libgit2/include/git2/buffer.h +20 -14
  100. data/vendor/libgit2/include/git2/cert.h +135 -0
  101. data/vendor/libgit2/include/git2/checkout.h +46 -14
  102. data/vendor/libgit2/include/git2/cherrypick.h +3 -3
  103. data/vendor/libgit2/include/git2/clone.h +2 -2
  104. data/vendor/libgit2/include/git2/commit.h +23 -1
  105. data/vendor/libgit2/include/git2/common.h +15 -6
  106. data/vendor/libgit2/include/git2/config.h +12 -12
  107. data/vendor/libgit2/include/git2/cred_helpers.h +4 -42
  108. data/vendor/libgit2/include/git2/credential.h +314 -0
  109. data/vendor/libgit2/include/git2/credential_helpers.h +52 -0
  110. data/vendor/libgit2/include/git2/deprecated.h +321 -3
  111. data/vendor/libgit2/include/git2/describe.h +4 -4
  112. data/vendor/libgit2/include/git2/diff.h +16 -14
  113. data/vendor/libgit2/include/git2/errors.h +4 -2
  114. data/vendor/libgit2/include/git2/filter.h +8 -0
  115. data/vendor/libgit2/include/git2/index.h +2 -1
  116. data/vendor/libgit2/include/git2/indexer.h +48 -4
  117. data/vendor/libgit2/include/git2/merge.h +6 -10
  118. data/vendor/libgit2/include/git2/net.h +0 -5
  119. data/vendor/libgit2/include/git2/object.h +2 -14
  120. data/vendor/libgit2/include/git2/odb.h +3 -2
  121. data/vendor/libgit2/include/git2/odb_backend.h +5 -4
  122. data/vendor/libgit2/include/git2/oid.h +11 -6
  123. data/vendor/libgit2/include/git2/pack.h +12 -1
  124. data/vendor/libgit2/include/git2/proxy.h +6 -4
  125. data/vendor/libgit2/include/git2/rebase.h +46 -2
  126. data/vendor/libgit2/include/git2/refs.h +19 -0
  127. data/vendor/libgit2/include/git2/remote.h +40 -15
  128. data/vendor/libgit2/include/git2/repository.h +29 -6
  129. data/vendor/libgit2/include/git2/revert.h +1 -1
  130. data/vendor/libgit2/include/git2/revwalk.h +7 -3
  131. data/vendor/libgit2/include/git2/stash.h +4 -4
  132. data/vendor/libgit2/include/git2/status.h +25 -16
  133. data/vendor/libgit2/include/git2/submodule.h +20 -3
  134. data/vendor/libgit2/include/git2/sys/alloc.h +9 -9
  135. data/vendor/libgit2/include/git2/sys/cred.h +15 -0
  136. data/vendor/libgit2/include/git2/sys/credential.h +90 -0
  137. data/vendor/libgit2/include/git2/sys/index.h +4 -2
  138. data/vendor/libgit2/include/git2/sys/mempack.h +2 -1
  139. data/vendor/libgit2/include/git2/sys/merge.h +1 -1
  140. data/vendor/libgit2/include/git2/sys/odb_backend.h +48 -4
  141. data/vendor/libgit2/include/git2/sys/refdb_backend.h +164 -21
  142. data/vendor/libgit2/include/git2/sys/repository.h +17 -6
  143. data/vendor/libgit2/include/git2/sys/transport.h +4 -4
  144. data/vendor/libgit2/include/git2/tag.h +11 -2
  145. data/vendor/libgit2/include/git2/trace.h +2 -2
  146. data/vendor/libgit2/include/git2/transport.h +11 -340
  147. data/vendor/libgit2/include/git2/tree.h +5 -3
  148. data/vendor/libgit2/include/git2/types.h +4 -89
  149. data/vendor/libgit2/include/git2/version.h +5 -5
  150. data/vendor/libgit2/include/git2/worktree.h +5 -5
  151. data/vendor/libgit2/src/CMakeLists.txt +99 -236
  152. data/vendor/libgit2/src/alloc.c +2 -14
  153. data/vendor/libgit2/src/{stdalloc.c → allocators/stdalloc.c} +3 -4
  154. data/vendor/libgit2/src/{stdalloc.h → allocators/stdalloc.h} +4 -4
  155. data/vendor/libgit2/src/allocators/win32_crtdbg.c +118 -0
  156. data/vendor/libgit2/src/{transports/cred.h → allocators/win32_crtdbg.h} +5 -4
  157. data/vendor/libgit2/src/apply.c +60 -30
  158. data/vendor/libgit2/src/attr.c +70 -64
  159. data/vendor/libgit2/src/attr_file.c +189 -96
  160. data/vendor/libgit2/src/attr_file.h +9 -9
  161. data/vendor/libgit2/src/attrcache.c +48 -48
  162. data/vendor/libgit2/src/attrcache.h +2 -1
  163. data/vendor/libgit2/src/blame.c +17 -5
  164. data/vendor/libgit2/src/blame.h +1 -1
  165. data/vendor/libgit2/src/blame_git.c +21 -7
  166. data/vendor/libgit2/src/blob.c +81 -17
  167. data/vendor/libgit2/src/blob.h +2 -2
  168. data/vendor/libgit2/src/branch.c +60 -32
  169. data/vendor/libgit2/src/buffer.c +19 -7
  170. data/vendor/libgit2/src/buffer.h +1 -0
  171. data/vendor/libgit2/src/cache.c +33 -36
  172. data/vendor/libgit2/src/cache.h +1 -1
  173. data/vendor/libgit2/src/cc-compat.h +5 -0
  174. data/vendor/libgit2/src/checkout.c +26 -16
  175. data/vendor/libgit2/src/cherrypick.c +9 -3
  176. data/vendor/libgit2/src/clone.c +29 -7
  177. data/vendor/libgit2/src/clone.h +4 -0
  178. data/vendor/libgit2/src/commit.c +70 -22
  179. data/vendor/libgit2/src/commit.h +6 -0
  180. data/vendor/libgit2/src/commit_list.c +28 -76
  181. data/vendor/libgit2/src/commit_list.h +2 -2
  182. data/vendor/libgit2/src/common.h +3 -75
  183. data/vendor/libgit2/src/config.c +31 -40
  184. data/vendor/libgit2/src/config.h +7 -6
  185. data/vendor/libgit2/src/config_backend.h +12 -0
  186. data/vendor/libgit2/src/config_cache.c +39 -39
  187. data/vendor/libgit2/src/config_entries.c +69 -99
  188. data/vendor/libgit2/src/config_entries.h +1 -0
  189. data/vendor/libgit2/src/config_file.c +346 -380
  190. data/vendor/libgit2/src/config_mem.c +12 -16
  191. data/vendor/libgit2/src/config_parse.c +49 -29
  192. data/vendor/libgit2/src/config_parse.h +13 -12
  193. data/vendor/libgit2/src/config_snapshot.c +206 -0
  194. data/vendor/libgit2/src/crlf.c +14 -14
  195. data/vendor/libgit2/src/describe.c +21 -20
  196. data/vendor/libgit2/src/diff.c +43 -58
  197. data/vendor/libgit2/src/diff.h +4 -3
  198. data/vendor/libgit2/src/diff_driver.c +37 -38
  199. data/vendor/libgit2/src/diff_file.c +12 -10
  200. data/vendor/libgit2/src/diff_file.h +2 -2
  201. data/vendor/libgit2/src/diff_generate.c +148 -98
  202. data/vendor/libgit2/src/diff_generate.h +2 -2
  203. data/vendor/libgit2/src/diff_parse.c +1 -1
  204. data/vendor/libgit2/src/diff_print.c +25 -13
  205. data/vendor/libgit2/src/diff_stats.c +1 -1
  206. data/vendor/libgit2/src/diff_tform.c +11 -11
  207. data/vendor/libgit2/src/errors.c +21 -25
  208. data/vendor/libgit2/src/errors.h +81 -0
  209. data/vendor/libgit2/src/features.h.in +9 -2
  210. data/vendor/libgit2/src/fetch.c +7 -2
  211. data/vendor/libgit2/src/fetchhead.c +36 -4
  212. data/vendor/libgit2/src/filebuf.c +6 -10
  213. data/vendor/libgit2/src/filebuf.h +2 -2
  214. data/vendor/libgit2/src/filter.c +16 -8
  215. data/vendor/libgit2/src/{fileops.c → futils.c} +21 -17
  216. data/vendor/libgit2/src/{fileops.h → futils.h} +5 -5
  217. data/vendor/libgit2/src/global.c +12 -40
  218. data/vendor/libgit2/src/global.h +0 -2
  219. data/vendor/libgit2/src/hash.c +61 -0
  220. data/vendor/libgit2/src/hash.h +19 -21
  221. data/vendor/libgit2/src/hash/sha1.h +38 -0
  222. data/vendor/libgit2/src/hash/{hash_collisiondetect.h → sha1/collisiondetect.c} +14 -17
  223. data/vendor/libgit2/src/{sha1_lookup.h → hash/sha1/collisiondetect.h} +8 -8
  224. data/vendor/libgit2/src/hash/{hash_common_crypto.h → sha1/common_crypto.c} +15 -19
  225. data/vendor/libgit2/src/hash/sha1/common_crypto.h +19 -0
  226. data/vendor/libgit2/src/hash/{hash_generic.c → sha1/generic.c} +22 -10
  227. data/vendor/libgit2/src/hash/{hash_generic.h → sha1/generic.h} +4 -14
  228. data/vendor/libgit2/src/hash/{hash_mbedtls.c → sha1/mbedtls.c} +15 -7
  229. data/vendor/libgit2/src/hash/{hash_mbedtls.h → sha1/mbedtls.h} +6 -11
  230. data/vendor/libgit2/src/hash/{hash_openssl.h → sha1/openssl.c} +14 -18
  231. data/vendor/libgit2/src/hash/sha1/openssl.h +19 -0
  232. data/vendor/libgit2/src/hash/{sha1dc → sha1/sha1dc}/sha1.c +14 -3
  233. data/vendor/libgit2/src/hash/{sha1dc → sha1/sha1dc}/sha1.h +0 -0
  234. data/vendor/libgit2/src/hash/{sha1dc → sha1/sha1dc}/ubc_check.c +0 -0
  235. data/vendor/libgit2/src/hash/{sha1dc → sha1/sha1dc}/ubc_check.h +0 -0
  236. data/vendor/libgit2/src/hash/{hash_win32.c → sha1/win32.c} +34 -24
  237. data/vendor/libgit2/src/hash/{hash_win32.h → sha1/win32.h} +6 -19
  238. data/vendor/libgit2/src/hashsig.c +1 -1
  239. data/vendor/libgit2/src/idxmap.c +91 -65
  240. data/vendor/libgit2/src/idxmap.h +151 -15
  241. data/vendor/libgit2/src/ignore.c +32 -38
  242. data/vendor/libgit2/src/index.c +105 -83
  243. data/vendor/libgit2/src/index.h +1 -1
  244. data/vendor/libgit2/src/indexer.c +71 -72
  245. data/vendor/libgit2/src/integer.h +39 -4
  246. data/vendor/libgit2/src/iterator.c +40 -35
  247. data/vendor/libgit2/src/iterator.h +8 -8
  248. data/vendor/libgit2/src/map.h +1 -1
  249. data/vendor/libgit2/src/merge.c +78 -51
  250. data/vendor/libgit2/src/merge.h +2 -2
  251. data/vendor/libgit2/src/merge_driver.c +5 -5
  252. data/vendor/libgit2/src/merge_file.c +1 -1
  253. data/vendor/libgit2/src/mwindow.c +18 -23
  254. data/vendor/libgit2/src/mwindow.h +4 -4
  255. data/vendor/libgit2/src/net.c +411 -0
  256. data/vendor/libgit2/src/net.h +57 -0
  257. data/vendor/libgit2/src/netops.c +6 -193
  258. data/vendor/libgit2/src/netops.h +1 -34
  259. data/vendor/libgit2/src/notes.c +8 -5
  260. data/vendor/libgit2/src/object.c +3 -3
  261. data/vendor/libgit2/src/object.h +2 -0
  262. data/vendor/libgit2/src/odb.c +41 -23
  263. data/vendor/libgit2/src/odb.h +3 -2
  264. data/vendor/libgit2/src/odb_loose.c +17 -10
  265. data/vendor/libgit2/src/odb_mempack.c +13 -24
  266. data/vendor/libgit2/src/odb_pack.c +4 -5
  267. data/vendor/libgit2/src/offmap.c +43 -55
  268. data/vendor/libgit2/src/offmap.h +102 -24
  269. data/vendor/libgit2/src/oid.c +19 -8
  270. data/vendor/libgit2/src/oidmap.c +39 -57
  271. data/vendor/libgit2/src/oidmap.h +99 -19
  272. data/vendor/libgit2/src/pack-objects.c +28 -33
  273. data/vendor/libgit2/src/pack-objects.h +1 -1
  274. data/vendor/libgit2/src/pack.c +117 -129
  275. data/vendor/libgit2/src/pack.h +15 -18
  276. data/vendor/libgit2/src/parse.c +10 -0
  277. data/vendor/libgit2/src/parse.h +3 -3
  278. data/vendor/libgit2/src/patch.c +1 -1
  279. data/vendor/libgit2/src/patch_generate.c +2 -2
  280. data/vendor/libgit2/src/patch_parse.c +130 -33
  281. data/vendor/libgit2/src/path.c +43 -6
  282. data/vendor/libgit2/src/path.h +2 -0
  283. data/vendor/libgit2/src/pathspec.c +14 -14
  284. data/vendor/libgit2/src/pool.c +26 -22
  285. data/vendor/libgit2/src/pool.h +7 -7
  286. data/vendor/libgit2/src/posix.c +7 -7
  287. data/vendor/libgit2/src/posix.h +12 -1
  288. data/vendor/libgit2/src/proxy.c +7 -2
  289. data/vendor/libgit2/src/push.c +13 -7
  290. data/vendor/libgit2/src/reader.c +2 -2
  291. data/vendor/libgit2/src/rebase.c +87 -28
  292. data/vendor/libgit2/src/refdb.c +12 -0
  293. data/vendor/libgit2/src/refdb_fs.c +219 -167
  294. data/vendor/libgit2/src/reflog.c +11 -13
  295. data/vendor/libgit2/src/refs.c +39 -23
  296. data/vendor/libgit2/src/refs.h +8 -1
  297. data/vendor/libgit2/src/refspec.c +9 -16
  298. data/vendor/libgit2/src/regexp.c +221 -0
  299. data/vendor/libgit2/src/regexp.h +97 -0
  300. data/vendor/libgit2/src/remote.c +57 -55
  301. data/vendor/libgit2/src/remote.h +2 -2
  302. data/vendor/libgit2/src/repository.c +187 -154
  303. data/vendor/libgit2/src/repository.h +49 -40
  304. data/vendor/libgit2/src/revert.c +8 -3
  305. data/vendor/libgit2/src/revparse.c +18 -19
  306. data/vendor/libgit2/src/revwalk.c +72 -34
  307. data/vendor/libgit2/src/revwalk.h +20 -0
  308. data/vendor/libgit2/src/settings.c +13 -1
  309. data/vendor/libgit2/src/sortedcache.c +12 -26
  310. data/vendor/libgit2/src/sortedcache.h +1 -1
  311. data/vendor/libgit2/src/stash.c +47 -67
  312. data/vendor/libgit2/src/status.c +17 -11
  313. data/vendor/libgit2/src/streams/openssl.c +54 -2
  314. data/vendor/libgit2/src/streams/socket.c +2 -2
  315. data/vendor/libgit2/src/strmap.c +37 -84
  316. data/vendor/libgit2/src/strmap.h +105 -33
  317. data/vendor/libgit2/src/submodule.c +151 -126
  318. data/vendor/libgit2/src/submodule.h +1 -1
  319. data/vendor/libgit2/src/sysdir.c +11 -1
  320. data/vendor/libgit2/src/tag.c +10 -2
  321. data/vendor/libgit2/src/trace.c +1 -1
  322. data/vendor/libgit2/src/trace.h +3 -3
  323. data/vendor/libgit2/src/trailer.c +46 -32
  324. data/vendor/libgit2/src/transaction.c +10 -9
  325. data/vendor/libgit2/src/transports/auth.c +16 -15
  326. data/vendor/libgit2/src/transports/auth.h +18 -11
  327. data/vendor/libgit2/src/transports/auth_negotiate.c +64 -33
  328. data/vendor/libgit2/src/transports/auth_negotiate.h +2 -2
  329. data/vendor/libgit2/src/transports/auth_ntlm.c +223 -0
  330. data/vendor/libgit2/src/transports/auth_ntlm.h +38 -0
  331. data/vendor/libgit2/src/transports/credential.c +476 -0
  332. data/vendor/libgit2/src/transports/{cred_helpers.c → credential_helpers.c} +21 -8
  333. data/vendor/libgit2/src/transports/git.c +11 -16
  334. data/vendor/libgit2/src/transports/http.c +488 -1248
  335. data/vendor/libgit2/src/transports/http.h +4 -1
  336. data/vendor/libgit2/src/transports/httpclient.c +1549 -0
  337. data/vendor/libgit2/src/transports/httpclient.h +190 -0
  338. data/vendor/libgit2/src/transports/local.c +10 -10
  339. data/vendor/libgit2/src/transports/smart.c +19 -19
  340. data/vendor/libgit2/src/transports/smart.h +3 -3
  341. data/vendor/libgit2/src/transports/smart_pkt.c +1 -1
  342. data/vendor/libgit2/src/transports/smart_protocol.c +40 -64
  343. data/vendor/libgit2/src/transports/ssh.c +77 -59
  344. data/vendor/libgit2/src/transports/winhttp.c +272 -242
  345. data/vendor/libgit2/src/tree-cache.c +14 -7
  346. data/vendor/libgit2/src/tree.c +16 -26
  347. data/vendor/libgit2/src/unix/map.c +1 -1
  348. data/vendor/libgit2/src/unix/posix.h +2 -12
  349. data/vendor/libgit2/src/userdiff.h +3 -1
  350. data/vendor/libgit2/src/util.c +51 -53
  351. data/vendor/libgit2/src/util.h +16 -21
  352. data/vendor/libgit2/src/wildmatch.c +320 -0
  353. data/vendor/libgit2/src/wildmatch.h +23 -0
  354. data/vendor/libgit2/src/win32/map.c +3 -5
  355. data/vendor/libgit2/src/win32/path_w32.c +40 -3
  356. data/vendor/libgit2/src/win32/path_w32.h +15 -29
  357. data/vendor/libgit2/src/win32/posix.h +1 -4
  358. data/vendor/libgit2/src/win32/posix_w32.c +47 -5
  359. data/vendor/libgit2/src/win32/precompiled.h +0 -2
  360. data/vendor/libgit2/src/win32/thread.c +5 -10
  361. data/vendor/libgit2/src/win32/w32_buffer.c +7 -3
  362. data/vendor/libgit2/src/win32/w32_common.h +39 -0
  363. data/vendor/libgit2/src/win32/w32_crtdbg_stacktrace.c +0 -93
  364. data/vendor/libgit2/src/win32/w32_crtdbg_stacktrace.h +0 -2
  365. data/vendor/libgit2/src/win32/w32_stack.c +4 -9
  366. data/vendor/libgit2/src/win32/w32_stack.h +3 -3
  367. data/vendor/libgit2/src/win32/w32_util.c +31 -0
  368. data/vendor/libgit2/src/win32/w32_util.h +6 -32
  369. data/vendor/libgit2/src/worktree.c +79 -49
  370. data/vendor/libgit2/src/xdiff/xdiffi.c +1 -1
  371. data/vendor/libgit2/src/xdiff/xmerge.c +12 -0
  372. data/vendor/libgit2/src/xdiff/xpatience.c +3 -0
  373. data/vendor/libgit2/src/zstream.c +5 -0
  374. data/vendor/libgit2/src/zstream.h +1 -0
  375. metadata +108 -41
  376. data/vendor/libgit2/deps/regex/CMakeLists.txt +0 -2
  377. data/vendor/libgit2/deps/regex/COPYING +0 -502
  378. data/vendor/libgit2/deps/regex/config.h +0 -7
  379. data/vendor/libgit2/deps/regex/regcomp.c +0 -3857
  380. data/vendor/libgit2/deps/regex/regex.c +0 -92
  381. data/vendor/libgit2/deps/regex/regex.h +0 -582
  382. data/vendor/libgit2/deps/regex/regex_internal.c +0 -1744
  383. data/vendor/libgit2/deps/regex/regex_internal.h +0 -819
  384. data/vendor/libgit2/deps/regex/regexec.c +0 -4369
  385. data/vendor/libgit2/include/git2/inttypes.h +0 -309
  386. data/vendor/libgit2/include/git2/sys/time.h +0 -31
  387. data/vendor/libgit2/libgit2.pc.in +0 -13
  388. data/vendor/libgit2/src/fnmatch.c +0 -248
  389. data/vendor/libgit2/src/fnmatch.h +0 -48
  390. data/vendor/libgit2/src/sha1_lookup.c +0 -35
  391. data/vendor/libgit2/src/transports/cred.c +0 -390
@@ -84,7 +84,7 @@ typedef enum {
84
84
 
85
85
  /* The child of a folder that is in a directory/file conflict. */
86
86
  GIT_MERGE_DIFF_DF_CHILD = (1 << 11),
87
- } git_merge_diff_type_t;
87
+ } git_merge_diff_t;
88
88
 
89
89
  typedef struct {
90
90
  git_repository *repo;
@@ -113,7 +113,7 @@ typedef struct {
113
113
  * Description of changes to one file across three trees.
114
114
  */
115
115
  typedef struct {
116
- git_merge_diff_type_t type;
116
+ git_merge_diff_t type;
117
117
 
118
118
  git_index_entry ancestor_entry;
119
119
 
@@ -32,7 +32,7 @@ static struct merge_driver_registry merge_driver_registry;
32
32
 
33
33
  static void git_merge_driver_global_shutdown(void);
34
34
 
35
- const git_repository* git_merge_driver_source_repo(const git_merge_driver_source *src)
35
+ git_repository* git_merge_driver_source_repo(const git_merge_driver_source *src)
36
36
  {
37
37
  assert(src);
38
38
  return src->repo;
@@ -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,411 @@
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_joinpath(
157
+ git_net_url *out,
158
+ git_net_url *one,
159
+ const char *two)
160
+ {
161
+ git_buf path = GIT_BUF_INIT;
162
+ const char *query;
163
+ size_t one_len, two_len;
164
+
165
+ git_net_url_dispose(out);
166
+
167
+ if ((query = strchr(two, '?')) != NULL) {
168
+ two_len = query - two;
169
+
170
+ if (*(++query) != '\0') {
171
+ out->query = git__strdup(query);
172
+ GIT_ERROR_CHECK_ALLOC(out->query);
173
+ }
174
+ } else {
175
+ two_len = strlen(two);
176
+ }
177
+
178
+ /* Strip all trailing `/`s from the first path */
179
+ one_len = one->path ? strlen(one->path) : 0;
180
+ while (one_len && one->path[one_len - 1] == '/')
181
+ one_len--;
182
+
183
+ /* Strip all leading `/`s from the second path */
184
+ while (*two == '/') {
185
+ two++;
186
+ two_len--;
187
+ }
188
+
189
+ git_buf_put(&path, one->path, one_len);
190
+ git_buf_putc(&path, '/');
191
+ git_buf_put(&path, two, two_len);
192
+
193
+ if (git_buf_oom(&path))
194
+ return -1;
195
+
196
+ out->path = git_buf_detach(&path);
197
+
198
+ if (one->scheme) {
199
+ out->scheme = git__strdup(one->scheme);
200
+ GIT_ERROR_CHECK_ALLOC(out->scheme);
201
+ }
202
+
203
+ if (one->host) {
204
+ out->host = git__strdup(one->host);
205
+ GIT_ERROR_CHECK_ALLOC(out->host);
206
+ }
207
+
208
+ if (one->port) {
209
+ out->port = git__strdup(one->port);
210
+ GIT_ERROR_CHECK_ALLOC(out->port);
211
+ }
212
+
213
+ if (one->username) {
214
+ out->username = git__strdup(one->username);
215
+ GIT_ERROR_CHECK_ALLOC(out->username);
216
+ }
217
+
218
+ if (one->password) {
219
+ out->password = git__strdup(one->password);
220
+ GIT_ERROR_CHECK_ALLOC(out->password);
221
+ }
222
+
223
+ return 0;
224
+ }
225
+
226
+ /*
227
+ * Some servers strip the query parameters from the Location header
228
+ * when sending a redirect. Others leave it in place.
229
+ * Check for both, starting with the stripped case first,
230
+ * since it appears to be more common.
231
+ */
232
+ static void remove_service_suffix(
233
+ git_net_url *url,
234
+ const char *service_suffix)
235
+ {
236
+ const char *service_query = strchr(service_suffix, '?');
237
+ size_t full_suffix_len = strlen(service_suffix);
238
+ size_t suffix_len = service_query ?
239
+ (size_t)(service_query - service_suffix) : full_suffix_len;
240
+ size_t path_len = strlen(url->path);
241
+ ssize_t truncate = -1;
242
+
243
+ /*
244
+ * Check for a redirect without query parameters,
245
+ * like "/newloc/info/refs"'
246
+ */
247
+ if (suffix_len && path_len >= suffix_len) {
248
+ size_t suffix_offset = path_len - suffix_len;
249
+
250
+ if (git__strncmp(url->path + suffix_offset, service_suffix, suffix_len) == 0 &&
251
+ (!service_query || git__strcmp(url->query, service_query + 1) == 0)) {
252
+ truncate = suffix_offset;
253
+ }
254
+ }
255
+
256
+ /*
257
+ * If we haven't already found where to truncate to remove the
258
+ * suffix, check for a redirect with query parameters, like
259
+ * "/newloc/info/refs?service=git-upload-pack"
260
+ */
261
+ if (truncate < 0 && git__suffixcmp(url->path, service_suffix) == 0)
262
+ truncate = path_len - full_suffix_len;
263
+
264
+ /* Ensure we leave a minimum of '/' as the path */
265
+ if (truncate == 0)
266
+ truncate++;
267
+
268
+ if (truncate > 0) {
269
+ url->path[truncate] = '\0';
270
+
271
+ git__free(url->query);
272
+ url->query = NULL;
273
+ }
274
+ }
275
+
276
+ int git_net_url_apply_redirect(
277
+ git_net_url *url,
278
+ const char *redirect_location,
279
+ const char *service_suffix)
280
+ {
281
+ git_net_url tmp = GIT_NET_URL_INIT;
282
+ int error = 0;
283
+
284
+ assert(url && redirect_location);
285
+
286
+ if (redirect_location[0] == '/') {
287
+ git__free(url->path);
288
+
289
+ if ((url->path = git__strdup(redirect_location)) == NULL) {
290
+ error = -1;
291
+ goto done;
292
+ }
293
+ } else {
294
+ git_net_url *original = url;
295
+
296
+ if ((error = git_net_url_parse(&tmp, redirect_location)) < 0)
297
+ goto done;
298
+
299
+ /* Validate that this is a legal redirection */
300
+
301
+ if (original->scheme &&
302
+ strcmp(original->scheme, tmp.scheme) != 0 &&
303
+ strcmp(tmp.scheme, "https") != 0) {
304
+ git_error_set(GIT_ERROR_NET, "cannot redirect from '%s' to '%s'",
305
+ original->scheme, tmp.scheme);
306
+
307
+ error = -1;
308
+ goto done;
309
+ }
310
+
311
+ if (original->host &&
312
+ git__strcasecmp(original->host, tmp.host) != 0) {
313
+ git_error_set(GIT_ERROR_NET, "cannot redirect from '%s' to '%s'",
314
+ original->host, tmp.host);
315
+
316
+ error = -1;
317
+ goto done;
318
+ }
319
+
320
+ git_net_url_swap(url, &tmp);
321
+ }
322
+
323
+ /* Remove the service suffix if it was given to us */
324
+ if (service_suffix)
325
+ remove_service_suffix(url, service_suffix);
326
+
327
+ done:
328
+ git_net_url_dispose(&tmp);
329
+ return error;
330
+ }
331
+
332
+ bool git_net_url_valid(git_net_url *url)
333
+ {
334
+ return (url->host && url->port && url->path);
335
+ }
336
+
337
+ int git_net_url_is_default_port(git_net_url *url)
338
+ {
339
+ return (strcmp(url->port, default_port_for_scheme(url->scheme)) == 0);
340
+ }
341
+
342
+ void git_net_url_swap(git_net_url *a, git_net_url *b)
343
+ {
344
+ git_net_url tmp = GIT_NET_URL_INIT;
345
+
346
+ memcpy(&tmp, a, sizeof(git_net_url));
347
+ memcpy(a, b, sizeof(git_net_url));
348
+ memcpy(b, &tmp, sizeof(git_net_url));
349
+ }
350
+
351
+ int git_net_url_fmt(git_buf *buf, git_net_url *url)
352
+ {
353
+ git_buf_puts(buf, url->scheme);
354
+ git_buf_puts(buf, "://");
355
+
356
+ if (url->username) {
357
+ git_buf_puts(buf, url->username);
358
+
359
+ if (url->password) {
360
+ git_buf_puts(buf, ":");
361
+ git_buf_puts(buf, url->password);
362
+ }
363
+
364
+ git_buf_putc(buf, '@');
365
+ }
366
+
367
+ git_buf_puts(buf, url->host);
368
+
369
+ if (url->port && !git_net_url_is_default_port(url)) {
370
+ git_buf_putc(buf, ':');
371
+ git_buf_puts(buf, url->port);
372
+ }
373
+
374
+ git_buf_puts(buf, url->path ? url->path : "/");
375
+
376
+ if (url->query) {
377
+ git_buf_putc(buf, '?');
378
+ git_buf_puts(buf, url->query);
379
+ }
380
+
381
+ return git_buf_oom(buf) ? -1 : 0;
382
+ }
383
+
384
+ int git_net_url_fmt_path(git_buf *buf, git_net_url *url)
385
+ {
386
+ git_buf_puts(buf, url->path ? url->path : "/");
387
+
388
+ if (url->query) {
389
+ git_buf_putc(buf, '?');
390
+ git_buf_puts(buf, url->query);
391
+ }
392
+
393
+ return git_buf_oom(buf) ? -1 : 0;
394
+ }
395
+
396
+ void git_net_url_dispose(git_net_url *url)
397
+ {
398
+ if (url->username)
399
+ git__memzero(url->username, strlen(url->username));
400
+
401
+ if (url->password)
402
+ git__memzero(url->password, strlen(url->password));
403
+
404
+ git__free(url->scheme); url->scheme = NULL;
405
+ git__free(url->host); url->host = NULL;
406
+ git__free(url->port); url->port = NULL;
407
+ git__free(url->path); url->path = NULL;
408
+ git__free(url->query); url->query = NULL;
409
+ git__free(url->username); url->username = NULL;
410
+ git__free(url->password); url->password = NULL;
411
+ }