Sha256: 57289a191f8fe92ef707254bab7a23c571ef8c130f90ab16d0a9926fe9264669
Contents?: true
Size: 1.42 KB
Versions: 108
Compression:
Stored size: 1.42 KB
Contents
class Thor class << self def register_subcommand(klass, subcommand, usage, description, options = {}) register(klass, subcommand, usage, description, options) # This could be done with ActiveSupport::Inflector module but is this necessary? register(klass, subcommand + "s", usage, description, :hide => true) end def before_hook(method, options = {}) @hook = {} unless @hook @hook[method] = options end def hooks @hook end def send(*args) if args.first == :dispatch && !args[2].empty? running_task = args[2].first help = args[2].include?('--help') || args[2].include?('-h') @hook.each do |method, options| if options[:only].include?(running_task.to_sym) && !help new.send(method) end end end super end def start(given_args=ARGV, config={}) config[:shell] ||= Thor::Base.shell.new send(:dispatch, nil, given_args.dup, nil, config) rescue Thor::Error => e ENV["THOR_DEBUG"] == "1" ? (raise e) : config[:shell].error(e.message) exit(1) if exit_on_failure? end # We overwrite this method so namespace is show # shelly *backup* restore FILENAME def handle_argument_error(task, error) raise InvocationError, "#{task.name.inspect} was called incorrectly. Call as #{self.banner(task, nil, self.to_s != 'Shelly::CLI::Main').inspect}." end end end
Version data entries
108 entries across 108 versions & 1 rubygems