Module: Gem::LocalRemoteOptions

Overview

Mixin methods for local and remote Gem::Command options.

Instance Method Summary collapse

Instance Method Details

#accept_uri_httpObject

Allows Gem::OptionParser to handle HTTP URIs.



19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
# File 'lib/rubygems/local_remote_options.rb', line 19

def accept_uri_http
  Gem::OptionParser.accept URI::HTTP do |value|
    begin
      uri = URI.parse value
    rescue URI::InvalidURIError
      raise Gem::OptionParser::InvalidArgument, value
    end

    valid_uri_schemes = ["http", "https", "file", "s3"]
    unless valid_uri_schemes.include?(uri.scheme)
      msg = "Invalid uri scheme for #{value}\nPreface URLs with one of #{valid_uri_schemes.map{|s| "#{s}://" }}"
      raise ArgumentError, msg
    end

    value
  end
end

#add_bulk_threshold_optionObject

Add the –bulk-threshold option



66
67
68
69
70
71
72
73
# File 'lib/rubygems/local_remote_options.rb', line 66

def add_bulk_threshold_option
  add_option(:"Local/Remote", '-B', '--bulk-threshold COUNT',
             "Threshold for switching to bulk",
             "synchronization (default #{Gem.configuration.bulk_threshold})") do
    |value, options|
    Gem.configuration.bulk_threshold = value.to_i
  end
end

#add_clear_sources_optionObject

Add the –clear-sources option



78
79
80
81
82
83
84
85
# File 'lib/rubygems/local_remote_options.rb', line 78

def add_clear_sources_option
  add_option(:"Local/Remote", '--clear-sources',
             'Clear the gem sources') do |value, options|

    Gem.sources = nil
    options[:sources_cleared] = true
  end
end

#add_local_remote_optionsObject

Add local/remote options to the command line parser.



40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
# File 'lib/rubygems/local_remote_options.rb', line 40

def add_local_remote_options
  add_option(:"Local/Remote", '-l', '--local',
             'Restrict operations to the LOCAL domain') do |value, options|
    options[:domain] = :local
  end

  add_option(:"Local/Remote", '-r', '--remote',
    'Restrict operations to the REMOTE domain') do |value, options|
    options[:domain] = :remote
  end

  add_option(:"Local/Remote", '-b', '--both',
             'Allow LOCAL and REMOTE operations') do |value, options|
    options[:domain] = :both
  end

  add_bulk_threshold_option
  add_clear_sources_option
  add_source_option
  add_proxy_option
  add_update_sources_option
end

#add_proxy_optionObject

Add the –http-proxy option



90
91
92
93
94
95
96
97
98
# File 'lib/rubygems/local_remote_options.rb', line 90

def add_proxy_option
  accept_uri_http

  add_option(:"Local/Remote", '-p', '--[no-]http-proxy [URL]', URI::HTTP,
             'Use HTTP proxy for remote operations') do |value, options|
    options[:http_proxy] = (value == false) ? :no_proxy : value
    Gem.configuration[:http_proxy] = options[:http_proxy]
  end
end

#add_source_optionObject

Add the –source option



103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
# File 'lib/rubygems/local_remote_options.rb', line 103

def add_source_option
  accept_uri_http

  add_option(:"Local/Remote", '-s', '--source URL', URI::HTTP,
             'Append URL to list of remote gem sources') do |source, options|

    source << '/' if source !~ /\/\z/

    if options.delete :sources_cleared
      Gem.sources = [source]
    else
      Gem.sources << source unless Gem.sources.include?(source)
    end
  end
end

#add_update_sources_optionObject

Add the –update-sources option



122
123
124
125
126
127
# File 'lib/rubygems/local_remote_options.rb', line 122

def add_update_sources_option
  add_option(:Deprecated, '-u', '--[no-]update-sources',
             'Update local source cache') do |value, options|
    Gem.configuration.update_sources = value
  end
end

#both?Boolean

Is fetching of local and remote information enabled?

Returns:

  • (Boolean)


132
133
134
# File 'lib/rubygems/local_remote_options.rb', line 132

def both?
  options[:domain] == :both
end

#local?Boolean

Is local fetching enabled?

Returns:

  • (Boolean)


139
140
141
# File 'lib/rubygems/local_remote_options.rb', line 139

def local?
  options[:domain] == :local || options[:domain] == :both
end

#remote?Boolean

Is remote fetching enabled?

Returns:

  • (Boolean)


146
147
148
# File 'lib/rubygems/local_remote_options.rb', line 146

def remote?
  options[:domain] == :remote || options[:domain] == :both
end