2009-05-20 16:54:42 +02:00
|
|
|
package se.scalablesolutions.akka.api;
|
|
|
|
|
|
2009-05-23 22:24:02 +02:00
|
|
|
import se.scalablesolutions.akka.annotation.state;
|
2009-05-20 16:54:42 +02:00
|
|
|
import se.scalablesolutions.akka.annotation.transactional;
|
2009-05-23 22:24:02 +02:00
|
|
|
import se.scalablesolutions.akka.kernel.*;
|
2009-05-20 16:54:42 +02:00
|
|
|
|
2009-05-23 22:24:02 +02:00
|
|
|
public class InMemStateful {
|
|
|
|
|
@state private TransactionalMap<String, String> mapState = new InMemoryTransactionalMap<String, String>();
|
|
|
|
|
@state private TransactionalVector<String> vectorState = new InMemoryTransactionalVector<String>();
|
|
|
|
|
@state private TransactionalRef<String> refState = new TransactionalRef<String>();
|
|
|
|
|
|
|
|
|
|
public String getMapState(String key) {
|
|
|
|
|
return (String)mapState.get(key).get();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public String getVectorState() {
|
|
|
|
|
return (String)vectorState.last();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public String getRefState() {
|
|
|
|
|
return (String)refState.get().get();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public void setMapState(String key, String msg) {
|
|
|
|
|
mapState.put(key, msg);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public void setVectorState(String msg) {
|
|
|
|
|
vectorState.add(msg);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public void setRefState(String msg) {
|
|
|
|
|
refState.swap(msg);
|
|
|
|
|
}
|
2009-05-20 16:54:42 +02:00
|
|
|
|
|
|
|
|
@transactional
|
2009-05-23 22:24:02 +02:00
|
|
|
public void success(String key, String msg) {
|
|
|
|
|
mapState.put(key, msg);
|
2009-05-24 07:41:47 +02:00
|
|
|
//vectorState.add(msg);
|
|
|
|
|
//refState.swap(msg);
|
2009-05-23 22:24:02 +02:00
|
|
|
}
|
2009-05-20 16:54:42 +02:00
|
|
|
|
2009-05-23 22:24:02 +02:00
|
|
|
@transactional
|
|
|
|
|
public void failure(String key, String msg, InMemFailer failer) {
|
|
|
|
|
mapState.put(key, msg);
|
2009-05-24 07:41:47 +02:00
|
|
|
//vectorState.add(msg);
|
|
|
|
|
//refState.swap(msg);
|
2009-05-23 22:24:02 +02:00
|
|
|
failer.fail();
|
|
|
|
|
}
|
2009-05-20 16:54:42 +02:00
|
|
|
|
2009-05-23 22:24:02 +02:00
|
|
|
@transactional
|
|
|
|
|
public void thisMethodHangs(String key, String msg, InMemFailer failer) {
|
|
|
|
|
setMapState(key, msg);
|
|
|
|
|
}
|
2009-05-20 16:54:42 +02:00
|
|
|
|
2009-05-23 22:24:02 +02:00
|
|
|
/*
|
|
|
|
|
public void clashOk(String key, String msg, InMemClasher clasher) {
|
|
|
|
|
mapState.put(key, msg);
|
|
|
|
|
clasher.clash();
|
|
|
|
|
}
|
2009-05-20 16:54:42 +02:00
|
|
|
|
2009-05-23 22:24:02 +02:00
|
|
|
public void clashNotOk(String key, String msg, InMemClasher clasher) {
|
|
|
|
|
mapState.put(key, msg);
|
|
|
|
|
clasher.clash();
|
|
|
|
|
this.success("clash", "clash");
|
|
|
|
|
}
|
|
|
|
|
*/
|
|
|
|
|
}
|