rubygems-update 2.6.11 → 2.7.11

Sign up to get free protection for your applications and to get access to all the features.
Files changed (405) hide show
  1. checksums.yaml +4 -4
  2. data/.travis.yml +8 -22
  3. data/CONTRIBUTING.rdoc +53 -54
  4. data/History.txt +405 -0
  5. data/Manifest.txt +46 -15
  6. data/POLICIES.rdoc +3 -3
  7. data/README.md +72 -0
  8. data/Rakefile +55 -12
  9. data/appveyor.yml +29 -1
  10. data/bin/gem +1 -1
  11. data/bin/update_rubygems +2 -2
  12. data/bundler/CHANGELOG.md +412 -9
  13. data/bundler/CODE_OF_CONDUCT.md +1 -1
  14. data/bundler/CONTRIBUTING.md +10 -29
  15. data/bundler/README.md +27 -11
  16. data/bundler/bundler.gemspec +58 -0
  17. data/bundler/exe/bundle +5 -7
  18. data/bundler/exe/bundle_ruby +4 -3
  19. data/bundler/lib/bundler.rb +103 -79
  20. data/bundler/lib/bundler/build_metadata.rb +53 -0
  21. data/bundler/lib/bundler/capistrano.rb +5 -0
  22. data/bundler/lib/bundler/cli.rb +231 -66
  23. data/bundler/lib/bundler/cli/add.rb +25 -0
  24. data/bundler/lib/bundler/cli/binstubs.rb +9 -7
  25. data/bundler/lib/bundler/cli/cache.rb +5 -4
  26. data/bundler/lib/bundler/cli/check.rb +3 -5
  27. data/bundler/lib/bundler/cli/clean.rb +5 -6
  28. data/bundler/lib/bundler/cli/common.rb +18 -2
  29. data/bundler/lib/bundler/cli/config.rb +26 -7
  30. data/bundler/lib/bundler/cli/console.rb +2 -1
  31. data/bundler/lib/bundler/cli/doctor.rb +1 -0
  32. data/bundler/lib/bundler/cli/exec.rb +6 -5
  33. data/bundler/lib/bundler/cli/gem.rb +42 -18
  34. data/bundler/lib/bundler/cli/info.rb +50 -0
  35. data/bundler/lib/bundler/cli/init.rb +21 -7
  36. data/bundler/lib/bundler/cli/inject.rb +13 -4
  37. data/bundler/lib/bundler/cli/install.rb +61 -77
  38. data/bundler/lib/bundler/cli/issue.rb +40 -0
  39. data/bundler/lib/bundler/cli/list.rb +22 -0
  40. data/bundler/lib/bundler/cli/lock.rb +4 -2
  41. data/bundler/lib/bundler/cli/open.rb +2 -2
  42. data/bundler/lib/bundler/cli/outdated.rb +30 -28
  43. data/bundler/lib/bundler/cli/package.rb +9 -6
  44. data/bundler/lib/bundler/cli/platform.rb +1 -0
  45. data/bundler/lib/bundler/cli/plugin.rb +1 -0
  46. data/bundler/lib/bundler/cli/pristine.rb +43 -0
  47. data/bundler/lib/bundler/cli/show.rb +1 -1
  48. data/bundler/lib/bundler/cli/update.rb +36 -13
  49. data/bundler/lib/bundler/cli/viz.rb +5 -1
  50. data/bundler/lib/bundler/compact_index_client.rb +1 -0
  51. data/bundler/lib/bundler/compact_index_client/cache.rb +1 -2
  52. data/bundler/lib/bundler/compact_index_client/updater.rb +36 -8
  53. data/bundler/lib/bundler/compatibility_guard.rb +14 -0
  54. data/bundler/lib/bundler/constants.rb +1 -0
  55. data/bundler/lib/bundler/current_ruby.rb +16 -8
  56. data/bundler/lib/bundler/definition.rb +252 -170
  57. data/bundler/lib/bundler/dep_proxy.rb +3 -1
  58. data/bundler/lib/bundler/dependency.rb +7 -7
  59. data/bundler/lib/bundler/deployment.rb +1 -1
  60. data/bundler/lib/bundler/deprecate.rb +15 -3
  61. data/bundler/lib/bundler/dsl.rb +103 -62
  62. data/bundler/lib/bundler/endpoint_specification.rb +13 -3
  63. data/bundler/lib/bundler/env.rb +101 -38
  64. data/bundler/lib/bundler/environment_preserver.rb +27 -6
  65. data/bundler/lib/bundler/errors.rb +3 -1
  66. data/bundler/lib/bundler/feature_flag.rb +39 -4
  67. data/bundler/lib/bundler/fetcher.rb +18 -11
  68. data/bundler/lib/bundler/fetcher/base.rb +1 -0
  69. data/bundler/lib/bundler/fetcher/compact_index.rb +2 -12
  70. data/bundler/lib/bundler/fetcher/dependency.rb +2 -1
  71. data/bundler/lib/bundler/fetcher/downloader.rb +14 -7
  72. data/bundler/lib/bundler/fetcher/index.rb +3 -2
  73. data/bundler/lib/bundler/friendly_errors.rb +7 -2
  74. data/bundler/lib/bundler/gem_helper.rb +24 -10
  75. data/bundler/lib/bundler/gem_helpers.rb +1 -0
  76. data/bundler/lib/bundler/gem_remote_fetcher.rb +1 -0
  77. data/bundler/lib/bundler/gem_tasks.rb +1 -0
  78. data/bundler/lib/bundler/gem_version_promoter.rb +13 -0
  79. data/bundler/lib/bundler/gemdeps.rb +1 -0
  80. data/bundler/lib/bundler/graph.rb +1 -0
  81. data/bundler/lib/bundler/index.rb +19 -11
  82. data/bundler/lib/bundler/injector.rb +54 -30
  83. data/bundler/lib/bundler/inline.rb +10 -10
  84. data/bundler/lib/bundler/installer.rb +114 -52
  85. data/bundler/lib/bundler/installer/gem_installer.rb +14 -4
  86. data/bundler/lib/bundler/installer/parallel_installer.rb +91 -42
  87. data/bundler/lib/bundler/installer/standalone.rb +1 -0
  88. data/bundler/lib/bundler/lazy_specification.rb +17 -4
  89. data/bundler/lib/bundler/lockfile_generator.rb +95 -0
  90. data/bundler/lib/bundler/lockfile_parser.rb +49 -35
  91. data/bundler/lib/bundler/match_platform.rb +1 -0
  92. data/bundler/lib/bundler/mirror.rb +10 -5
  93. data/bundler/lib/bundler/plugin.rb +8 -3
  94. data/bundler/lib/bundler/plugin/api/source.rb +16 -3
  95. data/bundler/lib/bundler/plugin/index.rb +9 -2
  96. data/bundler/lib/bundler/plugin/installer.rb +7 -6
  97. data/bundler/lib/bundler/plugin/source_list.rb +7 -8
  98. data/bundler/lib/bundler/process_lock.rb +24 -0
  99. data/bundler/lib/bundler/psyched_yaml.rb +10 -0
  100. data/bundler/lib/bundler/remote_specification.rb +25 -1
  101. data/bundler/lib/bundler/resolver.rb +176 -193
  102. data/bundler/lib/bundler/resolver/spec_group.rb +106 -0
  103. data/bundler/lib/bundler/retry.rb +1 -0
  104. data/bundler/lib/bundler/ruby_dsl.rb +1 -0
  105. data/bundler/lib/bundler/ruby_version.rb +7 -2
  106. data/bundler/lib/bundler/rubygems_ext.rb +18 -8
  107. data/bundler/lib/bundler/rubygems_gem_installer.rb +25 -2
  108. data/bundler/lib/bundler/rubygems_integration.rb +166 -69
  109. data/bundler/lib/bundler/runtime.rb +29 -19
  110. data/bundler/lib/bundler/settings.rb +202 -87
  111. data/bundler/lib/bundler/settings/validator.rb +79 -0
  112. data/bundler/lib/bundler/setup.rb +4 -7
  113. data/bundler/lib/bundler/shared_helpers.rb +143 -27
  114. data/bundler/lib/bundler/similarity_detector.rb +1 -0
  115. data/bundler/lib/bundler/source.rb +53 -1
  116. data/bundler/lib/bundler/source/gemspec.rb +1 -0
  117. data/bundler/lib/bundler/source/git.rb +51 -22
  118. data/bundler/lib/bundler/source/git/git_proxy.rb +23 -13
  119. data/bundler/lib/bundler/source/metadata.rb +63 -0
  120. data/bundler/lib/bundler/source/path.rb +38 -17
  121. data/bundler/lib/bundler/source/path/installer.rb +4 -2
  122. data/bundler/lib/bundler/source/rubygems.rb +161 -82
  123. data/bundler/lib/bundler/source/rubygems/remote.rb +12 -2
  124. data/bundler/lib/bundler/source_list.rb +75 -15
  125. data/bundler/lib/bundler/spec_set.rb +37 -21
  126. data/bundler/lib/bundler/ssl_certs/certificate_manager.rb +2 -1
  127. data/bundler/lib/bundler/stub_specification.rb +86 -2
  128. data/bundler/lib/bundler/templates/.document +1 -0
  129. data/bundler/lib/bundler/templates/Executable +13 -1
  130. data/bundler/lib/bundler/templates/Executable.bundler +105 -0
  131. data/bundler/lib/bundler/templates/Executable.standalone +5 -5
  132. data/bundler/lib/bundler/templates/Gemfile +3 -0
  133. data/bundler/lib/bundler/templates/gems.rb +8 -0
  134. data/bundler/lib/bundler/templates/newgem/Gemfile.tt +4 -2
  135. data/bundler/lib/bundler/templates/newgem/LICENSE.txt.tt +1 -1
  136. data/bundler/lib/bundler/templates/newgem/README.md.tt +14 -8
  137. data/bundler/lib/bundler/templates/newgem/Rakefile.tt +5 -5
  138. data/bundler/lib/bundler/templates/newgem/ext/newgem/newgem.c.tt +4 -4
  139. data/bundler/lib/bundler/templates/newgem/ext/newgem/newgem.h.tt +3 -3
  140. data/bundler/lib/bundler/templates/newgem/gitignore.tt +0 -1
  141. data/bundler/lib/bundler/templates/newgem/lib/newgem.rb.tt +6 -6
  142. data/bundler/lib/bundler/templates/newgem/lib/newgem/version.rb.tt +4 -4
  143. data/bundler/lib/bundler/templates/newgem/newgem.gemspec.tt +21 -12
  144. data/bundler/lib/bundler/templates/newgem/rspec.tt +1 -0
  145. data/bundler/lib/bundler/templates/newgem/spec/newgem_spec.rb.tt +0 -2
  146. data/bundler/lib/bundler/templates/newgem/spec/spec_helper.rb.tt +3 -0
  147. data/bundler/lib/bundler/templates/newgem/test/newgem_test.rb.tt +1 -1
  148. data/bundler/lib/bundler/templates/newgem/test/test_helper.rb.tt +3 -3
  149. data/bundler/lib/bundler/templates/newgem/{.travis.yml.tt → travis.yml.tt} +2 -0
  150. data/bundler/lib/bundler/ui.rb +1 -0
  151. data/bundler/lib/bundler/ui/rg_proxy.rb +1 -0
  152. data/bundler/lib/bundler/ui/shell.rb +26 -10
  153. data/bundler/lib/bundler/ui/silent.rb +12 -1
  154. data/bundler/lib/bundler/uri_credentials_filter.rb +1 -0
  155. data/bundler/lib/bundler/vendor/fileutils/lib/fileutils.rb +1638 -0
  156. data/bundler/lib/bundler/vendor/molinillo/lib/molinillo.rb +2 -0
  157. data/bundler/lib/bundler/vendor/molinillo/lib/molinillo/compatibility.rb +26 -0
  158. data/bundler/lib/bundler/vendor/molinillo/lib/molinillo/delegates/resolution_state.rb +7 -0
  159. data/bundler/lib/bundler/vendor/molinillo/lib/molinillo/delegates/specification_provider.rb +1 -0
  160. data/bundler/lib/bundler/vendor/molinillo/lib/molinillo/dependency_graph.rb +16 -5
  161. data/bundler/lib/bundler/vendor/molinillo/lib/molinillo/dependency_graph/action.rb +1 -0
  162. data/bundler/lib/bundler/vendor/molinillo/lib/molinillo/dependency_graph/add_edge_no_circular.rb +10 -2
  163. data/bundler/lib/bundler/vendor/molinillo/lib/molinillo/dependency_graph/add_vertex.rb +1 -0
  164. data/bundler/lib/bundler/vendor/molinillo/lib/molinillo/dependency_graph/delete_edge.rb +1 -0
  165. data/bundler/lib/bundler/vendor/molinillo/lib/molinillo/dependency_graph/detach_vertex_named.rb +1 -0
  166. data/bundler/lib/bundler/vendor/molinillo/lib/molinillo/dependency_graph/log.rb +1 -0
  167. data/bundler/lib/bundler/vendor/molinillo/lib/molinillo/dependency_graph/set_payload.rb +1 -0
  168. data/bundler/lib/bundler/vendor/molinillo/lib/molinillo/dependency_graph/tag.rb +1 -0
  169. data/bundler/lib/bundler/vendor/molinillo/lib/molinillo/dependency_graph/vertex.rb +16 -5
  170. data/bundler/lib/bundler/vendor/molinillo/lib/molinillo/errors.rb +75 -7
  171. data/bundler/lib/bundler/vendor/molinillo/lib/molinillo/gem_metadata.rb +2 -1
  172. data/bundler/lib/bundler/vendor/molinillo/lib/molinillo/modules/specification_provider.rb +1 -0
  173. data/bundler/lib/bundler/vendor/molinillo/lib/molinillo/modules/ui.rb +3 -1
  174. data/bundler/lib/bundler/vendor/molinillo/lib/molinillo/resolution.rb +501 -138
  175. data/bundler/lib/bundler/vendor/molinillo/lib/molinillo/resolver.rb +1 -0
  176. data/bundler/lib/bundler/vendor/molinillo/lib/molinillo/state.rb +8 -4
  177. data/bundler/lib/bundler/vendor/net-http-persistent/lib/net/http/persistent.rb +3 -1
  178. data/bundler/lib/bundler/vendor/thor/lib/thor.rb +46 -21
  179. data/bundler/lib/bundler/vendor/thor/lib/thor/actions.rb +24 -22
  180. data/bundler/lib/bundler/vendor/thor/lib/thor/actions/create_file.rb +2 -1
  181. data/bundler/lib/bundler/vendor/thor/lib/thor/actions/create_link.rb +2 -1
  182. data/bundler/lib/bundler/vendor/thor/lib/thor/actions/directory.rb +2 -2
  183. data/bundler/lib/bundler/vendor/thor/lib/thor/actions/empty_directory.rb +16 -8
  184. data/bundler/lib/bundler/vendor/thor/lib/thor/actions/file_manipulation.rb +66 -18
  185. data/bundler/lib/bundler/vendor/thor/lib/thor/actions/inject_into_file.rb +17 -15
  186. data/bundler/lib/bundler/vendor/thor/lib/thor/base.rb +55 -32
  187. data/bundler/lib/bundler/vendor/thor/lib/thor/command.rb +13 -11
  188. data/bundler/lib/bundler/vendor/thor/lib/thor/core_ext/hash_with_indifferent_access.rb +21 -1
  189. data/bundler/lib/bundler/vendor/thor/lib/thor/core_ext/io_binary_read.rb +7 -5
  190. data/bundler/lib/bundler/vendor/thor/lib/thor/core_ext/ordered_hash.rb +94 -63
  191. data/bundler/lib/bundler/vendor/thor/lib/thor/error.rb +3 -3
  192. data/bundler/lib/bundler/vendor/thor/lib/thor/group.rb +13 -13
  193. data/bundler/lib/bundler/vendor/thor/lib/thor/invocation.rb +4 -5
  194. data/bundler/lib/bundler/vendor/thor/lib/thor/line_editor/basic.rb +2 -0
  195. data/bundler/lib/bundler/vendor/thor/lib/thor/parser/argument.rb +4 -7
  196. data/bundler/lib/bundler/vendor/thor/lib/thor/parser/arguments.rb +16 -16
  197. data/bundler/lib/bundler/vendor/thor/lib/thor/parser/option.rb +42 -21
  198. data/bundler/lib/bundler/vendor/thor/lib/thor/parser/options.rb +13 -10
  199. data/bundler/lib/bundler/vendor/thor/lib/thor/runner.rb +31 -29
  200. data/bundler/lib/bundler/vendor/thor/lib/thor/shell.rb +1 -1
  201. data/bundler/lib/bundler/vendor/thor/lib/thor/shell/basic.rb +49 -33
  202. data/bundler/lib/bundler/vendor/thor/lib/thor/shell/color.rb +1 -1
  203. data/bundler/lib/bundler/vendor/thor/lib/thor/shell/html.rb +4 -4
  204. data/bundler/lib/bundler/vendor/thor/lib/thor/util.rb +8 -7
  205. data/bundler/lib/bundler/vendor/thor/lib/thor/version.rb +1 -1
  206. data/bundler/lib/bundler/vendored_fileutils.rb +9 -0
  207. data/bundler/lib/bundler/vendored_molinillo.rb +1 -0
  208. data/bundler/lib/bundler/vendored_persistent.rb +35 -0
  209. data/bundler/lib/bundler/vendored_thor.rb +6 -2
  210. data/bundler/lib/bundler/version.rb +19 -2
  211. data/bundler/lib/bundler/version_ranges.rb +76 -0
  212. data/bundler/lib/bundler/vlad.rb +5 -0
  213. data/bundler/lib/bundler/worker.rb +3 -1
  214. data/bundler/lib/bundler/yaml_serializer.rb +3 -3
  215. data/bundler/man/bundle-add.ronn +29 -0
  216. data/bundler/man/bundle-binstubs.ronn +15 -1
  217. data/bundler/man/bundle-check.ronn +26 -0
  218. data/bundler/man/bundle-clean.ronn +18 -0
  219. data/bundler/man/bundle-config.ronn +193 -69
  220. data/bundler/man/bundle-doctor.ronn +33 -0
  221. data/bundler/man/bundle-exec.ronn +10 -3
  222. data/bundler/man/bundle-gem.ronn +3 -2
  223. data/bundler/man/bundle-info.ronn +17 -0
  224. data/bundler/man/bundle-init.ronn +29 -0
  225. data/bundler/man/bundle-inject.ronn +22 -0
  226. data/bundler/man/bundle-install.ronn +44 -35
  227. data/bundler/man/bundle-list.ronn +15 -0
  228. data/bundler/man/bundle-lock.ronn +1 -1
  229. data/bundler/man/bundle-open.ronn +19 -0
  230. data/bundler/man/bundle-outdated.ronn +2 -2
  231. data/bundler/man/bundle-package.ronn +7 -2
  232. data/bundler/man/bundle-pristine.ronn +34 -0
  233. data/bundler/man/bundle-show.ronn +21 -0
  234. data/bundler/man/bundle-update.ronn +24 -17
  235. data/bundler/man/bundle-viz.ronn +30 -0
  236. data/bundler/man/bundle.ronn +36 -45
  237. data/bundler/man/gemfile.5.ronn +77 -71
  238. data/lib/rubygems.rb +102 -46
  239. data/lib/rubygems/basic_specification.rb +8 -4
  240. data/lib/rubygems/bundler_version_finder.rb +99 -0
  241. data/lib/rubygems/command.rb +10 -2
  242. data/lib/rubygems/command_manager.rb +8 -4
  243. data/lib/rubygems/commands/cert_command.rb +31 -6
  244. data/lib/rubygems/commands/cleanup_command.rb +10 -3
  245. data/lib/rubygems/commands/generate_index_command.rb +1 -1
  246. data/lib/rubygems/commands/help_command.rb +1 -1
  247. data/lib/rubygems/commands/install_command.rb +7 -0
  248. data/lib/rubygems/commands/open_command.rb +1 -1
  249. data/lib/rubygems/commands/owner_command.rb +7 -2
  250. data/lib/rubygems/commands/pristine_command.rb +11 -8
  251. data/lib/rubygems/commands/push_command.rb +39 -5
  252. data/lib/rubygems/commands/query_command.rb +17 -17
  253. data/lib/rubygems/commands/setup_command.rb +174 -69
  254. data/lib/rubygems/commands/signin_command.rb +33 -0
  255. data/lib/rubygems/commands/signout_command.rb +33 -0
  256. data/lib/rubygems/commands/sources_command.rb +1 -1
  257. data/lib/rubygems/commands/uninstall_command.rb +5 -4
  258. data/lib/rubygems/commands/unpack_command.rb +19 -7
  259. data/lib/rubygems/commands/update_command.rb +1 -1
  260. data/lib/rubygems/commands/which_command.rb +1 -1
  261. data/lib/rubygems/commands/yank_command.rb +4 -11
  262. data/lib/rubygems/config_file.rb +15 -26
  263. data/lib/rubygems/core_ext/kernel_require.rb +12 -16
  264. data/lib/rubygems/dependency.rb +3 -0
  265. data/lib/rubygems/dependency_installer.rb +8 -2
  266. data/lib/rubygems/dependency_list.rb +1 -1
  267. data/lib/rubygems/errors.rb +3 -0
  268. data/lib/rubygems/exceptions.rb +11 -1
  269. data/lib/rubygems/ext/builder.rb +2 -2
  270. data/lib/rubygems/ext/ext_conf_builder.rb +2 -4
  271. data/lib/rubygems/ext/rake_builder.rb +1 -1
  272. data/lib/rubygems/gem_runner.rb +5 -1
  273. data/lib/rubygems/gemcutter_utilities.rb +5 -2
  274. data/lib/rubygems/indexer.rb +6 -5
  275. data/lib/rubygems/install_update_options.rb +6 -29
  276. data/lib/rubygems/installer.rb +60 -13
  277. data/lib/rubygems/installer_test_case.rb +6 -3
  278. data/lib/rubygems/package.rb +55 -8
  279. data/lib/rubygems/package/file_source.rb +2 -2
  280. data/lib/rubygems/package/old.rb +3 -3
  281. data/lib/rubygems/package/tar_header.rb +17 -10
  282. data/lib/rubygems/package/tar_writer.rb +4 -3
  283. data/lib/rubygems/platform.rb +1 -1
  284. data/lib/rubygems/remote_fetcher.rb +2 -2
  285. data/lib/rubygems/request.rb +1 -1
  286. data/lib/rubygems/request_set.rb +47 -19
  287. data/lib/rubygems/request_set/gem_dependency_api.rb +3 -3
  288. data/lib/rubygems/request_set/lockfile.rb +1 -1
  289. data/lib/rubygems/requirement.rb +19 -4
  290. data/lib/rubygems/resolver.rb +24 -3
  291. data/lib/rubygems/resolver/api_specification.rb +5 -0
  292. data/lib/rubygems/resolver/installer_set.rb +4 -6
  293. data/lib/rubygems/safe_yaml.rb +51 -0
  294. data/lib/rubygems/security.rb +18 -6
  295. data/lib/rubygems/security/trust_dir.rb +1 -1
  296. data/lib/rubygems/security_option.rb +43 -0
  297. data/lib/rubygems/server.rb +21 -17
  298. data/lib/rubygems/source.rb +9 -6
  299. data/lib/rubygems/source/git.rb +2 -1
  300. data/lib/rubygems/source/local.rb +38 -35
  301. data/lib/rubygems/source/lock.rb +4 -1
  302. data/lib/rubygems/source_local.rb +3 -1
  303. data/lib/rubygems/source_specific_file.rb +3 -2
  304. data/lib/rubygems/spec_fetcher.rb +7 -3
  305. data/lib/rubygems/specification.rb +315 -249
  306. data/lib/rubygems/ssl_certs/{index.rubygems.org → rubygems.org}/GlobalSignRootCA.pem +0 -0
  307. data/lib/rubygems/ssl_certs/rubygems.org/GlobalSignRootCA_R3.pem +21 -0
  308. data/lib/rubygems/stub_specification.rb +4 -3
  309. data/lib/rubygems/test_case.rb +51 -11
  310. data/lib/rubygems/test_utilities.rb +2 -2
  311. data/lib/rubygems/text.rb +14 -1
  312. data/lib/rubygems/user_interaction.rb +24 -15
  313. data/lib/rubygems/util.rb +6 -16
  314. data/lib/rubygems/util/licenses.rb +72 -4
  315. data/lib/rubygems/validator.rb +3 -3
  316. data/lib/rubygems/version.rb +24 -4
  317. data/lib/rubygems/version_option.rb +6 -1
  318. data/lib/ubygems.rb +3 -0
  319. data/setup.rb +1 -1
  320. data/test/rubygems/private3072_key.pem +40 -0
  321. data/test/rubygems/public3072_cert.pem +25 -0
  322. data/test/rubygems/test_bundled_ca.rb +7 -4
  323. data/test/rubygems/test_config.rb +1 -1
  324. data/test/rubygems/test_gem.rb +158 -39
  325. data/test/rubygems/test_gem_bundler_version_finder.rb +126 -0
  326. data/test/rubygems/test_gem_command.rb +7 -1
  327. data/test/rubygems/test_gem_command_manager.rb +2 -2
  328. data/test/rubygems/test_gem_commands_build_command.rb +29 -1
  329. data/test/rubygems/test_gem_commands_cert_command.rb +64 -0
  330. data/test/rubygems/test_gem_commands_cleanup_command.rb +44 -1
  331. data/test/rubygems/test_gem_commands_install_command.rb +73 -2
  332. data/test/rubygems/test_gem_commands_open_command.rb +2 -1
  333. data/test/rubygems/test_gem_commands_owner_command.rb +25 -0
  334. data/test/rubygems/test_gem_commands_pristine_command.rb +1 -1
  335. data/test/rubygems/test_gem_commands_push_command.rb +25 -5
  336. data/test/rubygems/test_gem_commands_query_command.rb +154 -1
  337. data/test/rubygems/test_gem_commands_setup_command.rb +140 -10
  338. data/test/rubygems/test_gem_commands_signin_command.rb +98 -0
  339. data/test/rubygems/test_gem_commands_signout_command.rb +37 -0
  340. data/test/rubygems/test_gem_commands_sources_command.rb +52 -0
  341. data/test/rubygems/test_gem_commands_uninstall_command.rb +15 -3
  342. data/test/rubygems/test_gem_commands_update_command.rb +1 -7
  343. data/test/rubygems/test_gem_commands_which_command.rb +3 -3
  344. data/test/rubygems/test_gem_dependency.rb +28 -0
  345. data/test/rubygems/test_gem_dependency_installer.rb +1 -1
  346. data/test/rubygems/test_gem_doctor.rb +2 -2
  347. data/test/rubygems/test_gem_ext_builder.rb +8 -8
  348. data/test/rubygems/test_gem_ext_configure_builder.rb +1 -1
  349. data/test/rubygems/test_gem_ext_rake_builder.rb +2 -6
  350. data/test/rubygems/test_gem_gemcutter_utilities.rb +4 -4
  351. data/test/rubygems/test_gem_indexer.rb +1 -2
  352. data/test/rubygems/test_gem_install_update_options.rb +6 -1
  353. data/test/rubygems/test_gem_installer.rb +168 -31
  354. data/test/rubygems/test_gem_package.rb +183 -26
  355. data/test/rubygems/test_gem_package_old.rb +1 -1
  356. data/test/rubygems/test_gem_package_tar_header.rb +21 -0
  357. data/test/rubygems/test_gem_rdoc.rb +2 -0
  358. data/test/rubygems/test_gem_remote_fetcher.rb +24 -5
  359. data/test/rubygems/test_gem_request.rb +5 -2
  360. data/test/rubygems/test_gem_request_connection_pools.rb +6 -7
  361. data/test/rubygems/test_gem_request_set.rb +7 -7
  362. data/test/rubygems/test_gem_request_set_gem_dependency_api.rb +3 -3
  363. data/test/rubygems/test_gem_request_set_lockfile.rb +4 -4
  364. data/test/rubygems/test_gem_request_set_lockfile_parser.rb +1 -1
  365. data/test/rubygems/test_gem_request_set_lockfile_tokenizer.rb +1 -1
  366. data/test/rubygems/test_gem_requirement.rb +12 -0
  367. data/test/rubygems/test_gem_resolver.rb +26 -0
  368. data/test/rubygems/test_gem_resolver_api_specification.rb +24 -0
  369. data/test/rubygems/test_gem_resolver_conflict.rb +1 -1
  370. data/test/rubygems/test_gem_resolver_git_specification.rb +1 -1
  371. data/test/rubygems/test_gem_resolver_installer_set.rb +1 -1
  372. data/test/rubygems/test_gem_security.rb +5 -0
  373. data/test/rubygems/test_gem_security_policy.rb +27 -27
  374. data/test/rubygems/test_gem_security_signer.rb +6 -6
  375. data/test/rubygems/test_gem_security_trust_dir.rb +2 -2
  376. data/test/rubygems/test_gem_server.rb +194 -12
  377. data/test/rubygems/test_gem_source.rb +12 -3
  378. data/test/rubygems/test_gem_source_git.rb +1 -1
  379. data/test/rubygems/test_gem_spec_fetcher.rb +20 -0
  380. data/test/rubygems/test_gem_specification.rb +180 -42
  381. data/test/rubygems/test_gem_stream_ui.rb +8 -8
  382. data/test/rubygems/test_gem_stub_specification.rb +26 -8
  383. data/test/rubygems/test_gem_text.rb +16 -0
  384. data/test/rubygems/test_gem_util.rb +26 -0
  385. data/test/rubygems/test_gem_version.rb +68 -9
  386. data/test/rubygems/test_gem_version_option.rb +15 -0
  387. data/test/rubygems/test_kernel.rb +30 -0
  388. data/test/rubygems/test_require.rb +70 -21
  389. data/util/ci +1 -0
  390. data/util/generate_spdx_license_list.rb +16 -6
  391. data/util/update_bundled_ca_certificates.rb +1 -3
  392. metadata +61 -57
  393. data/README.rdoc +0 -54
  394. data/bundler/DEVELOPMENT.md +0 -150
  395. data/bundler/ISSUES.md +0 -117
  396. data/bundler/lib/bundler/postit_trampoline.rb +0 -73
  397. data/bundler/lib/bundler/vendor/postit/lib/postit.rb +0 -15
  398. data/bundler/lib/bundler/vendor/postit/lib/postit/environment.rb +0 -44
  399. data/bundler/lib/bundler/vendor/postit/lib/postit/installer.rb +0 -28
  400. data/bundler/lib/bundler/vendor/postit/lib/postit/parser.rb +0 -21
  401. data/bundler/lib/bundler/vendor/postit/lib/postit/setup.rb +0 -12
  402. data/bundler/lib/bundler/vendor/postit/lib/postit/version.rb +0 -3
  403. data/bundler/man/index.txt +0 -8
  404. data/lib/rubygems/ssl_certs/rubygems.global.ssl.fastly.net/DigiCertHighAssuranceEVRootCA.pem +0 -23
  405. data/lib/rubygems/ssl_certs/rubygems.org/AddTrustExternalCARoot.pem +0 -25
