class Falcon::Command::Serve

def run(verbose = false)

def run(verbose = false)
	app, _ = load_app(verbose)
	
	endpoint = Endpoint.parse(@options[:bind], **endpoint_options)
	
	bound_endpoint = Async::Reactor.run do
		Async::IO::SharedEndpoint.bound(endpoint)
	end.wait
	
	Async.logger.info(endpoint) do
		"Falcon taking flight! Using #{container_class} with concurrency: #{@options[:concurrency]}"
	end
	
	debug_trap = Async::IO::Trap.new(:USR1)
	
	debug_trap.ignore!
	
	if container_class.multiprocess?
		Async.logger.info "Full status: kill -USR1 #{-Process.pid}"
	end
	
	container_class.new(concurrency: @options[:concurrency], name: "Falcon Server") do |task, instance|
		task.async do
			if debug_trap.install!
				Async.logger.info "Per-process status: kill -USR1 #{Process.pid}"
			end
			
			debug_trap.trap do
				Async.logger.info(self) do |buffer|
					task.reactor.print_hierarchy(buffer)
				end
			end
		end
		
		server = Falcon::Server.new(app, bound_endpoint, endpoint.protocol, endpoint.scheme)
		
		server.run
		
		task.children.each(&:wait)
	end
end