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,651 +0,0 @@
1
- GEMFILE(5) GEMFILE(5)
2
-
3
-
4
-
5
- NAME
6
- Gemfile - A format for describing gem dependencies for Ruby programs
7
-
8
- SYNOPSIS
9
- A Gemfile describes the gem dependencies required to execute associated
10
- Ruby code.
11
-
12
- Place the Gemfile in the root of the directory containing the
13
- associated code. For instance, in a Rails application, place the
14
- Gemfile in the same directory as the Rakefile.
15
-
16
- SYNTAX
17
- A Gemfile is evaluated as Ruby code, in a context which makes available
18
- a number of methods used to describe the gem requirements.
19
-
20
- GLOBAL SOURCES
21
- At the top of the Gemfile, add a line for the Rubygems source that
22
- contains the gems listed in the Gemfile.
23
-
24
-
25
-
26
- source "https://rubygems.org"
27
-
28
-
29
-
30
- It is possible, but not recommended as of Bundler 1.7, to add multiple
31
- global source lines. Each of these sources MUST be a valid Rubygems
32
- repository.
33
-
34
- Sources are checked for gems following the heuristics described in
35
- SOURCE PRIORITY. If a gem is found in more than one global source,
36
- Bundler will print a warning after installing the gem indicating which
37
- source was used, and listing the other sources where the gem is
38
- available. A specific source can be selected for gems that need to use
39
- a non-standard repository, suppressing this warning, by using the
40
- :source option or a source block.
41
-
42
- CREDENTIALS
43
- Some gem sources require a username and password. Use bundle config(1)
44
- bundle-config.1.html to set the username and password for any of the
45
- sources that need it. The command must be run once on each computer
46
- that will install the Gemfile, but this keeps the credentials from
47
- being stored in plain text in version control.
48
-
49
-
50
-
51
- bundle config gems.example.com user:password
52
-
53
-
54
-
55
- For some sources, like a company Gemfury account, it may be easier to
56
- include the credentials in the Gemfile as part of the source URL.
57
-
58
-
59
-
60
- source "https://user:password@gems.example.com"
61
-
62
-
63
-
64
- Credentials in the source URL will take precedence over credentials set
65
- using config.
66
-
67
- RUBY
68
- If your application requires a specific Ruby version or engine, specify
69
- your requirements using the ruby method, with the following arguments.
70
- All parameters are OPTIONAL unless otherwise specified.
71
-
72
- VERSION (required)
73
- The version of Ruby that your application requires. If your application
74
- requires an alternate Ruby engine, such as JRuby, Rubinius or
75
- TruffleRuby, this should be the Ruby version that the engine is
76
- compatible with.
77
-
78
-
79
-
80
- ruby "1.9.3"
81
-
82
-
83
-
84
- ENGINE
85
- Each application may specify a Ruby engine. If an engine is specified,
86
- an engine version must also be specified.
87
-
88
- What exactly is an Engine? - A Ruby engine is an implementation of the
89
- Ruby language.
90
-
91
- o For background: the reference or original implementation of the
92
- Ruby programming language is called Matz's Ruby Interpreter
93
- https://en.wikipedia.org/wiki/Ruby_MRI, or MRI for short. This is
94
- named after Ruby creator Yukihiro Matsumoto, also known as Matz.
95
- MRI is also known as CRuby, because it is written in C. MRI is the
96
- most widely used Ruby engine.
97
-
98
- o Other implementations https://www.ruby-lang.org/en/about/ of Ruby
99
- exist. Some of the more well-known implementations include Rubinius
100
- https://rubinius.com/, and JRuby http://jruby.org/. Rubinius is an
101
- alternative implementation of Ruby written in Ruby. JRuby is an
102
- implementation of Ruby on the JVM, short for Java Virtual Machine.
103
-
104
-
105
-
106
- ENGINE VERSION
107
- Each application may specify a Ruby engine version. If an engine
108
- version is specified, an engine must also be specified. If the engine
109
- is "ruby" the engine version specified must match the Ruby version.
110
-
111
-
112
-
113
- ruby "1.8.7", :engine => "jruby", :engine_version => "1.6.7"
114
-
115
-
116
-
117
- PATCHLEVEL
118
- Each application may specify a Ruby patchlevel.
119
-
120
-
121
-
122
- ruby "2.0.0", :patchlevel => "247"
123
-
124
-
125
-
126
- GEMS
127
- Specify gem requirements using the gem method, with the following
128
- arguments. All parameters are OPTIONAL unless otherwise specified.
129
-
130
- NAME (required)
131
- For each gem requirement, list a single gem line.
132
-
133
-
134
-
135
- gem "nokogiri"
136
-
137
-
138
-
139
- VERSION
140
- Each gem MAY have one or more version specifiers.
141
-
142
-
143
-
144
- gem "nokogiri", ">= 1.4.2"
145
- gem "RedCloth", ">= 4.1.0", "< 4.2.0"
146
-
147
-
148
-
149
- REQUIRE AS
150
- Each gem MAY specify files that should be used when autorequiring via
151
- Bundler.require. You may pass an array with multiple files or true if
152
- file you want required has same name as gem or false to prevent any
153
- file from being autorequired.
154
-
155
-
156
-
157
- gem "redis", :require => ["redis/connection/hiredis", "redis"]
158
- gem "webmock", :require => false
159
- gem "byebug", :require => true
160
-
161
-
162
-
163
- The argument defaults to the name of the gem. For example, these are
164
- identical:
165
-
166
-
167
-
168
- gem "nokogiri"
169
- gem "nokogiri", :require => "nokogiri"
170
- gem "nokogiri", :require => true
171
-
172
-
173
-
174
- GROUPS
175
- Each gem MAY specify membership in one or more groups. Any gem that
176
- does not specify membership in any group is placed in the default
177
- group.
178
-
179
-
180
-
181
- gem "rspec", :group => :test
182
- gem "wirble", :groups => [:development, :test]
183
-
184
-
185
-
186
- The Bundler runtime allows its two main methods, Bundler.setup and
187
- Bundler.require, to limit their impact to particular groups.
188
-
189
-
190
-
191
- # setup adds gems to Ruby's load path
192
- Bundler.setup # defaults to all groups
193
- require "bundler/setup" # same as Bundler.setup
194
- Bundler.setup(:default) # only set up the _default_ group
195
- Bundler.setup(:test) # only set up the _test_ group (but `not` _default_)
196
- Bundler.setup(:default, :test) # set up the _default_ and _test_ groups, but no others
197
-
198
- # require requires all of the gems in the specified groups
199
- Bundler.require # defaults to the _default_ group
200
- Bundler.require(:default) # identical
201
- Bundler.require(:default, :test) # requires the _default_ and _test_ groups
202
- Bundler.require(:test) # requires the _test_ group
203
-
204
-
205
-
206
- The Bundler CLI allows you to specify a list of groups whose gems
207
- bundle install should not install with the without configuration.
208
-
209
- To specify multiple groups to ignore, specify a list of groups
210
- separated by spaces.
211
-
212
-
213
-
214
- bundle config set without test
215
- bundle config set without development test
216
-
217
-
218
-
219
- Also, calling Bundler.setup with no parameters, or calling require
220
- "bundler/setup" will setup all groups except for the ones you excluded
221
- via --without (since they are not available).
222
-
223
- Note that on bundle install, bundler downloads and evaluates all gems,
224
- in order to create a single canonical list of all of the required gems
225
- and their dependencies. This means that you cannot list different
226
- versions of the same gems in different groups. For more details, see
227
- Understanding Bundler https://bundler.io/rationale.html.
228
-
229
- PLATFORMS
230
- If a gem should only be used in a particular platform or set of
231
- platforms, you can specify them. Platforms are essentially identical to
232
- groups, except that you do not need to use the --without install-time
233
- flag to exclude groups of gems for other platforms.
234
-
235
- There are a number of Gemfile platforms:
236
-
237
- ruby C Ruby (MRI), Rubinius or TruffleRuby, but NOT Windows
238
-
239
- mri Same as ruby, but only C Ruby (MRI)
240
-
241
- mingw Windows 32 bit 'mingw32' platform (aka RubyInstaller)
242
-
243
- x64_mingw
244
- Windows 64 bit 'mingw32' platform (aka RubyInstaller x64)
245
-
246
- rbx Rubinius
247
-
248
- jruby JRuby
249
-
250
- truffleruby
251
- TruffleRuby
252
-
253
- mswin Windows
254
-
255
- You can restrict further by platform and version for all platforms
256
- except for rbx, jruby, truffleruby and mswin.
257
-
258
- To specify a version in addition to a platform, append the version
259
- number without the delimiter to the platform. For example, to specify
260
- that a gem should only be used on platforms with Ruby 2.3, use:
261
-
262
-
263
-
264
- ruby_23
265
-
266
-
267
-
268
- The full list of platforms and supported versions includes:
269
-
270
- ruby 1.8, 1.9, 2.0, 2.1, 2.2, 2.3, 2.4, 2.5, 2.6
271
-
272
- mri 1.8, 1.9, 2.0, 2.1, 2.2, 2.3, 2.4, 2.5, 2.6
273
-
274
- mingw 1.8, 1.9, 2.0, 2.1, 2.2, 2.3, 2.4, 2.5, 2.6
275
-
276
- x64_mingw
277
- 2.0, 2.1, 2.2, 2.3, 2.4, 2.5, 2.6
278
-
279
- As with groups, you can specify one or more platforms:
280
-
281
-
282
-
283
- gem "weakling", :platforms => :jruby
284
- gem "ruby-debug", :platforms => :mri_18
285
- gem "nokogiri", :platforms => [:mri_18, :jruby]
286
-
287
-
288
-
289
- All operations involving groups (bundle install bundle-install.1.html,
290
- Bundler.setup, Bundler.require) behave exactly the same as if any
291
- groups not matching the current platform were explicitly excluded.
292
-
293
- SOURCE
294
- You can select an alternate Rubygems repository for a gem using the
295
- ':source' option.
296
-
297
-
298
-
299
- gem "some_internal_gem", :source => "https://gems.example.com"
300
-
301
-
302
-
303
- This forces the gem to be loaded from this source and ignores any
304
- global sources declared at the top level of the file. If the gem does
305
- not exist in this source, it will not be installed.
306
-
307
- Bundler will search for child dependencies of this gem by first looking
308
- in the source selected for the parent, but if they are not found there,
309
- it will fall back on global sources using the ordering described in
310
- SOURCE PRIORITY.
311
-
312
- Selecting a specific source repository this way also suppresses the
313
- ambiguous gem warning described above in GLOBAL SOURCES (#source).
314
-
315
- Using the :source option for an individual gem will also make that
316
- source available as a possible global source for any other gems which
317
- do not specify explicit sources. Thus, when adding gems with explicit
318
- sources, it is recommended that you also ensure all other gems in the
319
- Gemfile are using explicit sources.
320
-
321
- GIT
322
- If necessary, you can specify that a gem is located at a particular git
323
- repository using the :git parameter. The repository can be accessed via
324
- several protocols:
325
-
326
- HTTP(S)
327
- gem "rails", :git => "https://github.com/rails/rails.git"
328
-
329
- SSH gem "rails", :git => "git@github.com:rails/rails.git"
330
-
331
- git gem "rails", :git => "git://github.com/rails/rails.git"
332
-
333
- If using SSH, the user that you use to run bundle install MUST have the
334
- appropriate keys available in their $HOME/.ssh.
335
-
336
- NOTE: http:// and git:// URLs should be avoided if at all possible.
337
- These protocols are unauthenticated, so a man-in-the-middle attacker
338
- can deliver malicious code and compromise your system. HTTPS and SSH
339
- are strongly preferred.
340
-
341
- The group, platforms, and require options are available and behave
342
- exactly the same as they would for a normal gem.
343
-
344
- A git repository SHOULD have at least one file, at the root of the
345
- directory containing the gem, with the extension .gemspec. This file
346
- MUST contain a valid gem specification, as expected by the gem build
347
- command.
348
-
349
- If a git repository does not have a .gemspec, bundler will attempt to
350
- create one, but it will not contain any dependencies, executables, or C
351
- extension compilation instructions. As a result, it may fail to
352
- properly integrate into your application.
353
-
354
- If a git repository does have a .gemspec for the gem you attached it
355
- to, a version specifier, if provided, means that the git repository is
356
- only valid if the .gemspec specifies a version matching the version
357
- specifier. If not, bundler will print a warning.
358
-
359
-
360
-
361
- gem "rails", "2.3.8", :git => "https://github.com/rails/rails.git"
362
- # bundle install will fail, because the .gemspec in the rails
363
- # repository's master branch specifies version 3.0.0
364
-
365
-
366
-
367
- If a git repository does not have a .gemspec for the gem you attached
368
- it to, a version specifier MUST be provided. Bundler will use this
369
- version in the simple .gemspec it creates.
370
-
371
- Git repositories support a number of additional options.
372
-
373
- branch, tag, and ref
374
- You MUST only specify at most one of these options. The default
375
- is :branch => "master". For example:
376
-
377
- gem "rails", :git => "https://github.com/rails/rails.git",
378
- :branch => "5-0-stable"
379
-
380
- gem "rails", :git => "https://github.com/rails/rails.git", :tag
381
- => "v5.0.0"
382
-
383
- gem "rails", :git => "https://github.com/rails/rails.git", :ref
384
- => "4aded"
385
-
386
- submodules
387
- For reference, a git submodule
388
- https://git-scm.com/book/en/v2/Git-Tools-Submodules lets you
389
- have another git repository within a subfolder of your
390
- repository. Specify :submodules => true to cause bundler to
391
- expand any submodules included in the git repository
392
-
393
- If a git repository contains multiple .gemspecs, each .gemspec
394
- represents a gem located at the same place in the file system as the
395
- .gemspec.
396
-
397
-
398
-
399
- |~rails [git root]
400
- | |-rails.gemspec [rails gem located here]
401
- |~actionpack
402
- | |-actionpack.gemspec [actionpack gem located here]
403
- |~activesupport
404
- | |-activesupport.gemspec [activesupport gem located here]
405
- |...
406
-
407
-
408
-
409
- To install a gem located in a git repository, bundler changes to the
410
- directory containing the gemspec, runs gem build name.gemspec and then
411
- installs the resulting gem. The gem build command, which comes standard
412
- with Rubygems, evaluates the .gemspec in the context of the directory
413
- in which it is located.
414
-
415
- GIT SOURCE
416
- A custom git source can be defined via the git_source method. Provide
417
- the source's name as an argument, and a block which receives a single
418
- argument and interpolates it into a string to return the full repo
419
- address:
420
-
421
-
422
-
423
- git_source(:stash){ |repo_name| "https://stash.corp.acme.pl/#{repo_name}.git" }
424
- gem 'rails', :stash => 'forks/rails'
425
-
426
-
427
-
428
- In addition, if you wish to choose a specific branch:
429
-
430
-
431
-
432
- gem "rails", :stash => "forks/rails", :branch => "branch_name"
433
-
434
-
435
-
436
- GITHUB
437
- NOTE: This shorthand should be avoided until Bundler 2.0, since it
438
- currently expands to an insecure git:// URL. This allows a
439
- man-in-the-middle attacker to compromise your system.
440
-
441
- If the git repository you want to use is hosted on GitHub and is
442
- public, you can use the :github shorthand to specify the github
443
- username and repository name (without the trailing ".git"), separated
444
- by a slash. If both the username and repository name are the same, you
445
- can omit one.
446
-
447
-
448
-
449
- gem "rails", :github => "rails/rails"
450
- gem "rails", :github => "rails"
451
-
452
-
453
-
454
- Are both equivalent to
455
-
456
-
457
-
458
- gem "rails", :git => "git://github.com/rails/rails.git"
459
-
460
-
461
-
462
- Since the github method is a specialization of git_source, it accepts a
463
- :branch named argument.
464
-
465
- GIST
466
- If the git repository you want to use is hosted as a Github Gist and is
467
- public, you can use the :gist shorthand to specify the gist identifier
468
- (without the trailing ".git").
469
-
470
-
471
-
472
- gem "the_hatch", :gist => "4815162342"
473
-
474
-
475
-
476
- Is equivalent to:
477
-
478
-
479
-
480
- gem "the_hatch", :git => "https://gist.github.com/4815162342.git"
481
-
482
-
483
-
484
- Since the gist method is a specialization of git_source, it accepts a
485
- :branch named argument.
486
-
487
- BITBUCKET
488
- If the git repository you want to use is hosted on Bitbucket and is
489
- public, you can use the :bitbucket shorthand to specify the bitbucket
490
- username and repository name (without the trailing ".git"), separated
491
- by a slash. If both the username and repository name are the same, you
492
- can omit one.
493
-
494
-
495
-
496
- gem "rails", :bitbucket => "rails/rails"
497
- gem "rails", :bitbucket => "rails"
498
-
499
-
500
-
501
- Are both equivalent to
502
-
503
-
504
-
505
- gem "rails", :git => "https://rails@bitbucket.org/rails/rails.git"
506
-
507
-
508
-
509
- Since the bitbucket method is a specialization of git_source, it
510
- accepts a :branch named argument.
511
-
512
- PATH
513
- You can specify that a gem is located in a particular location on the
514
- file system. Relative paths are resolved relative to the directory
515
- containing the Gemfile.
516
-
517
- Similar to the semantics of the :git option, the :path option requires
518
- that the directory in question either contains a .gemspec for the gem,
519
- or that you specify an explicit version that bundler should use.
520
-
521
- Unlike :git, bundler does not compile C extensions for gems specified
522
- as paths.
523
-
524
-
525
-
526
- gem "rails", :path => "vendor/rails"
527
-
528
-
529
-
530
- If you would like to use multiple local gems directly from the
531
- filesystem, you can set a global path option to the path containing the
532
- gem's files. This will automatically load gemspec files from
533
- subdirectories.
534
-
535
-
536
-
537
- path 'components' do
538
- gem 'admin_ui'
539
- gem 'public_ui'
540
- end
541
-
542
-
543
-
544
- BLOCK FORM OF SOURCE, GIT, PATH, GROUP and PLATFORMS
545
- The :source, :git, :path, :group, and :platforms options may be applied
546
- to a group of gems by using block form.
547
-
548
-
549
-
550
- source "https://gems.example.com" do
551
- gem "some_internal_gem"
552
- gem "another_internal_gem"
553
- end
554
-
555
- git "https://github.com/rails/rails.git" do
556
- gem "activesupport"
557
- gem "actionpack"
558
- end
559
-
560
- platforms :ruby do
561
- gem "ruby-debug"
562
- gem "sqlite3"
563
- end
564
-
565
- group :development, :optional => true do
566
- gem "wirble"
567
- gem "faker"
568
- end
569
-
570
-
571
-
572
- In the case of the group block form the :optional option can be given
573
- to prevent a group from being installed unless listed in the --with
574
- option given to the bundle install command.
575
-
576
- In the case of the git block form, the :ref, :branch, :tag, and
577
- :submodules options may be passed to the git method, and all gems in
578
- the block will inherit those options.
579
-
580
- The presence of a source block in a Gemfile also makes that source
581
- available as a possible global source for any other gems which do not
582
- specify explicit sources. Thus, when defining source blocks, it is
583
- recommended that you also ensure all other gems in the Gemfile are
584
- using explicit sources, either via source blocks or :source directives
585
- on individual gems.
586
-
587
- INSTALL_IF
588
- The install_if method allows gems to be installed based on a proc or
589
- lambda. This is especially useful for optional gems that can only be
590
- used if certain software is installed or some other conditions are met.
591
-
592
-
593
-
594
- install_if -> { RUBY_PLATFORM =~ /darwin/ } do
595
- gem "pasteboard"
596
- end
597
-
598
-
599
-
600
- GEMSPEC
601
- The .gemspec http://guides.rubygems.org/specification-reference/ file
602
- is where you provide metadata about your gem to Rubygems. Some required
603
- Gemspec attributes include the name, description, and homepage of your
604
- gem. This is also where you specify the dependencies your gem needs to
605
- run.
606
-
607
- If you wish to use Bundler to help install dependencies for a gem while
608
- it is being developed, use the gemspec method to pull in the
609
- dependencies listed in the .gemspec file.
610
-
611
- The gemspec method adds any runtime dependencies as gem requirements in
612
- the default group. It also adds development dependencies as gem
613
- requirements in the development group. Finally, it adds a gem
614
- requirement on your project (:path => '.'). In conjunction with
615
- Bundler.setup, this allows you to require project files in your test
616
- code as you would if the project were installed as a gem; you need not
617
- manipulate the load path manually or require project files via relative
618
- paths.
619
-
620
- The gemspec method supports optional :path, :glob, :name, and
621
- :development_group options, which control where bundler looks for the
622
- .gemspec, the glob it uses to look for the gemspec (defaults to:
623
- "{,,/*}.gemspec"), what named .gemspec it uses (if more than one is
624
- present), and which group development dependencies are included in.
625
-
626
- When a gemspec dependency encounters version conflicts during
627
- resolution, the local version under development will always be selected
628
- -- even if there are remote versions that better match other
629
- requirements for the gemspec gem.
630
-
631
- SOURCE PRIORITY
632
- When attempting to locate a gem to satisfy a gem requirement, bundler
633
- uses the following priority order:
634
-
635
- 1. The source explicitly attached to the gem (using :source, :path, or
636
- :git)
637
-
638
- 2. For implicit gems (dependencies of explicit gems), any source, git,
639
- or path repository declared on the parent. This results in bundler
640
- prioritizing the ActiveSupport gem from the Rails git repository
641
- over ones from rubygems.org
642
-
643
- 3. The sources specified via global source lines, searching each
644
- source in your Gemfile from last added to first added.
645
-
646
-
647
-
648
-
649
-
650
-
651
- July 2020 GEMFILE(5)