package railo.runtime.type.scope;
import java.util.Iterator;
import railo.runtime.PageContext;
import railo.runtime.config.ConfigServer;
import railo.runtime.dump.DumpData;
import railo.runtime.dump.DumpProperties;
import railo.runtime.exp.ExpressionException;
import railo.runtime.exp.PageException;
import railo.runtime.exp.PageRuntimeException;
import railo.runtime.type.Collection;
import railo.runtime.type.dt.DateTime;
import railo.runtime.type.util.StructSupport;
/**d
*
*/
public final class ClusterNotSupported extends StructSupport implements Cluster {
private static final String NOT_SUPPORTED="to enable the cluster scope please install a cluster scope impementation with the help of the extenson manager";
@Override
public int size() {
return 0;
}
@Override
public Collection.Key[] keys() {
return null;
}
@Override
public Object removeEL(Key key) {
return null;
}
@Override
public Object remove(Key key) throws PageException {
throw new ExpressionException(NOT_SUPPORTED);
}
@Override
public void clear() {
}
@Override
public Object get(Collection.Key key) throws ExpressionException {
throw new ExpressionException(NOT_SUPPORTED);
}
@Override
public Object get(Collection.Key key, Object defaultValue) {
return defaultValue;
}
@Override
public Object set(Key key, Object value) throws ExpressionException {
throw new ExpressionException(NOT_SUPPORTED);
}
@Override
public Object setEL(Collection.Key key, Object value) {
return null;
}
@Override
public void setEntry(ClusterEntry entry) {
}
@Override
public Iterator<Collection.Key> keyIterator() {
return null;
}
@Override
public Iterator<String> keysAsStringIterator() {
return null;
}
@Override
public Iterator<Entry<Key, Object>> entryIterator() {
return null;
}
@Override
public Iterator<Object> valueIterator() {
return null;
}
@Override
public boolean isInitalized() {
return false;
}
@Override
public void initialize(PageContext pc) {
}
@Override
public void release() {
}
@Override
public void release(PageContext pc) {
}
@Override
public DumpData toDumpData(PageContext pageContext, int maxlevel, DumpProperties dp) {
throw new PageRuntimeException(new ExpressionException(NOT_SUPPORTED));
//return new SimpleDumpData(NOT_SUPPORTED);
}
@Override
public Collection duplicate(boolean deepCopy) {
return new ClusterNotSupported();
}
@Override
public boolean containsKey(Collection.Key key) {
return false;
}
@Override
public boolean containsValue(Object value) {
return false;
}
@Override
public java.util.Collection values() {
return null;
}
@Override
public String castToString() throws ExpressionException {
throw new ExpressionException(NOT_SUPPORTED);
}
@Override
public String castToString(String defaultValue) {
return defaultValue;
}
@Override
public boolean castToBooleanValue() throws ExpressionException {
throw new ExpressionException(NOT_SUPPORTED);
}
@Override
public Boolean castToBoolean(Boolean defaultValue) {
return defaultValue;
}
@Override
public double castToDoubleValue() throws ExpressionException {
throw new ExpressionException(NOT_SUPPORTED);
}
@Override
public double castToDoubleValue(double defaultValue) {
return defaultValue;
}
@Override
public DateTime castToDateTime() throws ExpressionException {
throw new ExpressionException(NOT_SUPPORTED);
}
@Override
public DateTime castToDateTime(DateTime defaultValue) {
return defaultValue;
}
public int getType() {
return SCOPE_CLUSTER;
}
public String getTypeAsString() {
return "Cluster";
}
public int compareTo(String str) throws PageException {
throw new ExpressionException(NOT_SUPPORTED);
}
public int compareTo(boolean b) throws PageException {
throw new ExpressionException(NOT_SUPPORTED);
}
public int compareTo(double d) throws PageException {
throw new ExpressionException(NOT_SUPPORTED);
}
public int compareTo(DateTime dt) throws PageException {
throw new ExpressionException(NOT_SUPPORTED);
}
@Override
public void broadcast() {
//print.out("Cluster#broadcast()");
}
@Override
public void init(ConfigServer configServer) {
}
}