/*
* RED5 Open Source Flash Server - http://code.google.com/p/red5/
*
* Copyright 2006-2012 by respective authors (see below). 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.red5.io.object;
import java.util.Collection;
import java.util.Date;
import java.util.Map;
import java.util.Vector;
import org.red5.io.amf3.ByteArray;
import org.w3c.dom.Document;
/**
* Output interface which defines contract methods to be implemented
*
* @author The Red5 Project (red5@osflash.org)
* @author Luke Hubbard, Codegent Ltd (luke@codegent.com)
*/
public interface Output {
boolean supportsDataType(byte type);
void putString(String string);
// Basic Data Types
/**
* Write number
* @param num Number
*/
void writeNumber(Number num);
/**
* Write boolean
* @param bol Boolean
*/
void writeBoolean(Boolean bol);
/**
* Write string
* @param string String
*/
void writeString(String string);
/**
* Write date
* @param date Date
*/
void writeDate(Date date);
void writeNull();
/**
* Write array.
* @param array Array to write.
* @param serializer Serializer to use for subobjects.
*/
void writeArray(Collection<?> array, Serializer serializer);
/**
* Write array.
* @param array Array to write.
* @param serializer Serializer to use for subobjects.
*/
void writeArray(Object[] array, Serializer serializer);
/**
* Write primitive array.
* @param array Array to write.
* @param serializer Serializer to use for subobjects.
*/
void writeArray(Object array, Serializer serializer);
/**
* Write map.
*
* @param map Map to write
* @param serializer Serializer to use for subobjects.
*/
void writeMap(Map<Object, Object> map, Serializer serializer);
/**
* Write array as map.
*
* @param array Array to write
* @param serializer Serializer to use for subobjects.
*/
void writeMap(Collection<?> array, Serializer serializer);
/**
* Write object.
*
* @param object Object to write
* @param serializer Serializer to use for subobjects.
*/
void writeObject(Object object, Serializer serializer);
/**
* Write map as object.
*
* @param map Map to write
* @param serializer Serializer to use for subobjects.
*/
void writeObject(Map<Object, Object> map, Serializer serializer);
/**
* Write recordset.
*
* @param recordset Recordset to write.
* @param serializer Serializer to use for subobjects.
*/
void writeRecordSet(RecordSet recordset, Serializer serializer);
/**
* Write XML object
* @param xml XML document
*/
void writeXML(Document xml);
/**
* Write ByteArray object (AMF3 only).
*
* @param array object to write
*/
void writeByteArray(ByteArray array);
/**
* Write a Vector<int>.
*
* @param vector
*/
void writeVectorInt(Vector<Integer> vector);
/**
* Write a Vector<uint>.
*
* @param vector
*/
void writeVectorUInt(Vector<Long> vector);
/**
* Write a Vector<Number>.
*
* @param vector
*/
void writeVectorNumber(Vector<Double> vector);
/**
* Write a Vector<Object>.
*
* @param vector
*/
void writeVectorObject(Vector<Object> vector);
/**
* Write reference to complex data type
* @param obj Referenced object
*/
void writeReference(Object obj);
/**
* Whether object is custom
*
* @param custom Object
* @return true if object is of user type, false otherwise
*/
boolean isCustom(Object custom);
/**
* Write custom (user) object
* @param custom Custom data type object
*/
void writeCustom(Object custom);
/**
* Clear references
*/
void clearReferences();
}