use Object::Remote::Proxy;
use Scalar::Util qw(weaken blessed);
+use Object::Remote::Logging qw ( :log 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,
coerce => sub {
sub BUILD {
my ($self, $args) = @_;
+ log_trace { "constructing remote handle" };
if ($self->id) {
+ log_trace { "disarming free for this handle" };
$self->disarm_free;
} else {
die "No id supplied and no class either" unless $args->{class};
ref($_) eq 'HASH' and $_ = [ %$_ ] for $args->{args};
+ log_trace { "fetching id for handle and disarming free on remote side" };
$self->_set_id(
await_future(
- $self->connection->send(
- class_call => $args->{class}, 0,
+ $self->connection->send_class_call(
+ 0, $args->{class},
$args->{constructor}||'new', @{$args->{args}||[]}
)
)->{remote}->disarm_free->id
);
}
+ log_trace { "finished constructing remote handle; registering it " . ref($self) };
$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'" };
$method = "start::${method}" if (caller(0)||'') eq 'start';
future {
$self->connection->send(call => $self->id, $w, $method, @args)
sub call_discard {
my ($self, $method, @args) = @_;
+ log_trace { "invoking send_discard() with 'call' for method '$method' on connection for remote handle" };
$self->connection->send_discard(call => $self->id, $method, @args);
}
sub call_discard_free {
my ($self, $method, @args) = @_;
$self->disarm_free;
+ log_trace { "invoking send_discard() with 'call_free' for method '$method' on connection for remote handle" };
$self->connection->send_discard(call_free => $self->id, $method, @args);
}
sub DEMOLISH {
my ($self, $gd) = @_;
+ log_trace { "Demolishing remote handle" };
return if $gd or $self->disarmed_free;
$self->connection->send_free($self->id);
}