package org.red5.io.object;
/*
* RED5 Open Source Flash Server - http://code.google.com/p/red5/
*
* Copyright (c) 2006-2010 by respective authors (see below). All rights reserved.
*
* This library is free software; you can redistribute it and/or modify it under the
* terms of the GNU Lesser General Public License as published by the Free Software
* Foundation; either version 2.1 of the License, or (at your option) any later
* version.
*
* This library is distributed in the hope that it will be useful, but WITHOUT ANY
* WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A
* PARTICULAR PURPOSE. See the GNU Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public License along
* with this library; if not, write to the Free Software Foundation, Inc.,
* 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
*/
import java.util.Collection;
import java.util.Date;
import java.util.Map;
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 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();
}