@@ -1,4 +1,5 @@
1
1
  # frozen_string_literal: true
2
+
2
3
  module Bundler
3
4
  class DepProxy
4
5
  attr_reader :__platform, :dep
@@ -9,10 +10,11 @@ module Bundler
9
10
  end
10
11
 
11
12
  def hash
12
- @hash ||= dep.hash
13
+ @hash ||= [dep, __platform].hash
13
14
  end
14
15
 
15
16
  def ==(other)
17
+ return false if other.class != self.class
16
18
  dep == other.dep && __platform == other.__platform
17
19
  end
18
20
 
@@ -1,4 +1,5 @@
1
1
  # frozen_string_literal: true
2
+
2
3
  require "rubygems/dependency"
3
4
  require "bundler/shared_helpers"
4
5
  require "bundler/rubygems_ext"
@@ -29,6 +30,7 @@ module Bundler
29
30
  :mri_24 => Gem::Platform::RUBY,
30
31
  :mri_25 => Gem::Platform::RUBY,
31
32
  :rbx => Gem::Platform::RUBY,
33
+ :truffleruby => Gem::Platform::RUBY,
32
34
  :jruby => Gem::Platform::JAVA,
33
35
  :jruby_18 => Gem::Platform::JAVA,
34
36
  :jruby_19 => Gem::Platform::JAVA,
