implement optional watchdog for remote connections
[scpubgit/Object-Remote.git] / lib / Object / Remote / Node.pm
index 58923c8..e769e58 100644 (file)
@@ -2,23 +2,31 @@ package Object::Remote::Node;
 
 use strictures 1;
 use Object::Remote::Connector::STDIO;
-use Object::Remote::Logging qw(:log);
+use Object::Remote::Logging qw(:log :dlog);
+use Object::Remote::WatchDog;
 use Object::Remote;
 use CPS::Future;
 
 sub run {
-  log_trace { "run() has been invoked on remote node; creating STDIO connector" };
+  my ($class, %args) = @_; 
+  log_trace { "run() has been invoked on remote node" };
+  
+  if ($args{watchdog_timeout}) {
+    Object::Remote::WatchDog->new(timeout => $args{watchdog_timeout}); 
+  }
+  
   my $c = Object::Remote::Connector::STDIO->new->connect;
-
+  
   $c->register_class_call_handler;
 
   my $loop = Object::Remote->current_loop;
-
+  
   $c->on_close->on_ready(sub { 
     log_info { "Node connection with call handler has closed" };
     $loop->want_stop 
   });
 
+  Dlog_trace { "Node is sending 'Shere' to $_" } $c->send_to_fh;
   print { $c->send_to_fh } "Shere\n";
 
   log_debug { "Node is going to start the run loop" };