/usr/lib/ruby/vendor_ruby/mercenary/presenter.rb is in ruby-mercenary 0.3.4-1.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 | module Mercenary
class Presenter
attr_accessor :command
# Public: Make a new Presenter
#
# command - a Mercenary::Command to present
#
# Returns nothing
def initialize(command)
@command = command
end
# Public: Builds a string representation of the command usage
#
# Returns the string representation of the command usage
def usage_presentation
" #{command.syntax}"
end
# Public: Builds a string representation of the options
#
# Returns the string representation of the options
def options_presentation
return nil unless command.options.size > 0
command.options.map(&:to_s).join("\n")
end
# Public: Builds a string representation of the subcommands
#
# Returns the string representation of the subcommands
def subcommands_presentation
return nil unless command.commands.size > 0
command.commands.values.uniq.map(&:summarize).join("\n")
end
# Public: Builds the command header, including the command identity and description
#
# Returns the command header as a String
def command_header
header = "#{command.identity}"
header << " -- #{command.description}" if command.description
header
end
# Public: Builds a string representation of the whole command
#
# Returns the string representation of the whole command
def command_presentation
msg = []
msg << command_header
msg << "Usage:"
msg << usage_presentation
if opts = options_presentation
msg << "Options:\n#{opts}"
end
if subcommands = subcommands_presentation
msg << "Subcommands:\n#{subcommands_presentation}"
end
msg.join("\n\n")
end
# Public: Turn a print_* into a *_presentation or freak out
#
# meth - the method being called
# args - an array of arguments passed to the missing method
# block - the block passed to the missing method
#
# Returns the value of whatever function is called
def method_missing(meth, *args, &block)
if meth.to_s =~ /^print_(.+)$/
send("#{$1.downcase}_presentation")
else
super # You *must* call super if you don't handle the method,
# otherwise you'll mess up Ruby's method lookup.
end
end
end
end
|