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.



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

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



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

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



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

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.



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

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
# 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 << "/" unless source.end_with?("/")

    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



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

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)


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

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

#local?Boolean

Is local fetching enabled?

Returns:

  • (Boolean)


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

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

#remote?Boolean

Is remote fetching enabled?

Returns:

  • (Boolean)


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

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