class Middleman::Cli::Base
The base task from which everything else etends
def help(meth=nil, subcommand=false)
-
(void)
-
Parameters:
-
subcommand
(Boolean
) -- -
meth
(Symbol, String, nil
) --
def help(meth=nil, subcommand=false) if meth && !self.respond_to?(meth) klass, task = Thor::Util.find_class_and_task_by_namespace("#{meth}:#{meth}") klass.start(['-h', task].compact, shell: shell) else list = [] Thor::Util.thor_classes_in(Middleman::Cli).each do |thor_class| list += thor_class.printable_tasks(false) end list.sort! { |a, b| a[0] <=> b[0] } shell.say 'Tasks:' shell.print_table(list, ident: 2, truncate: true) shell.say end end
def method_missing(meth, *args)
-
meth
(Symbol
) --
def method_missing(meth, *args) meth = meth.to_s meth = self.class.map[meth] if self.class.map.key?(meth) klass, task = Thor::Util.find_class_and_task_by_namespace("#{meth}:#{meth}") if klass.nil? tasks_dir = File.join(Dir.pwd, 'tasks') if File.exist?(tasks_dir) Dir[File.join(tasks_dir, '**/*_task.rb')].each { |f| require f } klass, task = Thor::Util.find_class_and_task_by_namespace("#{meth}:#{meth}") end end if klass.nil? raise Thor::Error, "There's no '#{meth}' command for Middleman. Try 'middleman help' for a list of commands." else args.unshift(task) if task klass.start(args, shell: shell) end end
def start(*args)
def start(*args) # Change flag to a module ARGV.unshift('help') if ARGV.delete('--help') # Default command is server if ARGV[0] != 'help' && (ARGV.length < 1 || ARGV.first.include?('-')) ARGV.unshift('server') end super end
def version
def version say "Middleman #{Middleman::VERSION}" end