@@ -90,16 +92,14 @@ module Bundler
90
92
  @autorequire = Array(options["require"] || []) if options.key?("require")
91
93
  end
92
94
 
95
+ # Returns the platforms this dependency is valid for, in the same order as
96
+ # passed in the `valid_platforms` parameter
93
97
  def gem_platforms(valid_platforms)
94
98
  return valid_platforms if @platforms.empty?
95
99
 
96
- platforms = []
97
- @platforms.each do |p|
98
- platform = PLATFORM_MAP[p]
99
- next unless valid_platforms.include?(platform)
100
- platforms |= [platform]
101
- end
102
- platforms
100
+ @gem_platforms ||= @platforms.map {|pl| PLATFORM_MAP[pl] }.compact.uniq
101
+
102
+ valid_platforms & @gem_platforms
103
103
  end
104
104
 
105
105
  def should_include?
@@ -1,7 +1,7 @@
1
1
  # frozen_string_literal: true
2
2
 
3
3
  require "bundler/shared_helpers"
4
- Bundler::SharedHelpers.major_deprecation "Bundler no longer integrates with " \
4
+ Bundler::SharedHelpers.major_deprecation 2, "Bundler no longer integrates with " \
5
5
  "Capistrano, but Capistrano provides its own integration with " \
6
6
  "Bundler via the capistrano-bundler gem. Use it instead."
