2016-02-01 07:43:26 -05:00
|
|
|
# frozen_string_literal: true
|
2007-11-10 02:48:56 -05:00
|
|
|
#--
|
|
|
|
# Copyright 2006 by Chad Fowler, Rich Kilmer, Jim Weirich and others.
|
|
|
|
# All rights reserved.
|
|
|
|
# See LICENSE.txt for permissions.
|
|
|
|
#++
|
|
|
|
|
|
|
|
require 'rubygems'
|
2011-01-19 16:23:04 -05:00
|
|
|
|
|
|
|
# forward-declare
|
|
|
|
|
|
|
|
module Gem::Security # :nodoc:
|
|
|
|
class Policy # :nodoc:
|
|
|
|
end
|
|
|
|
end
|
2007-11-10 02:48:56 -05:00
|
|
|
|
|
|
|
##
|
|
|
|
# Mixin methods for install and update options for Gem::Commands
|
2009-06-09 17:38:59 -04:00
|
|
|
|
2007-11-10 02:48:56 -05:00
|
|
|
module Gem::InstallUpdateOptions
|
|
|
|
|
2009-06-09 17:38:59 -04:00
|
|
|
##
|
2007-11-10 02:48:56 -05:00
|
|
|
# Add the install/update options to the option parser.
|
2009-06-09 17:38:59 -04:00
|
|
|
|
2007-11-10 02:48:56 -05:00
|
|
|
def add_install_update_options
|
2012-11-29 01:52:18 -05:00
|
|
|
# TODO: use @parser.accept
|
2007-11-10 02:48:56 -05:00
|
|
|
OptionParser.accept Gem::Security::Policy do |value|
|
2011-01-19 16:23:04 -05:00
|
|
|
require 'rubygems/security'
|
|
|
|
|
2013-09-14 04:59:02 -04:00
|
|
|
raise OptionParser::InvalidArgument, 'OpenSSL not installed' unless
|
|
|
|
defined?(Gem::Security::HighSecurity)
|
|
|
|
|
2007-11-10 02:48:56 -05:00
|
|
|
value = Gem::Security::Policies[value]
|
2011-01-19 16:23:04 -05:00
|
|
|
valid = Gem::Security::Policies.keys.sort
|
|
|
|
message = "#{value} (#{valid.join ', '} are valid)"
|
|
|
|
raise OptionParser::InvalidArgument, message if value.nil?
|
2007-11-10 02:48:56 -05:00
|
|
|
value
|
|
|
|
end
|
|
|
|
|
|
|
|
add_option(:"Install/Update", '-i', '--install-dir DIR',
|
|
|
|
'Gem repository directory to get installed',
|
|
|
|
'gems') do |value, options|
|
|
|
|
options[:install_dir] = File.expand_path(value)
|
|
|
|
end
|
|
|
|
|
2008-03-31 18:40:06 -04:00
|
|
|
add_option(:"Install/Update", '-n', '--bindir DIR',
|
2012-11-29 01:52:18 -05:00
|
|
|
'Directory where binary files are',
|
|
|
|
'located') do |value, options|
|
2008-03-31 18:40:06 -04:00
|
|
|
options[:bin_dir] = File.expand_path(value)
|
|
|
|
end
|
|
|
|
|
2012-11-29 01:52:18 -05:00
|
|
|
add_option(:"Install/Update", '--[no-]document [TYPES]', Array,
|
|
|
|
'Generate documentation for installed gems',
|
|
|
|
'List the documentation types you wish to',
|
|
|
|
'generate. For example: rdoc,ri') do |value, options|
|
|
|
|
options[:document] = case value
|
|
|
|
when nil then %w[ri]
|
|
|
|
when false then []
|
|
|
|
else value
|
|
|
|
end
|
2007-11-10 02:48:56 -05:00
|
|
|
end
|
|
|
|
|
2014-09-13 23:30:02 -04:00
|
|
|
add_option(:"Install/Update", '--build-root DIR',
|
|
|
|
'Temporary installation root. Useful for building',
|
|
|
|
'packages. Do not use this when installing remote gems.') do |value, options|
|
|
|
|
options[:build_root] = File.expand_path(value)
|
|
|
|
end
|
|
|
|
|
|
|
|
add_option(:"Install/Update", '--vendor',
|
|
|
|
'Install gem into the vendor directory.',
|
|
|
|
'Only for use by gem repackagers.') do |value, options|
|
|
|
|
unless Gem.vendor_dir then
|
|
|
|
raise OptionParser::InvalidOption.new 'your platform is not supported'
|
|
|
|
end
|
|
|
|
|
|
|
|
options[:vendor] = true
|
|
|
|
options[:install_dir] = Gem.vendor_dir
|
|
|
|
end
|
|
|
|
|
2012-11-29 01:52:18 -05:00
|
|
|
add_option(:"Install/Update", '-N', '--no-document',
|
|
|
|
'Disable documentation generation') do |value, options|
|
|
|
|
options[:document] = []
|
|
|
|
end
|
|
|
|
|
|
|
|
add_option(:Deprecated, '--[no-]rdoc',
|
|
|
|
'Generate RDoc for installed gems',
|
|
|
|
'Use --document instead') do |value, options|
|
|
|
|
if value then
|
|
|
|
options[:document] << 'rdoc'
|
|
|
|
else
|
|
|
|
options[:document].delete 'rdoc'
|
|
|
|
end
|
|
|
|
|
|
|
|
options[:document].uniq!
|
|
|
|
end
|
|
|
|
|
|
|
|
add_option(:Deprecated, '--[no-]ri',
|
|
|
|
'Generate ri data for installed gems.',
|
|
|
|
'Use --document instead') do |value, options|
|
|
|
|
if value then
|
|
|
|
options[:document] << 'ri'
|
|
|
|
else
|
|
|
|
options[:document].delete 'ri'
|
|
|
|
end
|
|
|
|
|
|
|
|
options[:document].uniq!
|
2007-11-10 02:48:56 -05:00
|
|
|
end
|
|
|
|
|
2008-02-10 03:00:19 -05:00
|
|
|
add_option(:"Install/Update", '-E', '--[no-]env-shebang',
|
2007-11-10 02:48:56 -05:00
|
|
|
"Rewrite the shebang line on installed",
|
|
|
|
"scripts to use /usr/bin/env") do |value, options|
|
|
|
|
options[:env_shebang] = value
|
|
|
|
end
|
|
|
|
|
|
|
|
add_option(:"Install/Update", '-f', '--[no-]force',
|
|
|
|
'Force gem to install, bypassing dependency',
|
|
|
|
'checks') do |value, options|
|
|
|
|
options[:force] = value
|
|
|
|
end
|
|
|
|
|
|
|
|
add_option(:"Install/Update", '-w', '--[no-]wrappers',
|
|
|
|
'Use bin wrappers for executables',
|
|
|
|
'Not available on dosish platforms') do |value, options|
|
|
|
|
options[:wrappers] = value
|
|
|
|
end
|
|
|
|
|
|
|
|
add_option(:"Install/Update", '-P', '--trust-policy POLICY',
|
|
|
|
Gem::Security::Policy,
|
|
|
|
'Specify gem trust policy') do |value, options|
|
|
|
|
options[:security_policy] = value
|
|
|
|
end
|
|
|
|
|
|
|
|
add_option(:"Install/Update", '--ignore-dependencies',
|
|
|
|
'Do not install any required dependent gems') do |value, options|
|
|
|
|
options[:ignore_dependencies] = value
|
|
|
|
end
|
|
|
|
|
2007-12-20 03:39:12 -05:00
|
|
|
add_option(:"Install/Update", '--[no-]format-executable',
|
|
|
|
'Make installed executable names match ruby.',
|
|
|
|
'If ruby is ruby18, foo_exec will be',
|
|
|
|
'foo_exec18') do |value, options|
|
|
|
|
options[:format_executable] = value
|
|
|
|
end
|
2008-06-17 18:04:18 -04:00
|
|
|
|
2008-06-25 22:06:00 -04:00
|
|
|
add_option(:"Install/Update", '--[no-]user-install',
|
|
|
|
'Install in user\'s home directory instead',
|
2010-02-21 21:52:35 -05:00
|
|
|
'of GEM_HOME.') do |value, options|
|
2008-06-25 22:06:00 -04:00
|
|
|
options[:user_install] = value
|
|
|
|
end
|
|
|
|
|
2008-06-17 18:04:18 -04:00
|
|
|
add_option(:"Install/Update", "--development",
|
2012-11-29 01:52:18 -05:00
|
|
|
"Install additional development",
|
2008-06-17 18:04:18 -04:00
|
|
|
"dependencies") do |value, options|
|
|
|
|
options[:development] = true
|
2012-11-29 01:52:18 -05:00
|
|
|
options[:dev_shallow] = true
|
|
|
|
end
|
|
|
|
|
|
|
|
add_option(:"Install/Update", "--development-all",
|
|
|
|
"Install development dependencies for all",
|
|
|
|
"gems (including dev deps themselves)") do |value, options|
|
|
|
|
options[:development] = true
|
|
|
|
options[:dev_shallow] = false
|
2008-06-17 18:04:18 -04:00
|
|
|
end
|
2011-01-18 19:08:49 -05:00
|
|
|
|
|
|
|
add_option(:"Install/Update", "--conservative",
|
|
|
|
"Don't attempt to upgrade gems already",
|
|
|
|
"meeting version requirement") do |value, options|
|
|
|
|
options[:conservative] = true
|
2012-11-29 01:52:18 -05:00
|
|
|
options[:minimal_deps] = true
|
|
|
|
end
|
|
|
|
|
|
|
|
add_option(:"Install/Update", "--minimal-deps",
|
|
|
|
"Don't upgrade any dependencies that already",
|
|
|
|
"meet version requirements") do |value, options|
|
|
|
|
options[:minimal_deps] = true
|
2011-01-18 19:08:49 -05:00
|
|
|
end
|
2016-02-01 07:43:26 -05:00
|
|
|
|
|
|
|
add_option(:"Install/Update", "--[no-]post-install-message",
|
|
|
|
"Print post install message") do |value, options|
|
|
|
|
options[:post_install_message] = value
|
|
|
|
end
|
2016-03-03 19:29:40 -05:00
|
|
|
|
2016-04-06 02:01:14 -04:00
|
|
|
add_option(:"Install/Update", '-g', '--file [FILE]',
|
|
|
|
'Read from a gem dependencies API file and',
|
|
|
|
'install the listed gems') do |v,o|
|
|
|
|
v = Gem::GEM_DEP_FILES.find do |file|
|
|
|
|
File.exist? file
|
|
|
|
end unless v
|
|
|
|
|
|
|
|
unless v then
|
|
|
|
message = v ? v : "(tried #{Gem::GEM_DEP_FILES.join ', '})"
|
|
|
|
|
|
|
|
raise OptionParser::InvalidArgument,
|
|
|
|
"cannot find gem dependencies file #{message}"
|
|
|
|
end
|
|
|
|
|
|
|
|
options[:gemdeps] = v
|
|
|
|
end
|
|
|
|
|
|
|
|
add_option(:"Install/Update", '--without GROUPS', Array,
|
|
|
|
'Omit the named groups (comma separated)',
|
|
|
|
'when installing from a gem dependencies',
|
|
|
|
'file') do |v,o|
|
|
|
|
options[:without_groups].concat v.map { |without| without.intern }
|
|
|
|
end
|
|
|
|
|
|
|
|
add_option(:"Install/Update", '--default',
|
|
|
|
'Add the gem\'s full specification to',
|
|
|
|
'specifications/default and extract only its bin') do |v,o|
|
|
|
|
options[:install_as_default] = v
|
|
|
|
end
|
|
|
|
|
|
|
|
add_option(:"Install/Update", '--explain',
|
|
|
|
'Rather than install the gems, indicate which would',
|
|
|
|
'be installed') do |v,o|
|
|
|
|
options[:explain] = v
|
|
|
|
end
|
|
|
|
|
|
|
|
add_option(:"Install/Update", '--[no-]lock',
|
|
|
|
'Create a lock file (when used with -g/--file)') do |v,o|
|
|
|
|
options[:lock] = v
|
|
|
|
end
|
|
|
|
|
|
|
|
add_option(:"Install/Update", '--[no-]suggestions',
|
|
|
|
'Suggest alternates when gems are not found') do |v,o|
|
|
|
|
options[:suggest_alternate] = v
|
|
|
|
end
|
|
|
|
|
2007-11-10 02:48:56 -05:00
|
|
|
end
|
|
|
|
|
2009-06-09 17:38:59 -04:00
|
|
|
##
|
2007-11-10 02:48:56 -05:00
|
|
|
# Default options for the gem install command.
|
2009-06-09 17:38:59 -04:00
|
|
|
|
2007-11-10 02:48:56 -05:00
|
|
|
def install_update_defaults_str
|
2012-11-29 01:52:18 -05:00
|
|
|
'--document=rdoc,ri --wrappers'
|
2007-11-10 02:48:56 -05:00
|
|
|
end
|
|
|
|
|
|
|
|
end
|
|
|
|
|