class Falcon::Command::Host

Manages a {Controller::Host} instance which is responsible for running applications in a production environment.
Implements the ‘falcon host` command. Designed for deployment.

def call

Prepare the environment and run the controller.
def call
	Console.logger.info(self) do |buffer|
		buffer.puts "Falcon Host v#{VERSION} taking flight!"
		buffer.puts "- Configuration: #{@paths.join(', ')}"
		buffer.puts "- To terminate: Ctrl-C or kill #{Process.pid}"
		buffer.puts "- To reload: kill -HUP #{Process.pid}"
	end
	
	begin
		Bundler.require(:preload)
	rescue Bundler::GemfileNotFound
		# Ignore.
	end
	
	if GC.respond_to?(:compact)
		GC.compact
	end
	
	self.controller.run
end

def configuration

Generate a configuration based on the specified {paths}.
def configuration
	configuration = Configuration.new
	
	@paths.each do |path|
		path = File.expand_path(path)
		configuration.load_file(path)
	end
	
	return configuration
end

def container_class

The container class to use.
def container_class
	Async::Container.best_container_class
end

def controller

Prepare a new controller for the command.
def controller
	Controller::Host.new(self)
end