use Object::Remote::Proxy;
use Scalar::Util qw(weaken blessed);
-use Object::Remote::Logging qw ( :log router );
+use Object::Remote::Logging qw ( :log :dlog router );
use Object::Remote::Future;
-#must find way to exclude certain log events
-#from being forwarded - log events generated in
-#response to log events cause exploding
-#use Object::Remote::Logging qw(:log);
use Module::Runtime qw(use_module);
use Moo;
BEGIN { router()->exclude_forwarding }
has connection => (
- is => 'ro', required => 1,
+ is => 'ro', required => 1, handles => ['is_valid'],
coerce => sub {
blessed($_[0])
? $_[0]
)->{remote}->disarm_free->id
);
}
- log_trace { "finished constructing remote handle; registering it " . ref($self) };
+ Dlog_trace { "finished constructing remote handle; id is $_" } $self->id;
$self->connection->register_remote($self);
}
sub call {
my ($self, $method, @args) = @_;
my $w = wantarray;
- log_trace { my $def = defined $w ? 1 : 0; "call() has been invoked on a remote handle; wantarray: '$def'" };
+ my $id = $self->id;
+
$method = "start::${method}" if (caller(0)||'') eq 'start';
+ log_trace { "call('$method') has been invoked on remote handle '$id'; creating future" };
+
future {
- $self->connection->send(call => $self->id, $w, $method, @args)
+ log_debug { "Invoking send on connection for handle '$id' method '$method'" };
+ $self->connection->send(call => $id, $w, $method, @args)
};
}
sub DEMOLISH {
my ($self, $gd) = @_;
- log_trace { "Demolishing remote handle" };
+ Dlog_trace { "Demolishing remote handle $_" } $self->id;
return if $gd or $self->disarmed_free;
- $self->connection->send_free($self->id);
+ #this could happen after the connection has gone away
+ eval { $self->connection->send_free($self->id) };
+ if ($@ && $@ !~ m/^Attempt to invoke _send on a connection that is not valid/) {
+ die "Could not invoke send_free on connection for handle " . $self->id;
+ }
}
1;