7
7
 
@@ -1,11 +1,23 @@
1
1
  # frozen_string_literal: true
2
+
3
+ begin
4
+ require "rubygems/deprecate"
5
+ rescue LoadError
6
+ # it's fine if it doesn't exist on the current RubyGems...
7
+ nil
8
+ end
9
+
2
10
  module Bundler
3
- if defined? ::Deprecate
11
+ # If Bundler::Deprecate is an autoload constant, we need to define it
12
+ if defined?(Bundler::Deprecate) && !autoload?(:Deprecate)
13
+ # nothing to do!
14
+ elsif defined? ::Deprecate
4
15
  Deprecate = ::Deprecate
5
16
  elsif defined? Gem::Deprecate
6
17
  Deprecate = Gem::Deprecate
7
18
  else
8
- class Deprecate; end
19
+ class Deprecate
20
+ end
9
21
  end
10
22
 
11
23
  unless Deprecate.respond_to?(:skip_during)
@@ -20,7 +32,7 @@ module Bundler
20
32
 
21
33
  unless Deprecate.respond_to?(:skip)
22
34
  def Deprecate.skip
23
- @skip
35
+ @skip ||= false
24
36
  end
25
37
  end
26
38
 
@@ -1,4 +1,5 @@
1
1
  # frozen_string_literal: true
