rubygems-update 3.2.0.rc.1 → 3.2.3

Sign up to get free protection for your applications and to get access to all the features.
Files changed (497) hide show
  1. checksums.yaml +4 -4
  2. data/CONTRIBUTING.md +23 -8
  3. data/History.txt +307 -239
  4. data/Manifest.txt +36 -54
  5. data/POLICIES.md +4 -3
  6. data/Rakefile +29 -51
  7. data/bundler/CHANGELOG.md +786 -690
  8. data/bundler/UPGRADING.md +3 -3
  9. data/bundler/lib/bundler.rb +17 -3
  10. data/bundler/lib/bundler/build_metadata.rb +4 -12
  11. data/bundler/lib/bundler/cli.rb +31 -15
  12. data/bundler/lib/bundler/cli/add.rb +1 -1
  13. data/bundler/lib/bundler/cli/binstubs.rb +6 -2
  14. data/bundler/lib/bundler/cli/cache.rb +1 -7
  15. data/bundler/lib/bundler/cli/clean.rb +1 -1
  16. data/bundler/lib/bundler/cli/common.rb +14 -0
  17. data/bundler/lib/bundler/cli/doctor.rb +1 -1
  18. data/bundler/lib/bundler/cli/exec.rb +4 -4
  19. data/bundler/lib/bundler/cli/fund.rb +36 -0
  20. data/bundler/lib/bundler/cli/gem.rb +1 -1
  21. data/bundler/lib/bundler/cli/info.rb +2 -1
  22. data/bundler/lib/bundler/cli/init.rb +1 -1
  23. data/bundler/lib/bundler/cli/inject.rb +1 -1
  24. data/bundler/lib/bundler/cli/install.rb +18 -7
  25. data/bundler/lib/bundler/cli/list.rb +1 -1
  26. data/bundler/lib/bundler/cli/outdated.rb +1 -3
  27. data/bundler/lib/bundler/cli/pristine.rb +1 -1
  28. data/bundler/lib/bundler/cli/show.rb +1 -1
  29. data/bundler/lib/bundler/cli/update.rb +3 -1
  30. data/bundler/lib/bundler/compact_index_client.rb +1 -1
  31. data/bundler/lib/bundler/compact_index_client/cache.rb +6 -14
  32. data/bundler/lib/bundler/compact_index_client/gem_parser.rb +28 -0
  33. data/bundler/lib/bundler/compact_index_client/updater.rb +5 -5
  34. data/bundler/lib/bundler/definition.rb +49 -60
  35. data/bundler/lib/bundler/dep_proxy.rb +1 -1
  36. data/bundler/lib/bundler/dependency.rb +3 -1
  37. data/bundler/lib/bundler/dsl.rb +4 -4
  38. data/bundler/lib/bundler/endpoint_specification.rb +1 -1
  39. data/bundler/lib/bundler/env.rb +1 -1
  40. data/bundler/lib/bundler/feature_flag.rb +0 -1
  41. data/bundler/lib/bundler/fetcher.rb +3 -3
  42. data/bundler/lib/bundler/fetcher/base.rb +1 -1
  43. data/bundler/lib/bundler/fetcher/compact_index.rb +1 -1
  44. data/bundler/lib/bundler/fetcher/downloader.rb +1 -1
  45. data/bundler/lib/bundler/fetcher/index.rb +3 -4
  46. data/bundler/lib/bundler/friendly_errors.rb +18 -3
  47. data/bundler/lib/bundler/gem_helper.rb +17 -9
  48. data/bundler/lib/bundler/gem_helpers.rb +36 -25
  49. data/bundler/lib/bundler/gem_version_promoter.rb +1 -1
  50. data/bundler/lib/bundler/graph.rb +1 -1
  51. data/bundler/lib/bundler/index.rb +6 -2
  52. data/bundler/lib/bundler/injector.rb +10 -3
  53. data/bundler/lib/bundler/installer.rb +8 -6
  54. data/bundler/lib/bundler/installer/gem_installer.rb +1 -1
  55. data/bundler/lib/bundler/installer/parallel_installer.rb +1 -1
  56. data/bundler/lib/bundler/installer/standalone.rb +2 -2
  57. data/bundler/lib/bundler/lazy_specification.rb +22 -11
  58. data/bundler/lib/bundler/lockfile_generator.rb +1 -1
  59. data/bundler/lib/bundler/lockfile_parser.rb +1 -1
  60. data/bundler/lib/bundler/man/.document +1 -0
  61. data/bundler/{man/bundle-add.ronn → lib/bundler/man/bundle-add.1.ronn} +0 -0
  62. data/bundler/{man/bundle-binstubs.ronn → lib/bundler/man/bundle-binstubs.1.ronn} +2 -4
  63. data/bundler/{man/bundle-cache.ronn → lib/bundler/man/bundle-cache.1.ronn} +0 -0
  64. data/bundler/{man/bundle-check.ronn → lib/bundler/man/bundle-check.1.ronn} +0 -0
  65. data/bundler/{man/bundle-clean.ronn → lib/bundler/man/bundle-clean.1.ronn} +0 -0
  66. data/bundler/{man/bundle-config.ronn → lib/bundler/man/bundle-config.1.ronn} +14 -21
  67. data/bundler/{man/bundle-doctor.ronn → lib/bundler/man/bundle-doctor.1.ronn} +0 -0
  68. data/bundler/{man/bundle-exec.ronn → lib/bundler/man/bundle-exec.1.ronn} +0 -0
  69. data/bundler/{man/bundle-gem.ronn → lib/bundler/man/bundle-gem.1.ronn} +0 -0
  70. data/bundler/{man/bundle-info.ronn → lib/bundler/man/bundle-info.1.ronn} +0 -0
  71. data/bundler/{man/bundle-init.ronn → lib/bundler/man/bundle-init.1.ronn} +0 -0
  72. data/bundler/{man/bundle-inject.ronn → lib/bundler/man/bundle-inject.1.ronn} +0 -0
  73. data/bundler/{man/bundle-install.ronn → lib/bundler/man/bundle-install.1.ronn} +25 -3
  74. data/bundler/{man/bundle-list.ronn → lib/bundler/man/bundle-list.1.ronn} +0 -0
  75. data/bundler/{man/bundle-lock.ronn → lib/bundler/man/bundle-lock.1.ronn} +0 -0
  76. data/bundler/{man/bundle-open.ronn → lib/bundler/man/bundle-open.1.ronn} +0 -0
  77. data/bundler/{man/bundle-outdated.ronn → lib/bundler/man/bundle-outdated.1.ronn} +0 -0
  78. data/bundler/{man/bundle-platform.ronn → lib/bundler/man/bundle-platform.1.ronn} +0 -0
  79. data/bundler/{man/bundle-pristine.ronn → lib/bundler/man/bundle-pristine.1.ronn} +0 -0
  80. data/bundler/{man/bundle-remove.ronn → lib/bundler/man/bundle-remove.1.ronn} +0 -0
  81. data/bundler/{man/bundle-show.ronn → lib/bundler/man/bundle-show.1.ronn} +0 -0
  82. data/bundler/{man/bundle-update.ronn → lib/bundler/man/bundle-update.1.ronn} +0 -0
  83. data/bundler/{man/bundle-viz.ronn → lib/bundler/man/bundle-viz.1.ronn} +0 -0
  84. data/bundler/{man/bundle.ronn → lib/bundler/man/bundle.1.ronn} +0 -0
  85. data/bundler/{man → lib/bundler/man}/gemfile.5.ronn +4 -4
  86. data/bundler/lib/bundler/mirror.rb +2 -2
  87. data/bundler/lib/bundler/plugin.rb +5 -6
  88. data/bundler/lib/bundler/plugin/api/source.rb +1 -1
  89. data/bundler/lib/bundler/plugin/dsl.rb +1 -1
  90. data/bundler/lib/bundler/plugin/index.rb +1 -1
  91. data/bundler/lib/bundler/plugin/installer.rb +1 -1
  92. data/bundler/lib/bundler/plugin/installer/rubygems.rb +1 -1
  93. data/bundler/lib/bundler/plugin/source_list.rb +1 -1
  94. data/bundler/lib/bundler/remote_specification.rb +1 -1
  95. data/bundler/lib/bundler/resolver.rb +26 -30
  96. data/bundler/lib/bundler/resolver/spec_group.rb +21 -27
  97. data/bundler/lib/bundler/retry.rb +1 -1
  98. data/bundler/lib/bundler/ruby_version.rb +1 -1
  99. data/bundler/lib/bundler/rubygems_ext.rb +46 -1
  100. data/bundler/lib/bundler/rubygems_gem_installer.rb +2 -2
  101. data/bundler/lib/bundler/rubygems_integration.rb +22 -12
  102. data/bundler/lib/bundler/runtime.rb +2 -2
  103. data/bundler/lib/bundler/settings.rb +49 -43
  104. data/bundler/lib/bundler/shared_helpers.rb +1 -1
  105. data/bundler/lib/bundler/similarity_detector.rb +1 -1
  106. data/bundler/lib/bundler/source.rb +1 -1
  107. data/bundler/lib/bundler/source/git.rb +1 -1
  108. data/bundler/lib/bundler/source/git/git_proxy.rb +5 -3
  109. data/bundler/lib/bundler/source/path.rb +2 -2
  110. data/bundler/lib/bundler/source/path/installer.rb +1 -1
  111. data/bundler/lib/bundler/source/rubygems.rb +2 -2
  112. data/bundler/lib/bundler/source/rubygems/remote.rb +1 -1
  113. data/bundler/lib/bundler/source_list.rb +2 -2
  114. data/bundler/lib/bundler/spec_set.rb +7 -9
  115. data/bundler/lib/bundler/stub_specification.rb +1 -3
  116. data/bundler/lib/bundler/templates/newgem/README.md.tt +1 -2
  117. data/bundler/lib/bundler/templates/newgem/bin/console.tt +1 -2
  118. data/bundler/lib/bundler/templates/newgem/lib/newgem.rb.tt +2 -2
  119. data/bundler/lib/bundler/templates/newgem/newgem.gemspec.tt +8 -2
  120. data/bundler/lib/bundler/templates/newgem/spec/spec_helper.rb.tt +0 -1
  121. data/bundler/lib/bundler/ui/shell.rb +5 -5
  122. data/bundler/lib/bundler/uri_credentials_filter.rb +3 -1
  123. data/bundler/lib/bundler/vendor/molinillo/lib/molinillo.rb +0 -1
  124. data/bundler/lib/bundler/vendor/molinillo/lib/molinillo/dependency_graph.rb +34 -1
  125. data/bundler/lib/bundler/vendor/molinillo/lib/molinillo/dependency_graph/tag.rb +2 -2
  126. data/bundler/lib/bundler/vendor/molinillo/lib/molinillo/errors.rb +1 -1
  127. data/bundler/lib/bundler/vendor/molinillo/lib/molinillo/gem_metadata.rb +1 -1
  128. data/bundler/lib/bundler/vendor/molinillo/lib/molinillo/resolution.rb +38 -40
  129. data/bundler/lib/bundler/vendor/net-http-persistent/lib/net/http/persistent.rb +8 -1
  130. data/bundler/lib/bundler/vendor/tmpdir/lib/tmpdir.rb +154 -0
  131. data/bundler/lib/bundler/vendored_persistent.rb +0 -7
  132. data/bundler/lib/bundler/vendored_tmpdir.rb +4 -0
  133. data/bundler/lib/bundler/version.rb +1 -1
  134. data/bundler/lib/bundler/worker.rb +1 -1
  135. data/bundler/lib/bundler/yaml_serializer.rb +1 -1
  136. data/bundler/man/bundle-add.1 +1 -1
  137. data/bundler/man/bundle-binstubs.1 +5 -3
  138. data/bundler/man/bundle-cache.1 +1 -1
  139. data/bundler/man/bundle-check.1 +1 -1
  140. data/bundler/man/bundle-clean.1 +1 -1
  141. data/bundler/man/bundle-config.1 +14 -17
  142. data/bundler/man/bundle-doctor.1 +1 -1
  143. data/bundler/man/bundle-exec.1 +1 -1
  144. data/bundler/man/bundle-gem.1 +1 -1
  145. data/bundler/man/bundle-info.1 +1 -1
  146. data/bundler/man/bundle-init.1 +1 -1
  147. data/bundler/man/bundle-inject.1 +1 -1
  148. data/bundler/man/bundle-install.1 +30 -3
  149. data/bundler/man/bundle-list.1 +1 -1
  150. data/bundler/man/bundle-lock.1 +1 -1
  151. data/bundler/man/bundle-open.1 +1 -1
  152. data/bundler/man/bundle-outdated.1 +1 -1
  153. data/bundler/man/bundle-platform.1 +1 -1
  154. data/bundler/man/bundle-pristine.1 +1 -1
  155. data/bundler/man/bundle-remove.1 +1 -1
  156. data/bundler/man/bundle-show.1 +1 -1
  157. data/bundler/man/bundle-update.1 +1 -1
  158. data/bundler/man/bundle-viz.1 +1 -1
  159. data/bundler/man/bundle.1 +1 -1
  160. data/bundler/man/gemfile.5 +4 -4
  161. data/lib/rubygems.rb +8 -7
  162. data/lib/rubygems/available_set.rb +1 -3
  163. data/lib/rubygems/basic_specification.rb +0 -4
  164. data/lib/rubygems/command.rb +0 -2
  165. data/lib/rubygems/command_manager.rb +2 -4
  166. data/lib/rubygems/commands/build_command.rb +40 -20
  167. data/lib/rubygems/commands/cert_command.rb +1 -9
  168. data/lib/rubygems/commands/check_command.rb +0 -2
  169. data/lib/rubygems/commands/cleanup_command.rb +8 -4
  170. data/lib/rubygems/commands/contents_command.rb +0 -2
  171. data/lib/rubygems/commands/dependency_command.rb +0 -2
  172. data/lib/rubygems/commands/environment_command.rb +1 -3
  173. data/lib/rubygems/commands/fetch_command.rb +0 -2
  174. data/lib/rubygems/commands/generate_index_command.rb +0 -2
  175. data/lib/rubygems/commands/help_command.rb +2 -2
  176. data/lib/rubygems/commands/info_command.rb +0 -2
  177. data/lib/rubygems/commands/install_command.rb +0 -2
  178. data/lib/rubygems/commands/list_command.rb +0 -2
  179. data/lib/rubygems/commands/lock_command.rb +0 -2
  180. data/lib/rubygems/commands/mirror_command.rb +0 -2
  181. data/lib/rubygems/commands/open_command.rb +0 -2
  182. data/lib/rubygems/commands/outdated_command.rb +0 -2
  183. data/lib/rubygems/commands/owner_command.rb +9 -4
  184. data/lib/rubygems/commands/pristine_command.rb +1 -3
  185. data/lib/rubygems/commands/push_command.rb +6 -5
  186. data/lib/rubygems/commands/query_command.rb +16 -1
  187. data/lib/rubygems/commands/rdoc_command.rb +0 -2
  188. data/lib/rubygems/commands/search_command.rb +0 -2
  189. data/lib/rubygems/commands/server_command.rb +3 -1
  190. data/lib/rubygems/commands/setup_command.rb +21 -44
  191. data/lib/rubygems/commands/signin_command.rb +0 -2
  192. data/lib/rubygems/commands/signout_command.rb +0 -2
  193. data/lib/rubygems/commands/sources_command.rb +6 -4
  194. data/lib/rubygems/commands/specification_command.rb +6 -2
  195. data/lib/rubygems/commands/stale_command.rb +0 -2
  196. data/lib/rubygems/commands/uninstall_command.rb +0 -2
  197. data/lib/rubygems/commands/unpack_command.rb +0 -2
  198. data/lib/rubygems/commands/update_command.rb +20 -5
  199. data/lib/rubygems/commands/which_command.rb +0 -2
  200. data/lib/rubygems/commands/yank_command.rb +4 -7
  201. data/lib/rubygems/config_file.rb +0 -2
  202. data/lib/rubygems/core_ext/kernel_require.rb +3 -0
  203. data/lib/rubygems/core_ext/kernel_warn.rb +12 -13
  204. data/lib/rubygems/defaults.rb +2 -2
  205. data/lib/rubygems/dependency.rb +1 -3
  206. data/lib/rubygems/dependency_installer.rb +5 -5
  207. data/lib/rubygems/dependency_list.rb +0 -2
  208. data/lib/rubygems/doctor.rb +0 -2
  209. data/lib/rubygems/errors.rb +0 -12
  210. data/lib/rubygems/exceptions.rb +0 -20
  211. data/lib/rubygems/ext/builder.rb +13 -34
  212. data/lib/rubygems/ext/cmake_builder.rb +4 -6
  213. data/lib/rubygems/ext/configure_builder.rb +4 -6
  214. data/lib/rubygems/ext/ext_conf_builder.rb +19 -16
  215. data/lib/rubygems/ext/rake_builder.rb +4 -6
  216. data/lib/rubygems/gem_runner.rb +0 -2
  217. data/lib/rubygems/gemcutter_utilities.rb +101 -20
  218. data/lib/rubygems/indexer.rb +0 -3
  219. data/lib/rubygems/install_update_options.rb +2 -2
  220. data/lib/rubygems/installer.rb +16 -40
  221. data/lib/rubygems/installer_test_case.rb +7 -10
  222. data/lib/rubygems/mock_gem_ui.rb +0 -6
  223. data/lib/rubygems/name_tuple.rb +1 -3
  224. data/lib/rubygems/openssl.rb +7 -0
  225. data/lib/rubygems/package.rb +6 -12
  226. data/lib/rubygems/package/digest_io.rb +0 -2
  227. data/lib/rubygems/package/file_source.rb +0 -2
  228. data/lib/rubygems/package/io_source.rb +0 -2
  229. data/lib/rubygems/package/old.rb +0 -2
  230. data/lib/rubygems/package/tar_header.rb +1 -3
  231. data/lib/rubygems/package/tar_reader.rb +0 -2
  232. data/lib/rubygems/package/tar_reader/entry.rb +0 -2
  233. data/lib/rubygems/package/tar_test_case.rb +1 -3
  234. data/lib/rubygems/package/tar_writer.rb +0 -6
  235. data/lib/rubygems/package_task.rb +0 -2
  236. data/lib/rubygems/path_support.rb +0 -2
  237. data/lib/rubygems/platform.rb +18 -9
  238. data/lib/rubygems/psych_tree.rb +0 -2
  239. data/lib/rubygems/query_utils.rb +0 -9
  240. data/lib/rubygems/remote_fetcher.rb +6 -9
  241. data/lib/rubygems/request.rb +4 -11
  242. data/lib/rubygems/request/connection_pools.rb +0 -4
  243. data/lib/rubygems/request/http_pool.rb +0 -2
  244. data/lib/rubygems/request/https_pool.rb +0 -2
  245. data/lib/rubygems/request_set.rb +2 -15
  246. data/lib/rubygems/request_set/gem_dependency_api.rb +4 -6
  247. data/lib/rubygems/request_set/lockfile.rb +0 -4
  248. data/lib/rubygems/request_set/lockfile/parser.rb +0 -2
  249. data/lib/rubygems/request_set/lockfile/tokenizer.rb +0 -2
  250. data/lib/rubygems/requirement.rb +8 -8
  251. data/lib/rubygems/resolver.rb +7 -4
  252. data/lib/rubygems/resolver/activation_request.rb +9 -3
  253. data/lib/rubygems/resolver/api_set.rb +27 -20
  254. data/lib/rubygems/resolver/api_set/gem_parser.rb +20 -0
  255. data/lib/rubygems/resolver/api_specification.rb +23 -9
  256. data/lib/rubygems/resolver/best_set.rb +1 -3
  257. data/lib/rubygems/resolver/composed_set.rb +0 -2
  258. data/lib/rubygems/resolver/conflict.rb +1 -3
  259. data/lib/rubygems/resolver/current_set.rb +0 -2
  260. data/lib/rubygems/resolver/dependency_request.rb +1 -3
  261. data/lib/rubygems/resolver/git_set.rb +0 -2
  262. data/lib/rubygems/resolver/git_specification.rb +0 -2
  263. data/lib/rubygems/resolver/index_set.rb +0 -2
  264. data/lib/rubygems/resolver/index_specification.rb +26 -2
  265. data/lib/rubygems/resolver/installed_specification.rb +0 -2
  266. data/lib/rubygems/resolver/installer_set.rb +57 -10
  267. data/lib/rubygems/resolver/local_specification.rb +0 -2
  268. data/lib/rubygems/resolver/lock_set.rb +1 -3
  269. data/lib/rubygems/resolver/lock_specification.rb +0 -2
  270. data/lib/rubygems/resolver/molinillo/lib/molinillo.rb +6 -5
  271. data/lib/rubygems/resolver/molinillo/lib/molinillo/delegates/resolution_state.rb +7 -0
  272. data/lib/rubygems/resolver/molinillo/lib/molinillo/delegates/specification_provider.rb +1 -0
  273. data/lib/rubygems/resolver/molinillo/lib/molinillo/dependency_graph.rb +39 -5
  274. data/lib/rubygems/resolver/molinillo/lib/molinillo/dependency_graph/action.rb +1 -0
  275. data/lib/rubygems/resolver/molinillo/lib/molinillo/dependency_graph/add_edge_no_circular.rb +2 -1
  276. data/lib/rubygems/resolver/molinillo/lib/molinillo/dependency_graph/add_vertex.rb +2 -1
  277. data/lib/rubygems/resolver/molinillo/lib/molinillo/dependency_graph/delete_edge.rb +2 -1
  278. data/lib/rubygems/resolver/molinillo/lib/molinillo/dependency_graph/detach_vertex_named.rb +2 -1
  279. data/lib/rubygems/resolver/molinillo/lib/molinillo/dependency_graph/log.rb +7 -6
  280. data/lib/rubygems/resolver/molinillo/lib/molinillo/dependency_graph/set_payload.rb +2 -1
  281. data/lib/rubygems/resolver/molinillo/lib/molinillo/dependency_graph/tag.rb +4 -3
  282. data/lib/rubygems/resolver/molinillo/lib/molinillo/dependency_graph/vertex.rb +43 -10
  283. data/lib/rubygems/resolver/molinillo/lib/molinillo/errors.rb +75 -7
  284. data/lib/rubygems/resolver/molinillo/lib/molinillo/gem_metadata.rb +2 -1
  285. data/lib/rubygems/resolver/molinillo/lib/molinillo/modules/specification_provider.rb +1 -0
  286. data/lib/rubygems/resolver/molinillo/lib/molinillo/modules/ui.rb +3 -1
  287. data/lib/rubygems/resolver/molinillo/lib/molinillo/resolution.rb +506 -165
  288. data/lib/rubygems/resolver/molinillo/lib/molinillo/resolver.rb +3 -2
  289. data/lib/rubygems/resolver/molinillo/lib/molinillo/state.rb +8 -4
  290. data/lib/rubygems/resolver/requirement_list.rb +0 -2
  291. data/lib/rubygems/resolver/set.rb +0 -2
  292. data/lib/rubygems/resolver/source_set.rb +0 -2
  293. data/lib/rubygems/resolver/spec_specification.rb +14 -2
  294. data/lib/rubygems/resolver/specification.rb +13 -3
  295. data/lib/rubygems/resolver/stats.rb +0 -2
  296. data/lib/rubygems/resolver/vendor_set.rb +0 -2
  297. data/lib/rubygems/resolver/vendor_specification.rb +0 -2
  298. data/lib/rubygems/s3_uri_signer.rb +2 -8
  299. data/lib/rubygems/security.rb +2 -9
  300. data/lib/rubygems/security/policy.rb +1 -5
  301. data/lib/rubygems/security/signer.rb +1 -3
  302. data/lib/rubygems/security/trust_dir.rb +0 -2
  303. data/lib/rubygems/server.rb +7 -4
  304. data/lib/rubygems/source.rb +23 -12
  305. data/lib/rubygems/source/git.rb +0 -2
  306. data/lib/rubygems/source/installed.rb +0 -2
  307. data/lib/rubygems/source/local.rb +0 -2
  308. data/lib/rubygems/source/lock.rb +0 -2
  309. data/lib/rubygems/source/specific_file.rb +0 -2
  310. data/lib/rubygems/source/vendor.rb +0 -2
  311. data/lib/rubygems/source_list.rb +0 -2
  312. data/lib/rubygems/spec_fetcher.rb +1 -3
  313. data/lib/rubygems/specification.rb +27 -19
  314. data/lib/rubygems/specification_policy.rb +0 -2
  315. data/lib/rubygems/ssl_certs/{index.rubygems.org → rubygems.org}/GlobalSignRootCA.pem +0 -0
  316. data/lib/rubygems/ssl_certs/rubygems.org/GlobalSignRootCA_R3.pem +21 -0
  317. data/lib/rubygems/stub_specification.rb +1 -5
  318. data/lib/rubygems/syck_hack.rb +0 -2
  319. data/lib/rubygems/test_case.rb +18 -42
  320. data/lib/rubygems/test_utilities.rb +6 -13
  321. data/lib/rubygems/uninstaller.rb +0 -2
  322. data/lib/rubygems/uri_formatter.rb +2 -3
  323. data/lib/rubygems/uri_parser.rb +0 -2
  324. data/lib/rubygems/user_interaction.rb +0 -16
  325. data/lib/rubygems/util.rb +0 -2
  326. data/lib/rubygems/util/licenses.rb +0 -2
  327. data/lib/rubygems/util/list.rb +0 -2
  328. data/lib/rubygems/validator.rb +0 -2
  329. data/lib/rubygems/version.rb +0 -2
  330. data/lib/rubygems/version_option.rb +6 -0
  331. data/rubygems-update.gemspec +1 -1
  332. data/test/rubygems/plugin/load/rubygems_plugin.rb +0 -2
  333. data/test/rubygems/rubygems/commands/crash_command.rb +0 -2
  334. data/test/rubygems/rubygems_plugin.rb +0 -2
  335. data/test/rubygems/test_bundled_ca.rb +42 -41
  336. data/test/rubygems/test_config.rb +0 -2
  337. data/test/rubygems/test_deprecate.rb +0 -6
  338. data/test/rubygems/test_gem.rb +3 -5
  339. data/test/rubygems/test_gem_available_set.rb +0 -2
  340. data/test/rubygems/test_gem_bundler_version_finder.rb +0 -2
  341. data/test/rubygems/test_gem_command.rb +0 -4
  342. data/test/rubygems/test_gem_command_manager.rb +0 -2
  343. data/test/rubygems/test_gem_commands_build_command.rb +226 -13
  344. data/test/rubygems/test_gem_commands_cert_command.rb +2 -4
  345. data/test/rubygems/test_gem_commands_check_command.rb +0 -2
  346. data/test/rubygems/test_gem_commands_cleanup_command.rb +13 -4
  347. data/test/rubygems/test_gem_commands_contents_command.rb +2 -4
  348. data/test/rubygems/test_gem_commands_dependency_command.rb +0 -2
  349. data/test/rubygems/test_gem_commands_environment_command.rb +0 -2
  350. data/test/rubygems/test_gem_commands_fetch_command.rb +0 -2
  351. data/test/rubygems/test_gem_commands_generate_index_command.rb +0 -2
  352. data/test/rubygems/test_gem_commands_help_command.rb +15 -4
  353. data/test/rubygems/test_gem_commands_info_command.rb +0 -2
  354. data/test/rubygems/test_gem_commands_install_command.rb +132 -3
  355. data/test/rubygems/test_gem_commands_list_command.rb +0 -2
  356. data/test/rubygems/test_gem_commands_lock_command.rb +0 -2
  357. data/test/rubygems/test_gem_commands_mirror.rb +0 -2
  358. data/test/rubygems/test_gem_commands_open_command.rb +0 -2
  359. data/test/rubygems/test_gem_commands_outdated_command.rb +0 -2
  360. data/test/rubygems/test_gem_commands_owner_command.rb +48 -2
  361. data/test/rubygems/test_gem_commands_pristine_command.rb +2 -4
  362. data/test/rubygems/test_gem_commands_push_command.rb +70 -7
  363. data/test/rubygems/test_gem_commands_query_command.rb +3 -7
  364. data/test/rubygems/test_gem_commands_search_command.rb +0 -2
  365. data/test/rubygems/test_gem_commands_server_command.rb +0 -2
  366. data/test/rubygems/test_gem_commands_setup_command.rb +19 -30
  367. data/test/rubygems/test_gem_commands_signin_command.rb +27 -5
  368. data/test/rubygems/test_gem_commands_signout_command.rb +0 -2
  369. data/test/rubygems/test_gem_commands_sources_command.rb +60 -2
  370. data/test/rubygems/test_gem_commands_specification_command.rb +28 -2
  371. data/test/rubygems/test_gem_commands_stale_command.rb +0 -2
  372. data/test/rubygems/test_gem_commands_uninstall_command.rb +0 -2
  373. data/test/rubygems/test_gem_commands_unpack_command.rb +0 -2
  374. data/test/rubygems/test_gem_commands_update_command.rb +50 -4
  375. data/test/rubygems/test_gem_commands_which_command.rb +0 -2
  376. data/test/rubygems/test_gem_commands_yank_command.rb +30 -2
  377. data/test/rubygems/test_gem_config_file.rb +0 -2
  378. data/test/rubygems/test_gem_dependency.rb +0 -2
  379. data/test/rubygems/test_gem_dependency_installer.rb +38 -4
  380. data/test/rubygems/test_gem_dependency_list.rb +2 -4
  381. data/test/rubygems/test_gem_dependency_resolution_error.rb +0 -2
  382. data/test/rubygems/test_gem_doctor.rb +0 -2
  383. data/test/rubygems/test_gem_ext_builder.rb +12 -22
  384. data/test/rubygems/test_gem_ext_cmake_builder.rb +3 -11
  385. data/test/rubygems/test_gem_ext_configure_builder.rb +3 -11
  386. data/test/rubygems/test_gem_ext_ext_conf_builder.rb +9 -28
  387. data/test/rubygems/test_gem_ext_rake_builder.rb +30 -15
  388. data/test/rubygems/test_gem_gem_runner.rb +7 -6
  389. data/test/rubygems/test_gem_gemcutter_utilities.rb +3 -5
  390. data/test/rubygems/test_gem_impossible_dependencies_error.rb +0 -2
  391. data/test/rubygems/test_gem_indexer.rb +0 -2
  392. data/test/rubygems/test_gem_install_update_options.rb +14 -4
  393. data/test/rubygems/test_gem_installer.rb +113 -74
  394. data/test/rubygems/test_gem_local_remote_options.rb +0 -2
  395. data/test/rubygems/test_gem_name_tuple.rb +0 -2
  396. data/test/rubygems/test_gem_package.rb +25 -19
  397. data/test/rubygems/test_gem_package_old.rb +4 -6
  398. data/test/rubygems/test_gem_package_tar_header.rb +0 -2
  399. data/test/rubygems/test_gem_package_tar_reader.rb +0 -2
  400. data/test/rubygems/test_gem_package_tar_reader_entry.rb +0 -2
  401. data/test/rubygems/test_gem_package_tar_writer.rb +1 -3
  402. data/test/rubygems/test_gem_package_task.rb +0 -2
  403. data/test/rubygems/test_gem_path_support.rb +0 -2
  404. data/test/rubygems/test_gem_platform.rb +63 -6
  405. data/test/rubygems/test_gem_rdoc.rb +0 -2
  406. data/test/rubygems/test_gem_remote_fetcher.rb +18 -23
  407. data/test/rubygems/test_gem_request.rb +2 -6
  408. data/test/rubygems/test_gem_request_connection_pools.rb +0 -4
  409. data/test/rubygems/test_gem_request_set.rb +0 -2
  410. data/test/rubygems/test_gem_request_set_gem_dependency_api.rb +0 -2
  411. data/test/rubygems/test_gem_request_set_lockfile.rb +4 -6
  412. data/test/rubygems/test_gem_request_set_lockfile_parser.rb +0 -2
  413. data/test/rubygems/test_gem_request_set_lockfile_tokenizer.rb +0 -2
  414. data/test/rubygems/test_gem_requirement.rb +8 -2
  415. data/test/rubygems/test_gem_resolver.rb +0 -2
  416. data/test/rubygems/test_gem_resolver_activation_request.rb +0 -2
  417. data/test/rubygems/test_gem_resolver_api_set.rb +58 -57
  418. data/test/rubygems/test_gem_resolver_api_specification.rb +3 -5
  419. data/test/rubygems/test_gem_resolver_best_set.rb +3 -5
  420. data/test/rubygems/test_gem_resolver_composed_set.rb +0 -2
  421. data/test/rubygems/test_gem_resolver_conflict.rb +1 -3
  422. data/test/rubygems/test_gem_resolver_dependency_request.rb +0 -2
  423. data/test/rubygems/test_gem_resolver_git_set.rb +0 -2
  424. data/test/rubygems/test_gem_resolver_git_specification.rb +0 -2
  425. data/test/rubygems/test_gem_resolver_index_set.rb +0 -2
  426. data/test/rubygems/test_gem_resolver_index_specification.rb +0 -2
  427. data/test/rubygems/test_gem_resolver_installed_specification.rb +0 -2
  428. data/test/rubygems/test_gem_resolver_installer_set.rb +0 -2
  429. data/test/rubygems/test_gem_resolver_local_specification.rb +0 -2
  430. data/test/rubygems/test_gem_resolver_lock_set.rb +0 -2
  431. data/test/rubygems/test_gem_resolver_lock_specification.rb +0 -2
  432. data/test/rubygems/test_gem_resolver_requirement_list.rb +0 -2
  433. data/test/rubygems/test_gem_resolver_specification.rb +0 -4
  434. data/test/rubygems/test_gem_resolver_vendor_set.rb +1 -3
  435. data/test/rubygems/test_gem_resolver_vendor_specification.rb +0 -2
  436. data/test/rubygems/test_gem_security.rb +2 -4
  437. data/test/rubygems/test_gem_security_policy.rb +2 -4
  438. data/test/rubygems/test_gem_security_signer.rb +2 -4
  439. data/test/rubygems/test_gem_security_trust_dir.rb +2 -4
  440. data/test/rubygems/test_gem_server.rb +0 -4
  441. data/test/rubygems/test_gem_silent_ui.rb +0 -2
  442. data/test/rubygems/test_gem_source.rb +7 -4
  443. data/test/rubygems/test_gem_source_fetch_problem.rb +0 -2
  444. data/test/rubygems/test_gem_source_git.rb +0 -2
  445. data/test/rubygems/test_gem_source_installed.rb +0 -2
  446. data/test/rubygems/test_gem_source_list.rb +1 -2
  447. data/test/rubygems/test_gem_source_local.rb +0 -2
  448. data/test/rubygems/test_gem_source_lock.rb +0 -2
  449. data/test/rubygems/test_gem_source_specific_file.rb +0 -2
  450. data/test/rubygems/test_gem_source_subpath_problem.rb +49 -0
  451. data/test/rubygems/test_gem_source_vendor.rb +0 -2
  452. data/test/rubygems/test_gem_spec_fetcher.rb +0 -2
  453. data/test/rubygems/test_gem_specification.rb +15 -14
  454. data/test/rubygems/test_gem_stream_ui.rb +0 -2
  455. data/test/rubygems/test_gem_stub_specification.rb +4 -6
  456. data/test/rubygems/test_gem_text.rb +0 -2
  457. data/test/rubygems/test_gem_uninstaller.rb +7 -9
  458. data/test/rubygems/test_gem_unsatisfiable_dependency_error.rb +0 -2
  459. data/test/rubygems/test_gem_uri_formatter.rb +0 -2
  460. data/test/rubygems/test_gem_util.rb +0 -2
  461. data/test/rubygems/test_gem_validator.rb +1 -3
  462. data/test/rubygems/test_gem_version.rb +0 -2
  463. data/test/rubygems/test_gem_version_option.rb +1 -3
  464. data/test/rubygems/test_kernel.rb +0 -2
  465. data/test/rubygems/test_project_sanity.rb +0 -2
  466. data/test/rubygems/test_remote_fetch_error.rb +0 -2
  467. data/test/rubygems/test_require.rb +50 -17
  468. data/test/test_changelog_generator.rb +17 -0
  469. metadata +59 -77
  470. data/bundler/lib/bundler/vendor/molinillo/lib/molinillo/compatibility.rb +0 -26
  471. data/bundler/man/bundle-add.1.txt +0 -58
  472. data/bundler/man/bundle-binstubs.1.txt +0 -48
  473. data/bundler/man/bundle-cache.1.txt +0 -78
  474. data/bundler/man/bundle-check.1.txt +0 -33
  475. data/bundler/man/bundle-clean.1.txt +0 -26
  476. data/bundler/man/bundle-config.1.txt +0 -527
  477. data/bundler/man/bundle-doctor.1.txt +0 -44
  478. data/bundler/man/bundle-exec.1.txt +0 -181
  479. data/bundler/man/bundle-gem.1.txt +0 -117
  480. data/bundler/man/bundle-info.1.txt +0 -21
  481. data/bundler/man/bundle-init.1.txt +0 -34
  482. data/bundler/man/bundle-inject.1.txt +0 -32
  483. data/bundler/man/bundle-install.1.txt +0 -401
  484. data/bundler/man/bundle-list.1.txt +0 -44
  485. data/bundler/man/bundle-lock.1.txt +0 -93
  486. data/bundler/man/bundle-open.1.txt +0 -29
  487. data/bundler/man/bundle-outdated.1.txt +0 -131
  488. data/bundler/man/bundle-platform.1.txt +0 -57
  489. data/bundler/man/bundle-pristine.1.txt +0 -44
  490. data/bundler/man/bundle-remove.1.txt +0 -34
  491. data/bundler/man/bundle-show.1.txt +0 -27
  492. data/bundler/man/bundle-update.1.txt +0 -391
  493. data/bundler/man/bundle-viz.1.txt +0 -39
  494. data/bundler/man/bundle.1.txt +0 -116
  495. data/bundler/man/gemfile.5.txt +0 -651
  496. data/lib/rubygems/ssl_certs/rubygems.global.ssl.fastly.net/DigiCertHighAssuranceEVRootCA.pem +0 -23
  497. data/lib/rubygems/ssl_certs/rubygems.org/AddTrustExternalCARoot.pem +0 -25
