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
@@ -10,7 +10,7 @@
10
10
  #include "diff.h"
11
11
  #include "diff_file.h"
12
12
  #include "patch_generate.h"
13
- #include "fileops.h"
13
+ #include "futils.h"
14
14
  #include "zstream.h"
15
15
  #include "blob.h"
16
16
  #include "delta.h"
@@ -48,7 +48,7 @@ static int diff_print_info_init__common(
48
48
  if (!pi->id_strlen) {
49
49
  if (!repo)
50
50
  pi->id_strlen = GIT_ABBREV_DEFAULT;
51
- else if (git_repository__cvar(&pi->id_strlen, repo, GIT_CVAR_ABBREV) < 0)
51
+ else if (git_repository__configmap_lookup(&pi->id_strlen, repo, GIT_CONFIGMAP_ABBREV) < 0)
52
52
  return -1;
53
53
  }
54
54
 
@@ -269,7 +269,8 @@ static int diff_print_modes(
269
269
  }
270
270
 
271
271
  static int diff_print_oid_range(
272
- git_buf *out, const git_diff_delta *delta, int id_strlen)
272
+ git_buf *out, const git_diff_delta *delta, int id_strlen,
273
+ bool print_index)
273
274
  {
274
275
  char start_oid[GIT_OID_HEXSZ+1], end_oid[GIT_OID_HEXSZ+1];
275
276
 
@@ -293,8 +294,9 @@ static int diff_print_oid_range(
293
294
  git_oid_tostr(end_oid, id_strlen + 1, &delta->new_file.id);
294
295
 
295
296
  if (delta->old_file.mode == delta->new_file.mode) {
296
- git_buf_printf(out, "index %s..%s %o\n",
297
- start_oid, end_oid, delta->old_file.mode);
297
+ if (print_index)
298
+ git_buf_printf(out, "index %s..%s %o\n",
299
+ start_oid, end_oid, delta->old_file.mode);
298
300
  } else {
299
301
  if (delta->old_file.mode == 0)
300
302
  git_buf_printf(out, "new file mode %o\n", delta->new_file.mode);
@@ -303,7 +305,8 @@ static int diff_print_oid_range(
303
305
  else
304
306
  diff_print_modes(out, delta);
305
307
 
306
- git_buf_printf(out, "index %s..%s\n", start_oid, end_oid);
308
+ if (print_index)
309
+ git_buf_printf(out, "index %s..%s\n", start_oid, end_oid);
307
310
  }
308
311
 
309
312
  return git_buf_oom(out) ? -1 : 0;
@@ -325,10 +328,10 @@ static int diff_delta_format_with_paths(
325
328
  const char *oldpath,
326
329
  const char *newpath)
327
330
  {
328
- if (git_oid_iszero(&delta->old_file.id))
331
+ if (git_oid_is_zero(&delta->old_file.id))
329
332
  oldpath = "/dev/null";
330
333
 
331
- if (git_oid_iszero(&delta->new_file.id))
334
+ if (git_oid_is_zero(&delta->new_file.id))
332
335
  newpath = "/dev/null";
333
336
 
334
337
  return git_buf_printf(out, template, oldpath, newpath);
@@ -381,8 +384,8 @@ done:
381
384
 
382
385
  static bool delta_is_unchanged(const git_diff_delta *delta)
383
386
  {
384
- if (git_oid_iszero(&delta->old_file.id) &&
385
- git_oid_iszero(&delta->new_file.id))
387
+ if (git_oid_is_zero(&delta->old_file.id) &&
388
+ git_oid_is_zero(&delta->new_file.id))
386
389
  return true;
387
390
 
388
391
  if (delta->old_file.mode == GIT_FILEMODE_COMMIT ||
@@ -400,7 +403,8 @@ int git_diff_delta__format_file_header(
400
403
  const git_diff_delta *delta,
401
404
  const char *oldpfx,
402
405
  const char *newpfx,
403
- int id_strlen)
406
+ int id_strlen,
407
+ bool print_index)
404
408
  {
405
409
  git_buf old_path = GIT_BUF_INIT, new_path = GIT_BUF_INIT;
406
410
  bool unchanged = delta_is_unchanged(delta);
@@ -431,7 +435,8 @@ int git_diff_delta__format_file_header(
431
435
  }
432
436
 
433
437
  if (!unchanged) {
434
- if ((error = diff_print_oid_range(out, delta, id_strlen)) < 0)
438
+ if ((error = diff_print_oid_range(out, delta,
439
+ id_strlen, print_index)) < 0)
435
440
  goto done;
436
441
 
437
442
  if ((delta->flags & GIT_DIFF_FLAG_BINARY) == 0)
@@ -566,6 +571,7 @@ static int diff_print_patch_file(
566
571
  (pi->flags & GIT_DIFF_FORCE_BINARY);
567
572
  bool show_binary = !!(pi->flags & GIT_DIFF_SHOW_BINARY);
568
573
  int id_strlen = pi->id_strlen;
574
+ bool print_index = (pi->format != GIT_DIFF_FORMAT_PATCH_ID);
569
575
 
570
576
  if (binary && show_binary)
571
577
  id_strlen = delta->old_file.id_abbrev ? delta->old_file.id_abbrev :
@@ -582,7 +588,8 @@ static int diff_print_patch_file(
582
588
  return 0;
583
589
 
584
590
  if ((error = git_diff_delta__format_file_header(
585
- pi->buf, delta, oldpfx, newpfx, id_strlen)) < 0)
591
+ pi->buf, delta, oldpfx, newpfx,
592
+ id_strlen, print_index)) < 0)
586
593
  return error;
587
594
 
588
595
  pi->line.origin = GIT_DIFF_LINE_FILE_HDR;
@@ -670,6 +677,11 @@ int git_diff_print(
670
677
  print_hunk = diff_print_patch_hunk;
671
678
  print_line = diff_print_patch_line;
672
679
  break;
680
+ case GIT_DIFF_FORMAT_PATCH_ID:
681
+ print_file = diff_print_patch_file;
682
+ print_binary = diff_print_patch_binary;
683
+ print_line = diff_print_patch_line;
684
+ break;
673
685
  case GIT_DIFF_FORMAT_PATCH_HEADER:
674
686
  print_file = diff_print_patch_file;
675
687
  break;
@@ -55,7 +55,7 @@ int git_diff_file_stats__full_to_buf(
55
55
  {
56
56
  const char *old_path = NULL, *new_path = NULL;
57
57
  size_t padding;
58
- git_off_t old_size, new_size;
58
+ git_object_size_t old_size, new_size;
59
59
 
60
60
  old_path = delta->old_file.path;
61
61
  new_path = delta->new_file.path;
@@ -14,7 +14,7 @@
14
14
  #include "diff.h"
15
15
  #include "diff_generate.h"
16
16
  #include "path.h"
17
- #include "fileops.h"
17
+ #include "futils.h"
18
18
  #include "config.h"
19
19
 
20
20
  git_diff_delta *git_diff__delta_dup(
@@ -510,7 +510,7 @@ static int similarity_sig(
510
510
  if (file->size != git_blob_rawsize(info->blob))
511
511
  file->size = git_blob_rawsize(info->blob);
512
512
 
513
- sz = (size_t)(git__is_sizet(file->size) ? file->size : -1);
513
+ sz = git__is_sizet(file->size) ? (size_t)file->size : (size_t)-1;
514
514
 
515
515
  error = opts->metric->buffer_signature(
516
516
  &cache[info->idx], info->file,
@@ -560,13 +560,13 @@ static int similarity_measure(
560
560
 
561
561
  /* if exact match is requested, force calculation of missing OIDs now */
562
562
  if (exact_match) {
563
- if (git_oid_iszero(&a_file->id) &&
563
+ if (git_oid_is_zero(&a_file->id) &&
564
564
  diff->old_src == GIT_ITERATOR_TYPE_WORKDIR &&
565
565
  !git_diff__oid_for_file(&a_file->id,
566
566
  diff, a_file->path, a_file->mode, a_file->size))
567
567
  a_file->flags |= GIT_DIFF_FLAG_VALID_ID;
568
568
 
569
- if (git_oid_iszero(&b_file->id) &&
569
+ if (git_oid_is_zero(&b_file->id) &&
570
570
  diff->new_src == GIT_ITERATOR_TYPE_WORKDIR &&
571
571
  !git_diff__oid_for_file(&b_file->id,
572
572
  diff, b_file->path, b_file->mode, b_file->size))
@@ -49,9 +49,17 @@ void git_error_set_oom(void)
49
49
  GIT_GLOBAL->last_error = &g_git_oom_error;
50
50
  }
51
51
 
52
- void git_error_set(int error_class, const char *string, ...)
52
+ void git_error_set(int error_class, const char *fmt, ...)
53
+ {
54
+ va_list ap;
55
+
56
+ va_start(ap, fmt);
57
+ git_error_vset(error_class, fmt, ap);
58
+ va_end(ap);
59
+ }
60
+
61
+ void git_error_vset(int error_class, const char *fmt, va_list ap)
53
62
  {
54
- va_list arglist;
55
63
  #ifdef GIT_WIN32
56
64
  DWORD win32_error_code = (error_class == GIT_ERROR_OS) ? GetLastError() : 0;
57
65
  #endif
@@ -59,11 +67,8 @@ void git_error_set(int error_class, const char *string, ...)
59
67
  git_buf *buf = &GIT_GLOBAL->error_buf;
60
68
 
61
69
  git_buf_clear(buf);
62
- if (string) {
63
- va_start(arglist, string);
64
- git_buf_vprintf(buf, string, arglist);
65
- va_end(arglist);
66
-
70
+ if (fmt) {
71
+ git_buf_vprintf(buf, fmt, ap);
67
72
  if (error_class == GIT_ERROR_OS)
68
73
  git_buf_PUTS(buf, ": ");
69
74
  }
@@ -105,21 +110,6 @@ void git_error_set_str(int error_class, const char *string)
105
110
  set_error_from_buffer(error_class);
106
111
  }
107
112
 
108
- int git_error_set_regex(const regex_t *regex, int error_code)
109
- {
110
- char error_buf[1024];
111
-
112
- assert(error_code);
113
-
114
- regerror(error_code, regex, error_buf, sizeof(error_buf));
115
- git_error_set_str(GIT_ERROR_REGEX, error_buf);
116
-
117
- if (error_code == REG_NOMATCH)
118
- return GIT_ENOTFOUND;
119
-
120
- return GIT_EINVALIDSPEC;
121
- }
122
-
123
113
  void git_error_clear(void)
124
114
  {
125
115
  if (GIT_GLOBAL->last_error != NULL) {
@@ -0,0 +1,81 @@
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
+ #ifndef INCLUDE_errors_h__
9
+ #define INCLUDE_errors_h__
10
+
11
+ #include "common.h"
12
+
13
+ /*
14
+ * Set the error message for this thread, formatting as needed.
15
+ */
16
+ void git_error_set(int error_class, const char *fmt, ...) GIT_FORMAT_PRINTF(2, 3);
17
+ void git_error_vset(int error_class, const char *fmt, va_list ap);
18
+
19
+ /**
20
+ * Set error message for user callback if needed.
21
+ *
22
+ * If the error code in non-zero and no error message is set, this
23
+ * sets a generic error message.
24
+ *
25
+ * @return This always returns the `error_code` parameter.
26
+ */
27
+ GIT_INLINE(int) git_error_set_after_callback_function(
28
+ int error_code, const char *action)
29
+ {
30
+ if (error_code) {
31
+ const git_error *e = git_error_last();
32
+ if (!e || !e->message)
33
+ git_error_set(e ? e->klass : GIT_ERROR_CALLBACK,
34
+ "%s callback returned %d", action, error_code);
35
+ }
36
+ return error_code;
37
+ }
38
+
39
+ #ifdef GIT_WIN32
40
+ #define git_error_set_after_callback(code) \
41
+ git_error_set_after_callback_function((code), __FUNCTION__)
42
+ #else
43
+ #define git_error_set_after_callback(code) \
44
+ git_error_set_after_callback_function((code), __func__)
45
+ #endif
46
+
47
+ /**
48
+ * Gets the system error code for this thread.
49
+ */
50
+ int git_error_system_last(void);
51
+
52
+ /**
53
+ * Sets the system error code for this thread.
54
+ */
55
+ void git_error_system_set(int code);
56
+
57
+ /**
58
+ * Structure to preserve libgit2 error state
59
+ */
60
+ typedef struct {
61
+ int error_code;
62
+ unsigned int oom : 1;
63
+ git_error error_msg;
64
+ } git_error_state;
65
+
66
+ /**
67
+ * Capture current error state to restore later, returning error code.
68
+ * If `error_code` is zero, this does not clear the current error state.
69
+ * You must either restore this error state, or free it.
70
+ */
71
+ extern int git_error_state_capture(git_error_state *state, int error_code);
72
+
73
+ /**
74
+ * Restore error state to a previous value, returning saved error code.
75
+ */
76
+ extern int git_error_state_restore(git_error_state *state);
77
+
78
+ /** Free an error state. */
79
+ extern void git_error_state_free(git_error_state *state);
80
+
81
+ #endif
@@ -15,14 +15,21 @@
15
15
  #cmakedefine GIT_USE_STAT_MTIMESPEC 1
16
16
  #cmakedefine GIT_USE_STAT_MTIME_NSEC 1
17
17
  #cmakedefine GIT_USE_FUTIMENS 1
18
- #cmakedefine GIT_USE_REGCOMP_L 1
18
+
19
+ #cmakedefine GIT_REGEX_REGCOMP_L
20
+ #cmakedefine GIT_REGEX_REGCOMP
21
+ #cmakedefine GIT_REGEX_PCRE
22
+ #cmakedefine GIT_REGEX_PCRE2
23
+ #cmakedefine GIT_REGEX_BUILTIN 1
19
24
 
20
25
  #cmakedefine GIT_SSH 1
21
26
  #cmakedefine GIT_SSH_MEMORY_CREDENTIALS 1
22
27
 
28
+ #cmakedefine GIT_NTLM 1
23
29
  #cmakedefine GIT_GSSAPI 1
24
- #cmakedefine GIT_WINHTTP 1
30
+ #cmakedefine GIT_GSSFRAMEWORK 1
25
31
 
32
+ #cmakedefine GIT_WINHTTP 1
26
33
  #cmakedefine GIT_HTTPS 1
27
34
  #cmakedefine GIT_OPENSSL 1
28
35
  #cmakedefine GIT_SECURE_TRANSPORT 1
@@ -134,7 +134,7 @@ int git_fetch_negotiate(git_remote *remote, const git_fetch_options *opts)
134
134
  int git_fetch_download_pack(git_remote *remote, const git_remote_callbacks *callbacks)
135
135
  {
136
136
  git_transport *t = remote->transport;
137
- git_transfer_progress_cb progress = NULL;
137
+ git_indexer_progress_cb progress = NULL;
138
138
  void *payload = NULL;
139
139
 
140
140
  if (!remote->need_pack)
@@ -148,9 +148,14 @@ int git_fetch_download_pack(git_remote *remote, const git_remote_callbacks *call
148
148
  return t->download_pack(t, remote->repo, &remote->stats, progress, payload);
149
149
  }
150
150
 
151
- int git_fetch_init_options(git_fetch_options *opts, unsigned int version)
151
+ int git_fetch_options_init(git_fetch_options *opts, unsigned int version)
152
152
  {
153
153
  GIT_INIT_STRUCTURE_FROM_TEMPLATE(
154
154
  opts, version, git_fetch_options, GIT_FETCH_OPTIONS_INIT);
155
155
  return 0;
156
156
  }
157
+
158
+ int git_fetch_init_options(git_fetch_options *opts, unsigned int version)
159
+ {
160
+ return git_fetch_options_init(opts, version);
161
+ }
@@ -11,7 +11,7 @@
11
11
  #include "git2/oid.h"
12
12
 
13
13
  #include "buffer.h"
14
- #include "fileops.h"
14
+ #include "futils.h"
15
15
  #include "filebuf.h"
16
16
  #include "refs.h"
17
17
  #include "repository.h"
@@ -7,7 +7,7 @@
7
7
 
8
8
  #include "filebuf.h"
9
9
 
10
- #include "fileops.h"
10
+ #include "futils.h"
11
11
 
12
12
  static const size_t WRITE_BUFFER_SIZE = (4096 * 2);
13
13
 
@@ -44,18 +44,14 @@ static int verify_last_error(git_filebuf *file)
44
44
  static int lock_file(git_filebuf *file, int flags, mode_t mode)
45
45
  {
46
46
  if (git_path_exists(file->path_lock) == true) {
47
- if (flags & GIT_FILEBUF_FORCE)
48
- p_unlink(file->path_lock);
49
- else {
50
- git_error_clear(); /* actual OS error code just confuses */
51
- git_error_set(GIT_ERROR_OS,
52
- "failed to lock file '%s' for writing", file->path_lock);
53
- return GIT_ELOCKED;
54
- }
47
+ git_error_clear(); /* actual OS error code just confuses */
48
+ git_error_set(GIT_ERROR_OS,
49
+ "failed to lock file '%s' for writing", file->path_lock);
50
+ return GIT_ELOCKED;
55
51
  }
56
52
 
57
53
  /* create path to the file buffer is required */
58
- if (flags & GIT_FILEBUF_FORCE) {
54
+ if (flags & GIT_FILEBUF_CREATE_LEADING_DIRS) {
59
55
  /* XXX: Should dirmode here be configurable? Or is 0777 always fine? */
60
56
  file->fd = git_futils_creat_locked_withpath(file->path_lock, 0777, mode);
61
57
  } else {
@@ -9,7 +9,7 @@
9
9
 
10
10
  #include "common.h"
11
11
 
12
- #include "fileops.h"
12
+ #include "futils.h"
13
13
  #include "hash.h"
14
14
  #include <zlib.h>
15
15
 
@@ -19,7 +19,7 @@
19
19
 
20
20
  #define GIT_FILEBUF_HASH_CONTENTS (1 << 0)
21
21
  #define GIT_FILEBUF_APPEND (1 << 2)
22
- #define GIT_FILEBUF_FORCE (1 << 3)
22
+ #define GIT_FILEBUF_CREATE_LEADING_DIRS (1 << 3)
23
23
  #define GIT_FILEBUF_TEMPORARY (1 << 4)
24
24
  #define GIT_FILEBUF_DO_NOT_BUFFER (1 << 5)
25
25
  #define GIT_FILEBUF_FSYNC (1 << 6)
@@ -8,7 +8,7 @@
8
8
  #include "filter.h"
9
9
 
10
10
  #include "common.h"
11
- #include "fileops.h"
11
+ #include "futils.h"
12
12
  #include "hash.h"
13
13
  #include "repository.h"
14
14
  #include "global.h"
@@ -385,7 +385,7 @@ uint16_t git_filter_source_filemode(const git_filter_source *src)
385
385
 
386
386
  const git_oid *git_filter_source_id(const git_filter_source *src)
387
387
  {
388
- return git_oid_iszero(&src->oid) ? NULL : &src->oid;
388
+ return git_oid_is_zero(&src->oid) ? NULL : &src->oid;
389
389
  }
390
390
 
391
391
  git_filter_mode_t git_filter_source_mode(const git_filter_source *src)
@@ -428,13 +428,21 @@ static int filter_list_check_attributes(
428
428
  git_filter_def *fdef,
429
429
  const git_filter_source *src)
430
430
  {
431
- int error;
432
- size_t i;
433
431
  const char **strs = git__calloc(fdef->nattrs, sizeof(const char *));
432
+ uint32_t flags = 0;
433
+ size_t i;
434
+ int error;
435
+
434
436
  GIT_ERROR_CHECK_ALLOC(strs);
435
437
 
438
+ if ((src->flags & GIT_FILTER_NO_SYSTEM_ATTRIBUTES) != 0)
439
+ flags |= GIT_ATTR_CHECK_NO_SYSTEM;
440
+
441
+ if ((src->flags & GIT_FILTER_ATTRIBUTES_FROM_HEAD) != 0)
442
+ flags |= GIT_ATTR_CHECK_INCLUDE_HEAD;
443
+
436
444
  error = git_attr_get_many_with_session(
437
- strs, repo, attr_session, 0, src->path, fdef->nattrs, fdef->attrs);
445
+ strs, repo, attr_session, flags, src->path, fdef->nattrs, fdef->attrs);
438
446
 
439
447
  /* if no values were found but no matches are needed, it's okay! */
440
448
  if (error == GIT_ENOTFOUND && !fdef->nmatches) {
@@ -445,7 +453,7 @@ static int filter_list_check_attributes(
445
453
 
446
454
  for (i = 0; !error && i < fdef->nattrs; ++i) {
447
455
  const char *want = fdef->attrs[fdef->nattrs + i];
448
- git_attr_t want_type, found_type;
456
+ git_attr_value_t want_type, found_type;
449
457
 
450
458
  if (!want)
451
459
  continue;
@@ -455,7 +463,7 @@ static int filter_list_check_attributes(
455
463
 
456
464
  if (want_type != found_type)
457
465
  error = GIT_ENOTFOUND;
458
- else if (want_type == GIT_ATTR_VALUE_T &&
466
+ else if (want_type == GIT_ATTR_VALUE_STRING &&
459
467
  strcmp(want, strs[i]) &&
460
468
  strcmp(want, "*"))
461
469
  error = GIT_ENOTFOUND;
@@ -756,7 +764,7 @@ int git_filter_list_apply_to_file(
756
764
 
757
765
  static int buf_from_blob(git_buf *out, git_blob *blob)
758
766
  {
759
- git_off_t rawsize = git_blob_rawsize(blob);
767
+ git_object_size_t rawsize = git_blob_rawsize(blob);
760
768
 
761
769
  if (!git__is_sizet(rawsize)) {
762
770
  git_error_set(GIT_ERROR_OS, "blob is too large to filter");