// This file may be redistributed and modified only under the terms of
// the GNU Lesser General Public License (See COPYING for details).
// Copyright (C) 2000 Stefanus Du Toit

#ifndef ATLAS_OBJECTS_ENCODER_H
#define ATLAS_OBJECTS_ENCODER_H

#include <Atlas/EncoderBase.h>
#include <Atlas/Objects/Root.h>

namespace Atlas { namespace Objects {

/** Objects hierarchy encoder
 *
 * This Encoder can be used to send objects in the Atlas::Objects hierarchy to
 * a certain Bridge (e.g. a codec).
 *
 * Simply call the streamMessage member with a pointer to the object to be
 * sent.
 *
 * @see Atlas::Objects::Decoder
 * @author Stefanus Du Toit <sdt@gmx.net>
 */
class ObjectsEncoder : public Atlas::EncoderBase
{
public:
    /// The default constructor.
    /// @param b The Bridge to which objects are to be sent.
    explicit ObjectsEncoder(Atlas::Bridge & b) : EncoderBase(b) { }
    /// The default destructor.
    ~ObjectsEncoder();

    /// Send an object to the bridge.
    /// @param o The object that is to be sent.
    template <class ObjectData>
    void streamObjectsMessage(const Atlas::Objects::SmartPtr<ObjectData> & o)
    {
        m_b.streamMessage();
        o->sendContents(m_b);
        m_b.mapEnd();
    }
};

} } // namespace Atlas::Objects

#endif


syntax highlighted by Code2HTML, v. 0.9.1