@@ -1,26 +0,0 @@
1
- # frozen_string_literal: true
2
-
3
- module Bundler::Molinillo
4
- # Hacks needed for old Ruby versions.
5
- module Compatibility
6
- module_function
7
-
8
- if [].respond_to?(:flat_map)
9
- # Flat map
10
- # @param [Enumerable] enum an enumerable object
11
- # @block the block to flat-map with
12
- # @return The enum, flat-mapped
13
- def flat_map(enum, &blk)
14
- enum.flat_map(&blk)
15
- end
16
- else
17
- # Flat map
18
- # @param [Enumerable] enum an enumerable object
19
- # @block the block to flat-map with
20
- # @return The enum, flat-mapped
21
- def flat_map(enum, &blk)
22
- enum.map(&blk).flatten(1)
23
- end
24
- end
25
- end
26
- end
@@ -1,58 +0,0 @@
1
- BUNDLE-ADD(1) BUNDLE-ADD(1)
2
-
3
-
4
-
5
- NAME
6
- bundle-add - Add gem to the Gemfile and run bundle install
7
-
8
- SYNOPSIS
9
- bundle add GEM_NAME [--group=GROUP] [--version=VERSION]
10
- [--source=SOURCE] [--git=GIT] [--branch=BRANCH] [--skip-install]
11
- [--strict] [--optimistic]
12
-
13
- DESCRIPTION
14
- Adds the named gem to the Gemfile and run bundle install. bundle
15
- install can be avoided by using the flag --skip-install.
16
-
17
- Example:
18
-
19
- bundle add rails
20
-
21
- bundle add rails --version "< 3.0, > 1.1"
22
-
23
- bundle add rails --version "~> 5.0.0" --source
24
- "https://gems.example.com" --group "development"
25
-
26
- bundle add rails --skip-install
27
-
28
- bundle add rails --group "development, test"
29
-
30
- OPTIONS
31
- --version, -v
32
- Specify version requirements(s) for the added gem.
33
-
34
- --group, -g
35
- Specify the group(s) for the added gem. Multiple groups should
36
- be separated by commas.
37
-
38
- --source, , -s
39
- Specify the source for the added gem.
40
-
41
- --git Specify the git source for the added gem.
42
-
43
- --branch
44
- Specify the git branch for the added gem.
45
-
46
- --skip-install
47
- Adds the gem to the Gemfile but does not install it.
48
-
49
- --optimistic
50
- Adds optimistic declaration of version
51
-
52
- --strict
53
- Adds strict declaration of version
54
-
55
-
56
-
57
-
58
- July 2020 BUNDLE-ADD(1)
@@ -1,48 +0,0 @@
1
- BUNDLE-BINSTUBS(1) BUNDLE-BINSTUBS(1)
2
-
3
-
4
-
5
- NAME
6
- bundle-binstubs - Install the binstubs of the listed gems
7
-
8
- SYNOPSIS
9
- bundle binstubs GEM_NAME [--force] [--path PATH] [--standalone]
10
-
11
- DESCRIPTION
12
- Binstubs are scripts that wrap around executables. Bundler creates a
13
- small Ruby file (a binstub) that loads Bundler, runs the command, and
14
- puts it into bin/. Binstubs are a shortcut-or alternative- to always
15
- using bundle exec. This gives you a file that can be run directly, and
16
- one that will always run the correct gem version used by the
17
- application.
18
-
19
- For example, if you run bundle binstubs rspec-core, Bundler will create
20
- the file bin/rspec. That file will contain enough code to load Bundler,
21
- tell it to load the bundled gems, and then run rspec.
22
-
23
- This command generates binstubs for executables in GEM_NAME. Binstubs
24
- are put into bin, or the --path directory if one has been set. Calling
25
- binstubs with [GEM [GEM]] will create binstubs for all given gems.
26
-
27
- OPTIONS
28
- --force
29
- Overwrite existing binstubs if they exist.
30
-
31
- --path The location to install the specified binstubs to. This defaults
32
- to bin.
33
-
34
- --standalone
35
- Makes binstubs that can work without depending on Rubygems or
36
- Bundler at runtime.
37
-
38
- --shebang
39
- Specify a different shebang executable name than the default
40
- (default 'ruby')
41
-
42
- BUNDLE INSTALL --BINSTUBS
43
- To create binstubs for all the gems in the bundle you can use the
44
- --binstubs flag in bundle install(1) bundle-install.1.html.
45
-
46
-
47
-
48
- July 2020 BUNDLE-BINSTUBS(1)
@@ -1,78 +0,0 @@
1
- BUNDLE-CACHE(1) BUNDLE-CACHE(1)
2
-
3
-
4
-
5
- NAME
6
- bundle-cache - Package your needed .gem files into your application
7
-
8
- SYNOPSIS
9
- bundle cache
10
-
11
- DESCRIPTION
12
- Copy all of the .gem files needed to run the application into the
13
- vendor/cache directory. In the future, when running [bundle
14
- install(1)][bundle-install], use the gems in the cache in preference to
15
- the ones on rubygems.org.
16
-
17
- GIT AND PATH GEMS
18
- The bundle cache command can also package :git and :path dependencies
19
- besides .gem files. This needs to be explicitly enabled via the --all
20
- option. Once used, the --all option will be remembered.
21
-
22
- SUPPORT FOR MULTIPLE PLATFORMS
23
- When using gems that have different packages for different platforms,
24
- Bundler supports caching of gems for other platforms where the Gemfile
25
- has been resolved (i.e. present in the lockfile) in vendor/cache. This
26
- needs to be enabled via the --all-platforms option. This setting will
27
- be remembered in your local bundler configuration.
28
-
29
- REMOTE FETCHING
30
- By default, if you run bundle install(1)](bundle-install.1.html) after
31
- running bundle cache(1) bundle-cache.1.html, bundler will still connect
32
- to rubygems.org to check whether a platform-specific gem exists for any
33
- of the gems in vendor/cache.
34
-
35
- For instance, consider this Gemfile(5):
36
-
37
-
38
-
39
- source "https://rubygems.org"
40
-
41
- gem "nokogiri"
42
-
43
-
44
-
45
- If you run bundle cache under C Ruby, bundler will retrieve the version
46
- of nokogiri for the "ruby" platform. If you deploy to JRuby and run
47
- bundle install, bundler is forced to check to see whether a "java"
48
- platformed nokogiri exists.
49
-
50
- Even though the nokogiri gem for the Ruby platform is technically
51
- acceptable on JRuby, it has a C extension that does not run on JRuby.
52
- As a result, bundler will, by default, still connect to rubygems.org to
53
- check whether it has a version of one of your gems more specific to
54
- your platform.
55
-
56
- This problem is also not limited to the "java" platform. A similar
57
- (common) problem can happen when developing on Windows and deploying to
58
- Linux, or even when developing on OSX and deploying to Linux.
59
-
60
- If you know for sure that the gems packaged in vendor/cache are
61
- appropriate for the platform you are on, you can run bundle install
62
- --local to skip checking for more appropriate gems, and use the ones in
63
- vendor/cache.
64
-
65
- One way to be sure that you have the right platformed versions of all
66
- your gems is to run bundle cache on an identical machine and check in
67
- the gems. For instance, you can run bundle cache on an identical
68
- staging box during your staging process, and check in the vendor/cache
69
- before deploying to production.
70
-
71
- By default, bundle cache(1) bundle-cache.1.html fetches and also
72
- installs the gems to the default location. To package the dependencies
73
- to vendor/cache without installing them to the local install location,
74
- you can run bundle cache --no-install.
75
-
76
-
77
-
78
- July 2020 BUNDLE-CACHE(1)
@@ -1,33 +0,0 @@
1
- BUNDLE-CHECK(1) BUNDLE-CHECK(1)
2
-
3
-
4
-
5
- NAME
6
- bundle-check - Verifies if dependencies are satisfied by installed gems
7
-
8
- SYNOPSIS
9
- bundle check [--dry-run] [--gemfile=FILE] [--path=PATH]
10
-
11
- DESCRIPTION
12
- check searches the local machine for each of the gems requested in the
13
- Gemfile. If all gems are found, Bundler prints a success message and
14
- exits with a status of 0.
15
-
16
- If not, the first missing gem is listed and Bundler exits status 1.
17
-
18
- OPTIONS
19
- --dry-run
20
- Locks the [Gemfile(5)][Gemfile(5)] before running the command.
21
-
22
- --gemfile
23
- Use the specified gemfile instead of the
24
- [Gemfile(5)][Gemfile(5)].
25
-
26
- --path Specify a different path than the system default ($BUNDLE_PATH
27
- or $GEM_HOME). Bundler will remember this value for future
28
- installs on this machine.
29
-
30
-
31
-
32
-
33
- July 2020 BUNDLE-CHECK(1)
@@ -1,26 +0,0 @@
1
- BUNDLE-CLEAN(1) BUNDLE-CLEAN(1)
2
-
3
-
4
-
5
- NAME
6
- bundle-clean - Cleans up unused gems in your bundler directory
7
-
8
- SYNOPSIS
9
- bundle clean [--dry-run] [--force]
10
-
11
- DESCRIPTION
12
- This command will remove all unused gems in your bundler directory.
13
- This is useful when you have made many changes to your gem
14
- dependencies.
15
-
16
- OPTIONS
17
- --dry-run
18
- Print the changes, but do not clean the unused gems.
19
-
20
- --force
21
- Force a clean even if --path is not set.
22
-
23
-
24
-
25
-
26
- July 2020 BUNDLE-CLEAN(1)
@@ -1,527 +0,0 @@
1
- BUNDLE-CONFIG(1) BUNDLE-CONFIG(1)
2
-
3
-
4
-
5
- NAME
6
- bundle-config - Set bundler configuration options
7
-
8
- SYNOPSIS
9
- bundle config [list|get|set|unset] [name [value]]
10
-
11
- DESCRIPTION
12
- This command allows you to interact with Bundler's configuration
13
- system.
14
-
15
- Bundler loads configuration settings in this order:
16
-
17
- 1. Local config (<project_root>/.bundle/config or
18
- $BUNDLE_APP_CONFIG/config)
19
-
20
- 2. Environmental variables (ENV)
21
-
22
- 3. Global config (~/.bundle/config)
23
-
24
- 4. Bundler default config
25
-
26
-
27
-
28
- Executing bundle config list with will print a list of all bundler
29
- configuration for the current bundle, and where that configuration was
30
- set.
31
-
32
- Executing bundle config get <name> will print the value of that
33
- configuration setting, and where it was set.
34
-
35
- Executing bundle config set <name> <value> will set that configuration
36
- to the value specified for all bundles executed as the current user.
37
- The configuration will be stored in ~/.bundle/config. If name already
38
- is set, name will be overridden and user will be warned.
39
-
40
- Executing bundle config set --global <name> <value> works the same as
41
- above.
42
-
43
- Executing bundle config set --local <name> <value> will set that
44
- configuration in the directory for the local application. The
45
- configuration will be stored in <project_root>/.bundle/config. If
46
- BUNDLE_APP_CONFIG is set, the configuration will be stored in
47
- $BUNDLE_APP_CONFIG/config.
48
-
49
- Executing bundle config unset <name> will delete the configuration in
50
- both local and global sources.
51
-
52
- Executing bundle config unset --global <name> will delete the
53
- configuration only from the user configuration.
54
-
55
- Executing bundle config unset --local <name> <value> will delete the
56
- configuration only from the local application.
57
-
58
- Executing bundle with the BUNDLE_IGNORE_CONFIG environment variable set
59
- will cause it to ignore all configuration.
60
-
61
- Executing bundle config set disable_multisource true upgrades the
62
- warning about the Gemfile containing multiple primary sources to an
63
- error. Executing bundle config unset disable_multisource downgrades
64
- this error to a warning.
65
-
66
- REMEMBERING OPTIONS
67
- Flags passed to bundle install or the Bundler runtime, such as --path
68
- foo or --without production, are remembered between commands and saved
69
- to your local application's configuration (normally, ./.bundle/config).
70
-
71
- However, this will be changed in bundler 3, so it's better not to rely
72
- on this behavior. If these options must be remembered, it's better to
73
- set them using bundle config (e.g., bundle config set path foo).
74
-
75
- The options that can be configured are:
76
-
77
- bin Creates a directory (defaults to ~/bin) and place any
78
- executables from the gem there. These executables run in
79
- Bundler's context. If used, you might add this directory to your
80
- environment's PATH variable. For instance, if the rails gem
81
- comes with a rails executable, this flag will create a bin/rails
82
- executable that ensures that all referred dependencies will be
83
- resolved using the bundled gems.
84
-
85
- deployment
86
- In deployment mode, Bundler will 'roll-out' the bundle for
87
- production use. Please check carefully if you want to have this
88
- option enabled in development or test environments.
89
-
90
- path The location to install the specified gems to. This defaults to
91
- Rubygems' setting. Bundler shares this location with Rubygems,
92
- gem install ... will have gem installed there, too. Therefore,
93
- gems installed without a --path ... setting will show up by
94
- calling gem list. Accordingly, gems installed to other locations
95
- will not get listed.
96
-
97
- without
98
- A space-separated list of groups referencing gems to skip during
99
- installation.
100
-
101
- with A space-separated list of groups referencing gems to include
102
- during installation.
103
-
104
- BUILD OPTIONS
105
- You can use bundle config to give Bundler the flags to pass to the gem
106
- installer every time bundler tries to install a particular gem.
107
-
108
- A very common example, the mysql gem, requires Snow Leopard users to
109
- pass configuration flags to gem install to specify where to find the
110
- mysql_config executable.
111
-
112
-
113
-
114
- gem install mysql -- --with-mysql-config=/usr/local/mysql/bin/mysql_config
115
-
116
-
117
-
118
- Since the specific location of that executable can change from machine
119
- to machine, you can specify these flags on a per-machine basis.
120
-
121
-
122
-
123
- bundle config set build.mysql --with-mysql-config=/usr/local/mysql/bin/mysql_config
124
-
125
-
126
-
127
- After running this command, every time bundler needs to install the
128
- mysql gem, it will pass along the flags you specified.
129
-
130
- CONFIGURATION KEYS
131
- Configuration keys in bundler have two forms: the canonical form and
132
- the environment variable form.
133
-
134
- For instance, passing the --without flag to bundle install(1)
135
- bundle-install.1.html prevents Bundler from installing certain groups
136
- specified in the Gemfile(5). Bundler persists this value in
137
- app/.bundle/config so that calls to Bundler.setup do not try to find
138
- gems from the Gemfile that you didn't install. Additionally, subsequent
139
- calls to bundle install(1) bundle-install.1.html remember this setting
140
- and skip those groups.
141
-
142
- The canonical form of this configuration is "without". To convert the
143
- canonical form to the environment variable form, capitalize it, and
144
- prepend BUNDLE_. The environment variable form of "without" is
145
- BUNDLE_WITHOUT.
146
-
147
- Any periods in the configuration keys must be replaced with two
148
- underscores when setting it via environment variables. The
149
- configuration key local.rack becomes the environment variable
150
- BUNDLE_LOCAL__RACK.
151
-
152
- LIST OF AVAILABLE KEYS
153
- The following is a list of all configuration keys and their purpose.
154
- You can learn more about their operation in bundle install(1)
155
- bundle-install.1.html.
156
-
157
- o allow_bundler_dependency_conflicts
158
- (BUNDLE_ALLOW_BUNDLER_DEPENDENCY_CONFLICTS): Allow resolving to
159
- specifications that have dependencies on bundler that are
160
- incompatible with the running Bundler version.
161
-
162
- o allow_deployment_source_credential_changes
163
- (BUNDLE_ALLOW_DEPLOYMENT_SOURCE_CREDENTIAL_CHANGES): When in
164
- deployment mode, allow changing the credentials to a gem's source.
165
- Ex: https://some.host.com/gems/path/ ->
166
- https://user_name:password@some.host.com/gems/path
167
-
168
- o allow_offline_install (BUNDLE_ALLOW_OFFLINE_INSTALL): Allow Bundler
169
- to use cached data when installing without network access.
170
-
171
- o auto_clean_without_path (BUNDLE_AUTO_CLEAN_WITHOUT_PATH):
172
- Automatically run bundle clean after installing when an explicit
173
- path has not been set and Bundler is not installing into the system
174
- gems.
175
-
176
- o auto_install (BUNDLE_AUTO_INSTALL): Automatically run bundle
177
- install when gems are missing.
178
-
179
- o bin (BUNDLE_BIN): Install executables from gems in the bundle to
180
- the specified directory. Defaults to false.
181
-
182
- o cache_all (BUNDLE_CACHE_ALL): Cache all gems, including path and
183
- git gems.
184
-
185
- o cache_all_platforms (BUNDLE_CACHE_ALL_PLATFORMS): Cache gems for
186
- all platforms.
187
-
188
- o cache_path (BUNDLE_CACHE_PATH): The directory that bundler will
189
- place cached gems in when running bundle package, and that bundler
190
- will look in when installing gems. Defaults to vendor/cache.
191
-
192
- o clean (BUNDLE_CLEAN): Whether Bundler should run bundle clean
193
- automatically after bundle install.
194
-
195
- o console (BUNDLE_CONSOLE): The console that bundle console starts.
196
- Defaults to irb.
197
-
198
- o default_install_uses_path (BUNDLE_DEFAULT_INSTALL_USES_PATH):
199
- Whether a bundle install without an explicit --path argument
200
- defaults to installing gems in .bundle.
201
-
202
- o deployment (BUNDLE_DEPLOYMENT): Disallow changes to the Gemfile.
203
- When the Gemfile is changed and the lockfile has not been updated,
204
- running Bundler commands will be blocked.
205
-
206
- o disable_checksum_validation (BUNDLE_DISABLE_CHECKSUM_VALIDATION):
207
- Allow installing gems even if they do not match the checksum
208
- provided by RubyGems.
209
-
210
- o disable_exec_load (BUNDLE_DISABLE_EXEC_LOAD): Stop Bundler from
211
- using load to launch an executable in-process in bundle exec.
212
-
213
- o disable_local_branch_check (BUNDLE_DISABLE_LOCAL_BRANCH_CHECK):
214
- Allow Bundler to use a local git override without a branch
215
- specified in the Gemfile.
216
-
217
- o disable_multisource (BUNDLE_DISABLE_MULTISOURCE): When set,
218
- Gemfiles containing multiple sources will produce errors instead of
219
- warnings. Use bundle config unset disable_multisource to unset.
220
-
221
- o disable_shared_gems (BUNDLE_DISABLE_SHARED_GEMS): Stop Bundler from
222
- accessing gems installed to RubyGems' normal location.
223
-
224
- o disable_version_check (BUNDLE_DISABLE_VERSION_CHECK): Stop Bundler
225
- from checking if a newer Bundler version is available on
226
- rubygems.org.
227
-
228
- o force_ruby_platform (BUNDLE_FORCE_RUBY_PLATFORM): Ignore the
229
- current machine's platform and install only ruby platform gems. As
230
- a result, gems with native extensions will be compiled from source.
231
-
232
- o frozen (BUNDLE_FROZEN): Disallow changes to the Gemfile. When the
233
- Gemfile is changed and the lockfile has not been updated, running
234
- Bundler commands will be blocked. Defaults to true when
235
- --deployment is used.
236
-
237
- o gem.push_key (BUNDLE_GEM__PUSH_KEY): Sets the --key parameter for
238
- gem push when using the rake release command with a private
239
- gemstash server.
240
-
241
- o gemfile (BUNDLE_GEMFILE): The name of the file that bundler should
242
- use as the Gemfile. This location of this file also sets the root
243
- of the project, which is used to resolve relative paths in the
244
- Gemfile, among other things. By default, bundler will search up
245
- from the current working directory until it finds a Gemfile.
246
-
247
- o global_gem_cache (BUNDLE_GLOBAL_GEM_CACHE): Whether Bundler should
248
- cache all gems globally, rather than locally to the installing Ruby
249
- installation.
250
-
251
- o ignore_messages (BUNDLE_IGNORE_MESSAGES): When set, no post install
252
- messages will be printed. To silence a single gem, use dot notation
253
- like ignore_messages.httparty true.
254
-
255
- o init_gems_rb (BUNDLE_INIT_GEMS_RB) Generate a gems.rb instead of a
256
- Gemfile when running bundle init.
257
-
258
- o jobs (BUNDLE_JOBS): The number of gems Bundler can install in
259
- parallel. Defaults to 1.
260
-
261
- o no_install (BUNDLE_NO_INSTALL): Whether bundle package should skip
262
- installing gems.
263
-
264
- o no_prune (BUNDLE_NO_PRUNE): Whether Bundler should leave outdated
265
- gems unpruned when caching.
266
-
267
- o only_update_to_newer_versions
268
- (BUNDLE_ONLY_UPDATE_TO_NEWER_VERSIONS): During bundle update, only
269
- resolve to newer versions of the gems in the lockfile.
270
-
271
- o path (BUNDLE_PATH): The location on disk where all gems in your
272
- bundle will be located regardless of $GEM_HOME or $GEM_PATH values.
273
- Bundle gems not found in this location will be installed by bundle
274
- install. Defaults to Gem.dir. When --deployment is used, defaults
275
- to vendor/bundle.
276
-
277
- o path.system (BUNDLE_PATH__SYSTEM): Whether Bundler will install
278
- gems into the default system path (Gem.dir).
279
-
280
- o path_relative_to_cwd (BUNDLE_PATH_RELATIVE_TO_CWD) Makes --path
281
- relative to the CWD instead of the Gemfile.
282
-
283
- o plugins (BUNDLE_PLUGINS): Enable Bundler's experimental plugin
284
- system.
285
-
286
- o prefer_patch (BUNDLE_PREFER_PATCH): Prefer updating only to next
287
- patch version during updates. Makes bundle update calls equivalent
288
- to bundler update --patch.
289
-
290
- o print_only_version_number (BUNDLE_PRINT_ONLY_VERSION_NUMBER) Print
291
- only version number from bundler --version.
292
-
293
- o redirect (BUNDLE_REDIRECT): The number of redirects allowed for
294
- network requests. Defaults to 5.
295
-
296
- o retry (BUNDLE_RETRY): The number of times to retry failed network
297
- requests. Defaults to 3.
298
-
299
- o setup_makes_kernel_gem_public
300
- (BUNDLE_SETUP_MAKES_KERNEL_GEM_PUBLIC): Have Bundler.setup make the
301
- Kernel#gem method public, even though RubyGems declares it as
302
- private.
303
-
304
- o shebang (BUNDLE_SHEBANG): The program name that should be invoked
305
- for generated binstubs. Defaults to the ruby install name used to
306
- generate the binstub.
307
-
308
- o silence_deprecations (BUNDLE_SILENCE_DEPRECATIONS): Whether Bundler
309
- should silence deprecation warnings for behavior that will be
310
- changed in the next major version.
311
-
312
- o silence_root_warning (BUNDLE_SILENCE_ROOT_WARNING): Silence the
313
- warning Bundler prints when installing gems as root.
314
-
315
- o specific_platform (BUNDLE_SPECIFIC_PLATFORM): Allow bundler to
316
- resolve for the specific running platform and store it in the
317
- lockfile, instead of only using a generic platform. A specific
318
- platform is the exact platform triple reported by
319
- Gem::Platform.local, such as x86_64-darwin-16 or
320
- universal-java-1.8. On the other hand, generic platforms are those
321
- such as ruby, mswin, or java. In this example, x86_64-darwin-16
322
- would map to ruby and universal-java-1.8 to java.
323
-
324
- o ssl_ca_cert (BUNDLE_SSL_CA_CERT): Path to a designated CA
325
- certificate file or folder containing multiple certificates for
326
- trusted CAs in PEM format.
327
-
328
- o ssl_client_cert (BUNDLE_SSL_CLIENT_CERT): Path to a designated file
329
- containing a X.509 client certificate and key in PEM format.
330
-
331
- o ssl_verify_mode (BUNDLE_SSL_VERIFY_MODE): The SSL verification mode
332
- Bundler uses when making HTTPS requests. Defaults to verify peer.
333
-
334
- o suppress_install_using_messages
335
- (BUNDLE_SUPPRESS_INSTALL_USING_MESSAGES): Avoid printing Using ...
336
- messages during installation when the version of a gem has not
337
- changed.
338
-
339
- o system_bindir (BUNDLE_SYSTEM_BINDIR): The location where RubyGems
340
- installs binstubs. Defaults to Gem.bindir.
341
-
342
- o timeout (BUNDLE_TIMEOUT): The seconds allowed before timing out for
343
- network requests. Defaults to 10.
344
-
345
- o unlock_source_unlocks_spec (BUNDLE_UNLOCK_SOURCE_UNLOCKS_SPEC):
346
- Whether running bundle update --source NAME unlocks a gem with the
347
- given name. Defaults to true.
348
-
349
- o update_requires_all_flag (BUNDLE_UPDATE_REQUIRES_ALL_FLAG) Require
350
- passing --all to bundle update when everything should be updated,
351
- and disallow passing no options to bundle update.
352
-
353
- o user_agent (BUNDLE_USER_AGENT): The custom user agent fragment
354
- Bundler includes in API requests.
355
-
356
- o with (BUNDLE_WITH): A :-separated list of groups whose gems bundler
357
- should install.
358
-
359
- o without (BUNDLE_WITHOUT): A :-separated list of groups whose gems
360
- bundler should not install.
361
-
362
-
363
-
364
- In general, you should set these settings per-application by using the
365
- applicable flag to the bundle install(1) bundle-install.1.html or
366
- bundle package(1) bundle-package.1.html command.
367
-
368
- You can set them globally either via environment variables or bundle
369
- config, whichever is preferable for your setup. If you use both,
370
- environment variables will take preference over global settings.
371
-
372
- LOCAL GIT REPOS
373
- Bundler also allows you to work against a git repository locally
374
- instead of using the remote version. This can be achieved by setting up
375
- a local override:
376
-
377
-
378
-
379
- bundle config set local.GEM_NAME /path/to/local/git/repository
380
-
381
-
382
-
383
- For example, in order to use a local Rack repository, a developer could
384
- call:
385
-
386
-
387
-
388
- bundle config set local.rack ~/Work/git/rack
389
-
390
-
391
-
392
- Now instead of checking out the remote git repository, the local
393
- override will be used. Similar to a path source, every time the local
394
- git repository change, changes will be automatically picked up by
395
- Bundler. This means a commit in the local git repo will update the
396
- revision in the Gemfile.lock to the local git repo revision. This
397
- requires the same attention as git submodules. Before pushing to the
398
- remote, you need to ensure the local override was pushed, otherwise you
399
- may point to a commit that only exists in your local machine. You'll
400
- also need to CGI escape your usernames and passwords as well.
401
-
402
- Bundler does many checks to ensure a developer won't work with invalid
403
- references. Particularly, we force a developer to specify a branch in
404
- the Gemfile in order to use this feature. If the branch specified in
405
- the Gemfile and the current branch in the local git repository do not
406
- match, Bundler will abort. This ensures that a developer is always
407
- working against the correct branches, and prevents accidental locking
408
- to a different branch.
409
-
410
- Finally, Bundler also ensures that the current revision in the
411
- Gemfile.lock exists in the local git repository. By doing this, Bundler
412
- forces you to fetch the latest changes in the remotes.
413
-
414
- MIRRORS OF GEM SOURCES
415
- Bundler supports overriding gem sources with mirrors. This allows you
416
- to configure rubygems.org as the gem source in your Gemfile while still
417
- using your mirror to fetch gems.
418
-
419
-
420
-
421
- bundle config set mirror.SOURCE_URL MIRROR_URL
422
-
423
-
424
-
425
- For example, to use a mirror of rubygems.org hosted at
426
- rubygems-mirror.org:
427
-
428
-
429
-
430
- bundle config set mirror.http://rubygems.org http://rubygems-mirror.org
431
-
432
-
433
-
434
- Each mirror also provides a fallback timeout setting. If the mirror
435
- does not respond within the fallback timeout, Bundler will try to use
436
- the original server instead of the mirror.
437
-
438
-
439
-
440
- bundle config set mirror.SOURCE_URL.fallback_timeout TIMEOUT
441
-
442
-
443
-
444
- For example, to fall back to rubygems.org after 3 seconds:
445
-
446
-
447
-
448
- bundle config set mirror.https://rubygems.org.fallback_timeout 3
449
-
450
-
451
-
452
- The default fallback timeout is 0.1 seconds, but the setting can
453
- currently only accept whole seconds (for example, 1, 15, or 30).
454
-
455
- CREDENTIALS FOR GEM SOURCES
456
- Bundler allows you to configure credentials for any gem source, which
457
- allows you to avoid putting secrets into your Gemfile.
458
-
459
-
460
-
461
- bundle config set SOURCE_HOSTNAME USERNAME:PASSWORD
462
-
463
-
464
-
465
- For example, to save the credentials of user claudette for the gem
466
- source at gems.longerous.com, you would run:
467
-
468
-
469
-
470
- bundle config set gems.longerous.com claudette:s00pers3krit
471
-
472
-
473
-
474
- Or you can set the credentials as an environment variable like this:
475
-
476
-
477
-
478
- export BUNDLE_GEMS__LONGEROUS__COM="claudette:s00pers3krit"
479
-
480
-
481
-
482
- For gems with a git source with HTTP(S) URL you can specify credentials
483
- like so:
484
-
485
-
486
-
487
- bundle config set https://github.com/bundler/bundler.git username:password
488
-
489
-
490
-
491
- Or you can set the credentials as an environment variable like so:
492
-
493
-
494
-
495
- export BUNDLE_GITHUB__COM=username:password
496
-
497
-
498
-
499
- This is especially useful for private repositories on hosts such as
500
- Github, where you can use personal OAuth tokens:
501
-
502
-
503
-
504
- export BUNDLE_GITHUB__COM=abcd0123generatedtoken:x-oauth-basic
505
-
506
-
507
-
508
- CONFIGURE BUNDLER DIRECTORIES
509
- Bundler's home, config, cache and plugin directories are able to be
510
- configured through environment variables. The default location for
511
- Bundler's home directory is ~/.bundle, which all directories inherit
512
- from by default. The following outlines the available environment
513
- variables and their default values
514
-
515
-
516
-
517
- BUNDLE_USER_HOME : $HOME/.bundle
518
- BUNDLE_USER_CACHE : $BUNDLE_USER_HOME/cache
519
- BUNDLE_USER_CONFIG : $BUNDLE_USER_HOME/config
520
- BUNDLE_USER_PLUGIN : $BUNDLE_USER_HOME/plugin
521
-
522
-
523
-
524
-
525
-
526
-
527
- July 2020 BUNDLE-CONFIG(1)