X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?p=scpubgit%2FObject-Remote.git;a=blobdiff_plain;f=lib%2FObject%2FRemote%2FConnection.pm;h=c5bc9f673af6e22e7af162adac9798de1e782f8b;hp=2dcaa3679d8bd585af85aeffb7337c1213535633;hb=11dbd4a02cce95ee689233d2b1d2392470518732;hpb=5c608989561bc4892923c9e00dd20db910658fd1 diff --git a/lib/Object/Remote/Connection.pm b/lib/Object/Remote/Connection.pm index 2dcaa36..c5bc9f6 100644 --- a/lib/Object/Remote/Connection.pm +++ b/lib/Object/Remote/Connection.pm @@ -41,9 +41,15 @@ sub _build_ready_future { CPS::Future->new } has _receive_data_buffer => (is => 'ro', default => sub { my $x = ''; \$x }); -has local_objects_by_id => (is => 'ro', default => sub { {} }); +has local_objects_by_id => ( + is => 'ro', default => sub { {} }, + coerce => sub { +{ %{$_[0]} } }, # shallow clone on the way in +); -has remote_objects_by_id => (is => 'ro', default => sub { {} }); +has remote_objects_by_id => ( + is => 'ro', default => sub { {} }, + coerce => sub { +{ %{$_[0]} } }, # shallow clone on the way in +); has outstanding_futures => (is => 'ro', default => sub { {} }); @@ -95,7 +101,7 @@ sub new_from_spec { die "Couldn't figure out what to do with ${spec}"; } -sub new_remote { +sub remote_object { my ($self, @args) = @_; Object::Remote::Handle->new( connection => $self, @args @@ -109,7 +115,7 @@ sub connect { )); } -sub get_remote_sub { +sub remote_sub { my ($self, $sub) = @_; my ($pkg, $name) = $sub =~ m/^(.*)::([^:]+)$/; return await_future($self->send(class_call => $pkg, 0, can => $name));