org.jivesoftware.util.cache.ExternalizableUtil Maven / Gradle / Ivy
/*
* Copyright (C) 2005-2008 Jive Software. All rights reserved.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package org.jivesoftware.util.cache;
import java.io.*;
import java.util.Collection;
import java.util.List;
import java.util.Map;
import java.util.Set;
/**
* Utility methods to assist in working with the Externalizable interfaces. This class
* is only used when running inside of a Cluser. When using the open source version
* this class will use a dummy implementation. Anyway, this class is not used when
* not using the Enterprise edition.
*
* ExternalizableLite is very similar to the standard Externalizable interface, except that
* it uses DataOutput/DataInput instead of the Object stream equivalents.
*
* @author Gaston Dombiak
*/
public class ExternalizableUtil {
private static ExternalizableUtil instance = new ExternalizableUtil();
private ExternalizableUtilStrategy strategy = new DummyExternalizableUtil();
static {
instance = new ExternalizableUtil();
}
public static ExternalizableUtil getInstance() {
return instance;
}
/**
* Sets the implementation to use for serializing and deserializing
* objects.
*
* @param strategy the new strategy to use.
*/
public void setStrategy(ExternalizableUtilStrategy strategy) {
this.strategy = strategy;
}
/**
* Returns the implementation to use for serializing and deserializing
* objects.
*
* @return the implementation to use for serializing and deserializing
* objects.
*/
public ExternalizableUtilStrategy getStrategy() {
return strategy;
}
/**
* Hidding constructor. We only want one single instance.
*/
private ExternalizableUtil() {
super();
}
/**
* Writes a Map of String key and value pairs. This method handles the
* case when the Map is null.
*
* @param out the output stream.
* @param stringMap the Map of String key/value pairs.
* @throws java.io.IOException if an error occurs.
*/
public void writeStringMap(DataOutput out, Map stringMap) throws IOException {
strategy.writeStringMap(out, stringMap);
}
/**
* Reads a Map of String key and value pairs. This method will return
* null if the Map written to the stream was null.
*
* @param in the input stream.
* @return a Map of String key/value pairs.
* @throws IOException if an error occurs.
*/
public Map readStringMap(DataInput in) throws IOException {
return strategy.readStringMap(in);
}
/**
* Writes a Map of Long key and Integer value pairs. This method handles
* the case when the Map is null.
*
* @param out the output stream.
* @param map the Map of Long key/Integer value pairs.
* @throws IOException if an error occurs.
*/
public void writeLongIntMap(DataOutput out, Map map) throws IOException {
strategy.writeLongIntMap(out, map);
}
/**
* Reads a Map of Long key and Integer value pairs. This method will return
* null if the Map written to the stream was null.
*
* @param in the input stream.
* @return a Map of Long key/Integer value pairs.
* @throws IOException if an error occurs.
*/
public Map readLongIntMap(DataInput in) throws IOException {
return strategy.readLongIntMap(in);
}
/**
* Writes a List of Strings. This method handles the case when the List is
* null.
*
* @param out the output stream.
* @param stringList the List of Strings.
* @throws IOException if an error occurs.
*/
public void writeStringList(DataOutput out, List stringList) throws IOException {
strategy.writeStringList(out, stringList);
}
/**
* Reads a List of Strings. This method will return null if the List
* written to the stream was null.
*
* @param in the input stream.
* @return a List of Strings.
* @throws IOException if an error occurs.
*/
public List readStringList(DataInput in) throws IOException {
return strategy.readStringList(in);
}
/**
* Writes an array of long values. This method handles the case when the
* array is null.
*
* @param out the output stream.
* @param array the array of long values.
* @throws IOException if an error occurs.
*/
public void writeLongArray(DataOutput out, long [] array) throws IOException {
strategy.writeLongArray(out, array);
}
/**
* Reads an array of long values. This method will return null if
* the array written to the stream was null.
*
* @param in the input stream.
* @return an array of long values.
* @throws IOException if an error occurs.
*/
public long [] readLongArray(DataInput in) throws IOException {
return strategy.readLongArray(in);
}
public void writeLong(DataOutput out, long value) throws IOException {
strategy.writeLong(out, value);
}
public long readLong(DataInput in) throws IOException {
return strategy.readLong(in);
}
public void writeInt(DataOutput out, int value) throws IOException {
strategy.writeInt(out, value);
}
public int readInt(DataInput in) throws IOException {
return strategy.readInt(in);
}
public void writeBoolean(DataOutput out, boolean value) throws IOException {
strategy.writeBoolean(out, value);
}
public boolean readBoolean(DataInput in) throws IOException {
return strategy.readBoolean(in);
}
public void writeByteArray(DataOutput out, byte[] value) throws IOException {
strategy.writeByteArray(out, value);
}
public byte[] readByteArray(DataInput in) throws IOException {
return strategy.readByteArray(in);
}
public void writeSerializable(DataOutput out, Serializable value) throws IOException {
strategy.writeSerializable(out, value);
}
public Serializable readSerializable(DataInput in) throws IOException {
return strategy.readSerializable(in);
}
public void writeSafeUTF(DataOutput out, String value) throws IOException {
strategy.writeSafeUTF(out, value);
}
public String readSafeUTF(DataInput in) throws IOException {
return strategy.readSafeUTF(in);
}
/**
* Writes a collection of Externalizable objects. The collection passed as a parameter
* must be a collection and not a null value.
*
* @param out the output stream.
* @param value the collection of Externalizable objects. This value must not be null.
* @throws IOException if an error occurs.
*/
public void writeExternalizableCollection(DataOutput out, Collection extends Externalizable> value) throws IOException {
strategy.writeExternalizableCollection(out, value);
}
/**
* Writes a collection of Serializable objects. The collection passed as a parameter
* must be a collection and not a null value.
*
* @param out the output stream.
* @param value the collection of Serializable objects. This value must not be null.
* @throws IOException if an error occurs.
*/
public void writeSerializableCollection(DataOutput out, Collection extends Serializable> value) throws IOException {
strategy.writeSerializableCollection(out, value);
}
/**
* Reads a collection of Externalizable objects and adds them to the collection passed as a parameter. The
* collection passed as a parameter must be a collection and not a null value.
*
* @param in the input stream.
* @param value the collection of Externalizable objects. This value must not be null.
* @param loader class loader to use to build elements inside of the serialized collection.
* @throws IOException if an error occurs.
* @return the number of elements added to the collection.
*/
public int readExternalizableCollection(DataInput in, Collection extends Externalizable> value, ClassLoader loader)
throws IOException {
return strategy.readExternalizableCollection(in, value, loader);
}
/**
* Writes a Map of String key and value pairs. This method handles the
* case when the Map is null.
*
* @param out the output stream.
* @param map the Map of String key and Externalizable value pairs.
* @throws java.io.IOException if an error occurs.
*/
public void writeExternalizableMap(DataOutput out, Map map) throws IOException {
strategy.writeExternalizableMap(out, map);
}
/**
* Reads a collection of Serializable objects and adds them to the collection passed as a parameter. The
* collection passed as a parameter must be a collection and not a null value.
*
* @param in the input stream.
* @param value the collection of Serializable objects. This value must not be null.
* @param loader class loader to use to build elements inside of the serialized collection.
* @throws IOException if an error occurs.
* @return the number of elements added to the collection.
*/
public int readSerializableCollection(DataInput in, Collection extends Serializable> value, ClassLoader loader)
throws IOException {
return strategy.readSerializableCollection(in, value, loader);
}
/**
* Writes a Map of Serializable key and value pairs. This method handles the
* case when the Map is null.
*
* @param out the output stream.
* @param map the Map of Serializable key and value pairs.
* @throws java.io.IOException if an error occurs.
*/
public void writeSerializableMap(DataOutput out, Map extends Serializable, ? extends Serializable> map) throws IOException {
strategy.writeSerializableMap(out, map);
}
/**
* Reads a Map of String key and value pairs. This method will return
* null if the Map written to the stream was null.
*
* @param in the input stream.
* @param map a Map of String key and Externalizable value pairs.
* @param loader class loader to use to build elements inside of the serialized collection.
* @throws IOException if an error occurs.
* @return the number of elements added to the collection.
*/
public int readExternalizableMap(DataInput in, Map map, ClassLoader loader) throws IOException {
return strategy.readExternalizableMap(in, map, loader);
}
/**
* Reads a Map of Serializable key and value pairs. This method will return
* null if the Map written to the stream was null.
*
* @param in the input stream.
* @param map a Map of Serializable key and value pairs.
* @param loader class loader to use to build elements inside of the serialized collection.
* @throws IOException if an error occurs.
* @return the number of elements added to the collection.
*/
public int readSerializableMap(DataInput in, Map extends Serializable, ? extends Serializable> map, ClassLoader loader) throws IOException {
return strategy.readSerializableMap(in, map, loader);
}
/**
* Writes a Map of String key and Set of Strings value pairs. This method DOES NOT handle the
* case when the Map is null.
*
* @param out the output stream.
* @param map the Map of String key and Set of Strings value pairs.
* @throws java.io.IOException if an error occurs.
*/
public void writeStringsMap(DataOutput out, Map> map) throws IOException {
strategy.writeStringsMap(out, map);
}
/**
* Reads a Map of String key and Set of Strings value pairs.
*
* @param in the input stream.
* @param map a Map of String key and Set of Strings value pairs.
* @return number of elements added to the collection.
* @throws IOException if an error occurs.
*/
public int readStringsMap(DataInput in, Map> map) throws IOException {
return strategy.readStringsMap(in, map);
}
/**
* Writes content of collection of strings to the output stream.
*
* @param out the output stream.
* @param collection the Collection of Strings.
* @throws IOException if an error occurs.
*/
public void writeStrings(DataOutput out, Collection collection) throws IOException {
strategy.writeStrings(out, collection);
}
/**
* Reads the string array from the input stream and adds them to the specified collection.
*
* @param in the input stream.
* @param collection the collection to add the read strings from the input stream.
* @return number of elements added to the collection.
* @throws IOException if an error occurs.
*/
public int readStrings(DataInput in, Collection collection) throws IOException {
return strategy.readStrings(in, collection);
}
}