/*
* Quasar: lightweight threads and actors for the JVM.
* Copyright (c) 2013-2015, Parallel Universe Software Co. All rights reserved.
*
* This program and the accompanying materials are dual-licensed under
* either the terms of the Eclipse Public License v1.0 as published by
* the Eclipse Foundation
*
* or (per the licensee's choosing)
*
* under the terms of the GNU Lesser General Public License version 3.0
* as published by the Free Software Foundation.
*/
package co.paralleluniverse.remote.galaxy;
import co.paralleluniverse.actors.ActorImpl;
import co.paralleluniverse.actors.ActorRef;
/**
*
* @author pron
*/
public class GlxGlobalRemoteActor<Message> extends GlxRemoteActor<Message> {
private final long id;
public GlxGlobalRemoteActor(final ActorRef<Message> actor, Object globalId) {
super(actor);
this.id = (Long) globalId;
startReceiver();
}
private void startReceiver() {
final ActorImpl<Message> actor = getActor();
if (actor == null)
throw new IllegalStateException("Actor for " + this + " not running locally");
final GlobalRemoteChannelReceiver<Object> receiver = GlobalRemoteChannelReceiver.getReceiver(actor.getMailbox(), id);
receiver.setFilter(new GlobalRemoteChannelReceiver.MessageFilter<Object>() {
@Override
public boolean shouldForwardMessage(Object msg) {
if (msg instanceof RemoteActorAdminMessage) {
handleAdminMessage((RemoteActorAdminMessage) msg);
return false;
}
return true;
}
});
}
@Override
protected Object readResolve() throws java.io.ObjectStreamException {
final GlxGlobalRemoteActor remote = (GlxGlobalRemoteActor) super.readResolve();
// Grid.getInstance().store().setListener(id, remote);
return remote;
}
}