Class: Gem::StreamUI

Inherits:
Object
  • Object
show all
Extended by:
Deprecate
Defined in:
lib/rubygems/user_interaction.rb

Overview

Gem::StreamUI implements a simple stream based user interface.

Direct Known Subclasses

ConsoleUI, MockGemUi, SilentUI

Defined Under Namespace

Classes: SilentDownloadReporter, SilentProgressReporter, SimpleProgressReporter, ThreadedDownloadReporter, VerboseProgressReporter

Instance Attribute Summary collapse

Instance Method Summary collapse

Methods included from Deprecate

deprecate, skip, skip=, skip_during

Constructor Details

#initialize(in_stream, out_stream, err_stream = STDERR, usetty = true) ⇒ StreamUI

Creates a new StreamUI wrapping in_stream for user input, out_stream for standard output, err_stream for error output. If usetty is true then special operations (like asking for passwords) will use the TTY commands to disable character echo.



197
198
199
200
201
202
# File 'lib/rubygems/user_interaction.rb', line 197

def initialize(in_stream, out_stream, err_stream=STDERR, usetty=true)
  @ins = in_stream
  @outs = out_stream
  @errs = err_stream
  @usetty = usetty
end

Instance Attribute Details

#errsObject (readonly)

The error stream



189
190
191
# File 'lib/rubygems/user_interaction.rb', line 189

def errs
  @errs
end

#insObject (readonly)

The input stream



179
180
181
# File 'lib/rubygems/user_interaction.rb', line 179

def ins
  @ins
end

#outsObject (readonly)

The output stream



184
185
186
# File 'lib/rubygems/user_interaction.rb', line 184

def outs
  @outs
end

Instance Method Details

#_gets_noechoObject



321
322
323
324
# File 'lib/rubygems/user_interaction.rb', line 321

def _gets_noecho
  require_io_console
  @ins.noecho {@ins.gets}
end

#alert(statement, question = nil) ⇒ Object

Display an informational alert. Will ask question if it is not nil.



336
337
338
339
# File 'lib/rubygems/user_interaction.rb', line 336

def alert(statement, question=nil)
  @outs.puts "INFO:  #{statement}"
  ask(question) if question
end

#alert_error(statement, question = nil) ⇒ Object

Display an error message in a location expected to get error messages. Will ask question if it is not nil.



353
354
355
356
# File 'lib/rubygems/user_interaction.rb', line 353

def alert_error(statement, question=nil)
  @errs.puts "ERROR:  #{statement}"
  ask(question) if question
end

#alert_warning(statement, question = nil) ⇒ Object

Display a warning on stderr. Will ask question if it is not nil.



344
345
346
347
# File 'lib/rubygems/user_interaction.rb', line 344

def alert_warning(statement, question=nil)
  @errs.puts "WARNING:  #{statement}"
  ask(question) if question
end

#ask(question) ⇒ Object

Ask a question. Returns an answer if connected to a tty, nil otherwise.



285
286
287
288
289
290
291
292
293
294
# File 'lib/rubygems/user_interaction.rb', line 285

def ask(question)
  return nil if not tty?

  @outs.print(question + "  ")
  @outs.flush

  result = @ins.gets
  result.chomp! if result
  result
end

#ask_for_password(question) ⇒ Object

Ask for a password. Does not echo response to terminal.



299
300
301
302
303
304
305
306
307
308
309
# File 'lib/rubygems/user_interaction.rb', line 299

def ask_for_password(question)
  return nil if not tty?

  @outs.print(question, "  ")
  @outs.flush

  password = _gets_noecho
  @outs.puts
  password.chomp! if password
  password
end

#ask_yes_no(question, default = nil) ⇒ Object

Ask a question. Returns a true for yes, false for no. If not connected to a tty, raises an exception if default is nil, otherwise returns default.



249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
# File 'lib/rubygems/user_interaction.rb', line 249

def ask_yes_no(question, default=nil)
  unless tty?
    if default.nil?
      raise Gem::OperationNotSupportedError,
            "Not connected to a tty and no default specified"
    else
      return default
    end
  end

  default_answer = case default
                   when nil
                     'yn'
                   when true
                     'Yn'
                   else
                     'yN'
                   end

  result = nil

  while result.nil? do
    result = case ask "#{question} [#{default_answer}]"
             when /^y/i then true
             when /^n/i then false
             when /^$/  then default
             else            nil
             end
  end

  return result
end

#backtrace(exception) ⇒ Object

Prints a formatted backtrace to the errors stream if backtraces are enabled.



215
216
217
218
219
# File 'lib/rubygems/user_interaction.rb', line 215

def backtrace(exception)
  return unless Gem.configuration.backtrace

  @errs.puts "\t#{exception.backtrace.join "\n\t"}"
end

#choose_from_list(question, list) ⇒ Object

Choose from a list of options. question is a prompt displayed above the list. list is a list of option strings. Returns the pair [option_name, option_index].



226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
# File 'lib/rubygems/user_interaction.rb', line 226

def choose_from_list(question, list)
  @outs.puts question

  list.each_with_index do |item, index|
    @outs.puts " #{index+1}. #{item}"
  end

  @outs.print "> "
  @outs.flush

  result = @ins.gets

  return nil, nil unless result

  result = result.strip.to_i - 1
  return list[result], result
end

#closeObject



375
376
# File 'lib/rubygems/user_interaction.rb', line 375

def close
end

#debug(statement) ⇒ Object

Display a debug message on the same location as error messages.



361
362
363
# File 'lib/rubygems/user_interaction.rb', line 361

def debug(statement)
  @errs.puts statement
end

#download_reporter(*args) ⇒ Object

Return a download reporter object chosen from the current verbosity



514
515
516
517
518
519
520
# File 'lib/rubygems/user_interaction.rb', line 514

def download_reporter(*args)
  if [nil, false].include?(Gem.configuration.verbose) || !@outs.tty?
    SilentDownloadReporter.new(@outs, *args)
  else
    ThreadedDownloadReporter.new(@outs, *args)
  end
end

#progress_reporter(*args) ⇒ Object

Return a progress reporter object chosen from the current verbosity.



381
382
383
384
385
386
387
388
389
390
# File 'lib/rubygems/user_interaction.rb', line 381

def progress_reporter(*args)
  case Gem.configuration.verbose
  when nil, false
    SilentProgressReporter.new(@outs, *args)
  when true
    SimpleProgressReporter.new(@outs, *args)
  else
    VerboseProgressReporter.new(@outs, *args)
  end
end

#require_io_consoleObject



311
312
313
314
315
316
317
318
319
# File 'lib/rubygems/user_interaction.rb', line 311

def require_io_console
  @require_io_console ||= begin
    begin
      require 'io/console'
    rescue LoadError
    end
    true
  end
end

#say(statement = "") ⇒ Object

Display a statement.



329
330
331
# File 'lib/rubygems/user_interaction.rb', line 329

def say(statement="")
  @outs.puts statement
end

#terminate_interaction(status = 0) ⇒ Object

Terminate the application with exit code status, running any exit handlers that might have been defined.



370
371
372
373
# File 'lib/rubygems/user_interaction.rb', line 370

def terminate_interaction(status = 0)
  close
  raise Gem::SystemExitException, status
end

#tty?Boolean

Returns true if TTY methods should be used on this StreamUI.

Returns:

  • (Boolean)


207
208
209
# File 'lib/rubygems/user_interaction.rb', line 207

def tty?
  @usetty && @ins.tty?
end