Module: Gem::LocalRemoteOptions

Overview

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

Instance Method Summary collapse

Instance Method Details

#accept_uri_httpObject

Allows OptionParser to handle HTTP URIs.



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

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

    unless ['http', 'https', 'file'].include?(uri.scheme)
       raise OptionParser::InvalidArgument, value
    end

    value
  end
end

#add_bulk_threshold_optionObject

Add the –bulk-threshold option



63
64
65
66
67
68
69
70
# File 'lib/rubygems/local_remote_options.rb', line 63

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



75
76
77
78
79
80
81
82
# File 'lib/rubygems/local_remote_options.rb', line 75

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.



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

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



87
88
89
90
91
92
93
94
95
# File 'lib/rubygems/local_remote_options.rb', line 87

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



100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
# File 'lib/rubygems/local_remote_options.rb', line 100

def add_source_option
  accept_uri_http

  add_option(:"Local/Remote", '--source URL', URI::HTTP,
             'Add URL as a remote source for gems') do |source, options|

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

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

#add_update_sources_optionObject

Add the –update-sources option



119
120
121
122
123
124
# File 'lib/rubygems/local_remote_options.rb', line 119

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)


129
130
131
# File 'lib/rubygems/local_remote_options.rb', line 129

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

#local?Boolean

Is local fetching enabled?

Returns:

  • (Boolean)


136
137
138
# File 'lib/rubygems/local_remote_options.rb', line 136

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

#remote?Boolean

Is remote fetching enabled?

Returns:

  • (Boolean)


143
144
145
# File 'lib/rubygems/local_remote_options.rb', line 143

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