2
+
2
3
  require "bundler/dependency"
3
4
  require "bundler/ruby_dsl"
4
5
 
@@ -14,6 +15,9 @@ module Bundler
14
15
 
15
16
  VALID_PLATFORMS = Bundler::Dependency::PLATFORM_MAP.keys.freeze
16
17
 
18
+ VALID_KEYS = %w[group groups git path glob name branch ref tag require submodules
19
+ platform platforms type source install_if].freeze
20
+
17
21
  attr_reader :gemspecs
18
22
  attr_accessor :dependencies
19
23
 
@@ -30,14 +34,16 @@ module Bundler
30
34
  @ruby_version = nil
31
35
  @gemspecs = []
32
36
  @gemfile = nil
37
+ @gemfiles = []
33
38
  add_git_sources
34
39
  end
35
40
 
36
41
  def eval_gemfile(gemfile, contents = nil)
37
- expanded_gemfile_path = Pathname.new(gemfile).expand_path
42
+ expanded_gemfile_path = Pathname.new(gemfile).expand_path(@gemfile && @gemfile.parent)
38
43
  original_gemfile = @gemfile
39
44
  @gemfile = expanded_gemfile_path
40
- contents ||= Bundler.read_file(gemfile.to_s)
45
+ @gemfiles << expanded_gemfile_path
46
+ contents ||= Bundler.read_file(@gemfile.to_s)
41
47
  instance_eval(contents.dup.untaint, gemfile.to_s, 1)
