module Vedeu # This class ensures that STDIN, STDOUT and STDERR point to the # correct places. It also handles the initial configuration of the # application, the starting of the application, the handling of # uncaught exceptions and finally the exiting of the application # with the correct exit code. # class Launcher # @!attribute [r] exit_code # @return [Fixnum] Return value indicating successful execution # (0) or an error occurred (1). attr_reader :exit_code # :nocov: # @param (see #initialize) def self.execute!(argv = [], stdin = STDIN, stdout = STDOUT, stderr = STDERR, kernel = Kernel) new(argv, stdin, stdout, stderr, kernel).debug_execute! end # :nocov: # Returns a new instance of Vedeu::Launcher. # # @param argv [Array] # @param stdin [IO] # @param stdout [IO] # @param stderr [IO] # @param kernel [Kernel] # @return [Vedeu::Launcher] def initialize(argv = [], stdin = STDIN, stdout = STDOUT, stderr = STDERR, kernel = Kernel) @argv = argv @stdin = stdin @stdout = stdout @stderr = stderr @kernel = kernel @exit_code = 1 end # :nocov: # If debugging is enabled, execute the application within the # debugging context. At the moment, this simple uses 'ruby-prof' # to profile the running application. # # @return [void] def debug_execute! if configuration.debug? Vedeu.debug { execute! } else execute! end terminate! end # :nocov: # Alters the STD[IN|OUT|ERR] to those requested by the client # application, then starts the application. If an uncaught # exception occurs during the application runtime, we exit # ungracefully with any error message(s). # # @return [void] def execute! $stdin = @stdin $stdout = @stdout $stderr = @stderr Vedeu::Runtime::Application.start(configuration) @exit_code = 0 rescue StandardError => uncaught_exception Vedeu.log_stdout(type: :error, message: uncaught_exception.message) if configuration.debug? Vedeu.log_stdout(type: :error, message: uncaught_exception.backtrace.join("\n")) end end protected # @!attribute [r] argv # @return [Array] The command line arguments provided. attr_reader :argv private # :nocov: # Terminates the application after resetting $stdin, $stdout and # $stderr. # # @return [void] def terminate! Vedeu.log(type: :info, message: 'Exiting gracefully.') $stdin = STDIN $stdout = STDOUT $stderr = STDERR @kernel.exit(exit_code) end # :nocov: # @return [Vedeu::Configuration] def configuration Vedeu::Configuration end end # Launcher end # Vedeu