Class: ProcessHost::Host
- Inherits:
-
Object
- Object
- ProcessHost::Host
- Includes:
- Log::Dependency
- Defined in:
- lib/process_host/host.rb
Defined Under Namespace
Modules: Assertions
Constant Summary collapse
- NameConflictError =
Class.new StandardError
Class Method Summary collapse
Instance Method Summary collapse
- #log_observer ⇒ Object
- #processes ⇒ Object
- #record_error(&block) ⇒ Object
- #record_errors_observer ⇒ Object
- #register(process_class, process_name = nil) ⇒ Object
- #start(&block) ⇒ Object
- #start_processes(&block) ⇒ Object
Class Method Details
Instance Method Details
#log_observer ⇒ Object
99 100 101 |
# File 'lib/process_host/host.rb', line 99 def log_observer @log_observer ||= SupervisorObservers::Log.new end |
#processes ⇒ Object
103 104 105 |
# File 'lib/process_host/host.rb', line 103 def processes @processes ||= {} end |
#record_error(&block) ⇒ Object
35 36 37 |
# File 'lib/process_host/host.rb', line 35 def record_error(&block) record_errors_observer.record_error_proc = block end |
#record_errors_observer ⇒ Object
95 96 97 |
# File 'lib/process_host/host.rb', line 95 def record_errors_observer @record_errors_observer ||= SupervisorObservers::RecordErrors.new end |
#register(process_class, process_name = nil) ⇒ Object
15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 |
# File 'lib/process_host/host.rb', line 15 def register(process_class, process_name=nil) logger.trace { "Registering process (ProcessClass: #{process_class}, Name: #{process_name.inspect})" } process_name ||= process_class.process_name if registered_process = processes[process_name] = "Process with specified name is already registered (ProcessClass: #{process_class}, Name: #{process_name.inspect}, RegisteredProcessClass: #{registered_process.name})" logger.error raise NameConflictError, else processes[process_name] = process_class end logger.debug { "Process registered (ProcessClass: #{process_class}, Name: #{process_name.inspect})" } process_name end |
#start(&block) ⇒ Object
39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 |
# File 'lib/process_host/host.rb', line 39 def start(&block) started_processes = [] Actor::Supervisor.start do |supervisor| supervisor.add_observer record_errors_observer supervisor.add_observer log_observer signal.trap 'TSTP' do = Actor::Messages::Suspend send.(, supervisor.address) logger.info { "Handled TSTP signal (MessageName: #{.}, SupervisorAddress: #{supervisor.address.id})" } end signal.trap 'CONT' do = Actor::Messages::Resume send.(, supervisor.address) logger.info { "Handled CONT signal (MessageName: #{.}, SupervisorAddress: #{supervisor.address.id})" } end signal.trap 'INT' do = Actor::Messages::Shutdown send.(, supervisor.address) logger.info { "Handled INT signal (MessageName: #{.}, SupervisorAddress: #{supervisor.address.id})" } end start_processes do |process| started_processes << process end block.(supervisor) if block end started_processes end |
#start_processes(&block) ⇒ Object
81 82 83 84 85 86 87 88 89 90 91 92 93 |
# File 'lib/process_host/host.rb', line 81 def start_processes(&block) processes.each_value do |process_class| process = process_class.build process.start block.(process) if block end rescue => error record_errors_observer.(error) raise error end |