42
48
  rescue Exception => e
43
49
  message = "There was an error " \
@@ -95,10 +101,10 @@ module Bundler
95
101
 
96
102
  # if there's already a dependency with this name we try to prefer one
97
103
  if current = @dependencies.find {|d| d.name == dep.name }
104
+ deleted_dep = @dependencies.delete(current) if current.type == :development
105
+
98
106
  if current.requirement != dep.requirement
99
- if current.type == :development
100
- @dependencies.delete current
101
- else
107
+ unless deleted_dep
102
108
  return if dep.type == :development
103
109
  raise GemfileError, "You cannot specify the same gem twice with different version requirements.\n" \
104
110
  "You specified: #{current.name} (#{current.requirement}) and #{dep.name} (#{dep.requirement})"
@@ -111,9 +117,7 @@ module Bundler
111
117
  end
112
118
 
113
119
  if current.source != dep.source
114
- if current.type == :development
115
- @dependencies.delete current
116
- else
120
+ unless deleted_dep
117
121
  return if dep.type == :development
118
122
  raise GemfileError, "You cannot specify the same gem twice coming from different sources.\n" \
119
123
  "You specified that #{dep.name} (#{dep.requirement}) should come from " \
@@ -128,10 +132,12 @@ module Bundler
128
132
  def source(source, *args, &blk)
129
133
  options = args.last.is_a?(Hash) ? args.pop.dup : {}
130
134
  options = normalize_hash(options)
135
+ source = normalize_source(source)
136
+
131
137
  if options.key?("type")
132
138
  options["type"] = options["type"].to_s
133
139
  unless Plugin.source?(options["type"])
134
- raise "No sources available for #{options["type"]}"
140
+ raise InvalidOption, "No plugin sources available for #{options["type"]}"
135
141
  end
136
142
 
137
143
  unless block_given?
@@ -141,12 +147,10 @@ module Bundler
141
147
  source_opts = options.merge("uri" => source)
142
148
  with_source(@sources.add_plugin_source(options["type"], source_opts), &blk)
143
149
  elsif block_given?
144
- source = normalize_source(source)
145
150
  with_source(@sources.add_rubygems_source("remotes" => source), &blk)
146
151
  else
147
- source = normalize_source(source)
148
152
  check_primary_source_safety(@sources)
