Class: Bundler::CLI::Config::Base
- Inherits:
-
Object
- Object
- Bundler::CLI::Config::Base
- Defined in:
- lib/bundler/cli/config.rb
Instance Attribute Summary collapse
-
#name ⇒ Object
readonly
Returns the value of attribute name.
-
#options ⇒ Object
readonly
Returns the value of attribute options.
-
#scope ⇒ Object
readonly
Returns the value of attribute scope.
-
#thor ⇒ Object
readonly
Returns the value of attribute thor.
-
#value ⇒ Object
readonly
Returns the value of attribute value.
Instance Method Summary collapse
- #confirm(name) ⇒ Object
- #confirm_all ⇒ Object
- #explicit_scope? ⇒ Boolean
-
#initialize(options, name, value, thor) ⇒ Base
constructor
A new instance of Base.
- #message ⇒ Object
- #new_value ⇒ Object
- #run ⇒ Object
- #show_pretty_values_for(setting) ⇒ Object
- #validate_scope! ⇒ Object
- #warn_unused_scope(msg) ⇒ Object
Constructor Details
permalink #initialize(options, name, value, thor) ⇒ Base
Returns a new instance of Base.
63 64 65 66 67 68 69 70 |
# File 'lib/bundler/cli/config.rb', line 63 def initialize(, name, value, thor) @options = @name = name value = Array(value) @value = value.empty? ? nil : value.join(" ") @thor = thor validate_scope! end |
Instance Attribute Details
permalink #name ⇒ Object (readonly)
Returns the value of attribute name.
61 62 63 |
# File 'lib/bundler/cli/config.rb', line 61 def name @name end |
permalink #options ⇒ Object (readonly)
Returns the value of attribute options.
61 62 63 |
# File 'lib/bundler/cli/config.rb', line 61 def @options end |
permalink #scope ⇒ Object (readonly)
Returns the value of attribute scope.
61 62 63 |
# File 'lib/bundler/cli/config.rb', line 61 def scope @scope end |
permalink #thor ⇒ Object (readonly)
Returns the value of attribute thor.
61 62 63 |
# File 'lib/bundler/cli/config.rb', line 61 def thor @thor end |
permalink #value ⇒ Object (readonly)
Returns the value of attribute value.
61 62 63 |
# File 'lib/bundler/cli/config.rb', line 61 def value @value end |
Instance Method Details
permalink #confirm(name) ⇒ Object
[View source]
125 126 127 128 |
# File 'lib/bundler/cli/config.rb', line 125 def confirm(name) Bundler.ui.confirm "Settings for `#{name}` in order of priority. The top value will be used" show_pretty_values_for(name) end |
permalink #confirm_all ⇒ Object
[View source]
107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 |
# File 'lib/bundler/cli/config.rb', line 107 def confirm_all if @options[:parseable] thor.with_padding do Bundler.settings.all.each do |setting| val = Bundler.settings[setting] Bundler.ui.info "#{setting}=#{val}" end end else Bundler.ui.confirm "Settings are listed in order of priority. The top value will be used.\n" Bundler.settings.all.each do |setting| Bundler.ui.confirm setting show_pretty_values_for(setting) Bundler.ui.confirm "" end end end |
permalink #explicit_scope? ⇒ Boolean
168 169 170 |
# File 'lib/bundler/cli/config.rb', line 168 def explicit_scope? @explicit_scope end |
permalink #message ⇒ Object
[View source]
139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 |
# File 'lib/bundler/cli/config.rb', line 139 def locations = Bundler.settings.locations(name) if @options[:parseable] "#{name}=#{new_value}" if new_value elsif scope == "global" if !locations[:local].nil? "Your application has set #{name} to #{locations[:local].inspect}. " \ "This will override the global value you are currently setting" elsif locations[:env] "You have a bundler environment variable for #{name} set to " \ "#{locations[:env].inspect}. This will take precedence over the global value you are setting" elsif !locations[:global].nil? && locations[:global] != value "You are replacing the current global value of #{name}, which is currently " \ "#{locations[:global].inspect}" end elsif scope == "local" && !locations[:local].nil? && locations[:local] != value "You are replacing the current local value of #{name}, which is currently " \ "#{locations[:local].inspect}" end end |
permalink #new_value ⇒ Object
[View source]
130 131 132 133 134 135 136 137 |
# File 'lib/bundler/cli/config.rb', line 130 def new_value pathname = Pathname.new(value) if name.start_with?("local.") && pathname.directory? pathname..to_s else value end end |
permalink #run ⇒ Object
[View source]
72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 |
# File 'lib/bundler/cli/config.rb', line 72 def run unless name warn_unused_scope "Ignoring --#{scope}" confirm_all return end if [:delete] if !explicit_scope? || scope != "global" Bundler.settings.set_local(name, nil) end if !explicit_scope? || scope != "local" Bundler.settings.set_global(name, nil) end return end if value.nil? warn_unused_scope "Ignoring --#{scope} since no value to set was given" if [:parseable] if value = Bundler.settings[name] Bundler.ui.info("#{name}=#{value}") end return end confirm(name) return end Bundler.ui.info() if Bundler.settings.send("set_#{scope}", name, new_value) end |
permalink #show_pretty_values_for(setting) ⇒ Object
[View source]
160 161 162 163 164 165 166 |
# File 'lib/bundler/cli/config.rb', line 160 def show_pretty_values_for(setting) thor.with_padding do Bundler.settings.pretty_values_for(setting).each do |line| Bundler.ui.info line end end end |
permalink #validate_scope! ⇒ Object
[View source]
179 180 181 182 183 184 185 186 187 188 189 190 191 192 |
# File 'lib/bundler/cli/config.rb', line 179 def validate_scope! @explicit_scope = true scopes = %w[global local].select {|s| [s] } case scopes.size when 0 @scope = inside_app? ? "local" : "global" @explicit_scope = false when 1 @scope = scopes.first else raise InvalidOption, "The options #{scopes.join " and "} were specified. Please only use one of the switches at a time." end end |
permalink #warn_unused_scope(msg) ⇒ Object
[View source]
172 173 174 175 176 177 |
# File 'lib/bundler/cli/config.rb', line 172 def warn_unused_scope(msg) return unless explicit_scope? return if [:parseable] Bundler.ui.warn(msg) end |