149
- @sources.add_rubygems_remote(source)
153
+ @sources.global_rubygems_source = source
150
154
  end
151
155
  end
152
156
 
@@ -164,6 +168,19 @@ module Bundler
164
168
  end
165
169
 
166
170
  def path(path, options = {}, &blk)
171
+ unless block_given?
172
+ msg = "You can no longer specify a path source by itself. Instead, \n" \
173
+ "either use the :path option on a gem, or specify the gems that \n" \
174
+ "bundler should find in the path source by passing a block to \n" \
175
+ "the path method, like: \n\n" \
176
+ " path 'dir/containing/rails' do\n" \
177
+ " gem 'rails'\n" \
178
+ " end\n\n"
179
+
180
+ raise DeprecatedError, msg if Bundler.feature_flag.disable_multisource?
181
+ SharedHelpers.major_deprecation(2, msg.strip)
182
+ end
183
+
167
184
  source_options = normalize_hash(options).merge(
168
185
  "path" => Pathname.new(path),
169
186
  "root_path" => gemfile_root,
@@ -189,7 +206,8 @@ module Bundler
189
206
  end
190
207
 
191
208
  def github(repo, options = {})
192
- raise ArgumentError, "Github sources require a block" unless block_given?
209
+ raise ArgumentError, "GitHub sources require a block" unless block_given?
210
+ raise DeprecatedError, "The #github method has been removed" if Bundler.feature_flag.skip_default_git_sources?
193
211
  github_uri = @git_sources["github"].call(repo)
194
212
  git_options = normalize_hash(options).merge("uri" => github_uri)
195
213
  git_source = @sources.add_git_source(git_options)
@@ -197,16 +215,16 @@ module Bundler
197
215
  end
198
216
 
199
217
  def to_definition(lockfile, unlock)
200
- Definition.new(lockfile, @dependencies, @sources, unlock, @ruby_version, @optional_groups)
218
+ Definition.new(lockfile, @dependencies, @sources, unlock, @ruby_version, @optional_groups, @gemfiles)
201
219
  end
202
220
 
203
221
  def group(*args, &blk)
204
- opts = Hash === args.last ? args.pop.dup : {}
205
- normalize_group_options(opts, args)
222
+ options = args.last.is_a?(Hash) ? args.pop.dup : {}
223
+ normalize_group_options(options, args)
206
224
 
207
225
  @groups.concat args
208
226
 
209
- if opts["optional"]
227
+ if options["optional"]
210
228
  optional_groups = args - @optional_groups
211
229
  @optional_groups.concat optional_groups
212
230
  end
@@ -216,9 +234,9 @@ module Bundler
216
234
  args.each { @groups.pop }
217
235
  end
218
236
 
219
- def install_if(*args, &blk)
237
+ def install_if(*args)
220
238
  @install_conditionals.concat args
221
- blk.call
239
+ yield
222
240
  ensure
223
241
  args.each { @install_conditionals.pop }
224
242
  end
@@ -250,7 +268,12 @@ module Bundler
250
268
  private
251
269
 
252
270
  def add_git_sources
271
+ return if Bundler.feature_flag.skip_default_git_sources?
272
+
253
273
  git_source(:github) do |repo_name|
274
+ warn_deprecated_git_source(:github, <<-'RUBY'.strip, 'Change any "reponame" :github sources to "username/reponame".')
275
+ "https://github.com/#{repo_name}.git"
276
+ RUBY
254
277
  # It would be better to use https instead of the git protocol, but this
255
278
  # can break deployment of existing locked bundles when switching between
256
279
  # different versions of Bundler. The change will be made in 2.0, which
@@ -267,23 +290,29 @@ module Bundler
267
290
  repo_name = "#{repo_name}/#{repo_name}" unless repo_name.include?("/")
268
291
  # TODO: 2.0 upgrade this setting to the default
269
292
  if Bundler.settings["github.https"]
293
+ Bundler::SharedHelpers.major_deprecation 2, "The `github.https` setting will be removed"
270
294
  "https://github.com/#{repo_name}.git"
271
295
  else
272
- warn_github_source_change(repo_name)
273
296
  "git://github.com/#{repo_name}.git"
274
297
  end
275
298
  end
276
299
 
277
300
  # TODO: 2.0 remove this deprecated git source
278
301
  git_source(:gist) do |repo_name|
279
- warn_deprecated_git_source(:gist, 'https://gist.github.com/#{repo_name}.git')
302
+ warn_deprecated_git_source(:gist, '"https://gist.github.com/#{repo_name}.git"')
303
+
280
304
  "https://gist.github.com/#{repo_name}.git"
281
305
  end
282
306
 
283
307
  # TODO: 2.0 remove this deprecated git source
284
308
  git_source(:bitbucket) do |repo_name|
285
- user_name, repo_name = repo_name.split "/"
286
- warn_deprecated_git_source(:bitbucket, 'https://#{user_name}@bitbucket.org/#{user_name}/#{repo_name}.git')
309
+ warn_deprecated_git_source(:bitbucket, <<-'RUBY'.strip)
310
+ user_name, repo_name = repo_name.split("/")
311
+ repo_name ||= user_name
312
+ "https://#{user_name}@bitbucket.org/#{user_name}/#{repo_name}.git"
313
+ RUBY
314
+
315
+ user_name, repo_name = repo_name.split("/")
287
316
  repo_name ||= user_name
288
317
  "https://#{user_name}@bitbucket.org/#{user_name}/#{repo_name}.git"
289
318
  end
@@ -308,7 +337,7 @@ module Bundler
308
337
  end
309
338
 
310
339
  def valid_keys
311
- @valid_keys ||= %w(group groups git path glob name branch ref tag require submodules platform platforms type source install_if)
340
+ @valid_keys ||= VALID_KEYS
312
341
  end
313
342
 
314
343
  def normalize_options(name, version, opts)
@@ -318,6 +347,9 @@ module Bundler
318
347
  if name =~ /\s/
319
348
  raise GemfileError, %('#{name}' is not a valid gem name because it contains whitespace)
320
349
  end
350
+ if name.empty?
351
+ raise GemfileError, %(an empty gem name is not valid)
352
+ end
321
353
 
322
354
  normalize_hash(opts)
323
355
 
@@ -355,7 +387,7 @@ module Bundler
355
387
  opts["git"] = @git_sources[git_name].call(opts[git_name])
356
388
  end
357
389
 
358
- %w(git path).each do |type|
390
+ %w[git path].each do |type|
359
391
  next unless param = opts[type]
360
392
  if version.first && version.first =~ /^\s*=?\s*(\d[^\s]*)\s*$/
361
393
  options = opts.merge("name" => name, "version" => $1)
@@ -366,8 +398,8 @@ module Bundler
366
398
  opts["source"] = source
367
399
  end
368
400
 
369
- opts["source"] ||= @source
370
- opts["env"] ||= @env
401
+ opts["source"] ||= @source
402
+ opts["env"] ||= @env
371
403
  opts["platforms"] = platforms.dup
372
404
  opts["group"] = groups
373
405
  opts["should_include"] = install_if
@@ -377,32 +409,38 @@ module Bundler
377
409
  normalize_hash(opts)
378
410
 
379
411
  groups = groups.map {|group| ":#{group}" }.join(", ")
380
- validate_keys("group #{groups}", opts, %w(optional))
412
+ validate_keys("group #{groups}", opts, %w[optional])
381
413
 
382
414
  opts["optional"] ||= false
383
415
  end
384
416
 
385
417
  def validate_keys(command, opts, valid_keys)
386
418
  invalid_keys = opts.keys - valid_keys
387
- if invalid_keys.any?
388
- message = String.new
389
- message << "You passed #{invalid_keys.map {|k| ":" + k }.join(", ")} "
390
- message << if invalid_keys.size > 1
391
- "as options for #{command}, but they are invalid."
392
- else
393
- "as an option for #{command}, but it is invalid."
394
- end
395
-
396
- message << " Valid options are: #{valid_keys.join(", ")}."
397
- message << " You may be able to resolve this by upgrading Bundler to the newest version."
398
- raise InvalidOption, message
419
+
420
+ git_source = opts.keys & @git_sources.keys.map(&:to_s)
421
+ if opts["branch"] && !(opts["git"] || opts["github"] || git_source.any?)
422
+ raise GemfileError, %(The `branch` option for `#{command}` is not allowed. Only gems with a git source can specify a branch)
399
423
  end
424
+
425
+ return true unless invalid_keys.any?
426
+
427
+ message = String.new
428
+ message << "You passed #{invalid_keys.map {|k| ":" + k }.join(", ")} "
429
+ message << if invalid_keys.size > 1
430
+ "as options for #{command}, but they are invalid."
431
+ else
432
+ "as an option for #{command}, but it is invalid."
433
+ end
434
+
435
+ message << " Valid options are: #{valid_keys.join(", ")}."
436
+ message << " You may be able to resolve this by upgrading Bundler to the newest version."
437
+ raise InvalidOption, message
400
438
  end
401
439
 
402
440
  def normalize_source(source)
403
441
  case source
404
442
  when :gemcutter, :rubygems, :rubyforge
405
- Bundler::SharedHelpers.major_deprecation "The source :#{source} is deprecated because HTTP " \
443
+ Bundler::SharedHelpers.major_deprecation 2, "The source :#{source} is deprecated because HTTP " \
406
444
  "requests are insecure.\nPlease change your source to 'https://" \
407
445
  "rubygems.org' if possible, or 'http://rubygems.org' if not."
408
446
  "http://rubygems.org"
@@ -413,17 +451,20 @@ module Bundler
413
451
  end
414
452
  end
415
453
 
416
- def check_primary_source_safety(source)
417
- return unless source.rubygems_primary_remotes.any?
454
+ def check_primary_source_safety(source_list)
455
+ return if source_list.rubygems_primary_remotes.empty? && source_list.global_rubygems_source.nil?
418
456
 
419
- # TODO: 2.0 upgrade from setting to default
420
- if Bundler.settings[:disable_multisource]
421
- raise GemfileError, "Warning: this Gemfile contains multiple primary sources. " \
457
+ if Bundler.feature_flag.disable_multisource?
458
+ msg = "This Gemfile contains multiple primary sources. " \
422
459
  "Each source after the first must include a block to indicate which gems " \
423
- "should come from that source. To downgrade this error to a warning, run " \
424
- "`bundle config --delete disable_multisource`"
460
+ "should come from that source"
461
+ unless Bundler.feature_flag.bundler_2_mode?
462
+ msg += ". To downgrade this error to a warning, run " \
463
+ "`bundle config --delete disable_multisource`"
464
+ end
465
+ raise GemfileEvalError, msg
425
466
  else
426
- Bundler::SharedHelpers.major_deprecation "Your Gemfile contains multiple primary sources. " \
467
+ Bundler::SharedHelpers.major_deprecation 2, "Your Gemfile contains multiple primary sources. " \
427
468
  "Using `source` more than once without a block is a security risk, and " \
428
469
  "may result in installing unexpected gems. To resolve this warning, use " \
429
470
  "a block to indicate which gems should come from the secondary source. " \
@@ -432,20 +473,20 @@ module Bundler
432
473
  end
433
474
  end
434
475
 
435
- def warn_github_source_change(repo_name)
476
+ def warn_deprecated_git_source(name, replacement, additional_message = nil)
436
477
  # TODO: 2.0 remove deprecation
437
- Bundler::SharedHelpers.major_deprecation "The :github option uses the git: protocol, which is not secure. " \
438
- "Bundler 2.0 will use the https: protocol, which is secure. Enable this change now by " \
439
- "running `bundle config github.https true`."
440
- end
478
+ additional_message &&= " #{additional_message}"
479
+ replacement = if replacement.count("\n").zero?
480
+ "{|repo_name| #{replacement} }"
481
+ else
482
+ "do |repo_name|\n#{replacement.to_s.gsub(/^/, " ")}\n end"
483
+ end
484
+
485
+ Bundler::SharedHelpers.major_deprecation 2, <<-EOS
486
+ The :#{name} git source is deprecated, and will be removed in Bundler 2.0.#{additional_message} Add this code to the top of your Gemfile to ensure it continues to work:
487
+
488
+ git_source(:#{name}) #{replacement}
441
489
 
442
- def warn_deprecated_git_source(name, repo_string)
443
- # TODO: 2.0 remove deprecation
444
- Bundler::SharedHelpers.major_deprecation <<-EOS
445
- The :#{name} git source is deprecated, and will be removed in Bundler 2.0. Add this code to your Gemfile to ensure it continues to work:
446
- git_source(:#{name}) do |repo_name|
447
- "#{repo_string}"
448
- end
449
490
  EOS
450
491
  end
451
492
 
@@ -524,7 +565,7 @@ The :#{name} git source is deprecated, and will be removed in Bundler 2.0. Add t
524
565
  lines = contents.lines.to_a
525
566
  indent = " # "
526
567
  indicator = indent.tr("#", ">")
527
- first_line = (line_numer.zero?)
568
+ first_line = line_numer.zero?
528
569
  last_line = (line_numer == (lines.count - 1))
529
570
 
530
571
  m << "\n"