108 lines
3.0 KiB
C++
108 lines
3.0 KiB
C++
//
|
|
// VMime library (http://www.vmime.org)
|
|
// Copyright (C) 2002-2005 Vincent Richard <vincent@vincent-richard.net>
|
|
//
|
|
// This program is free software; you can redistribute it and/or
|
|
// modify it under the terms of the GNU General Public License as
|
|
// published by the Free Software Foundation; either version 2 of
|
|
// the License, or (at your option) any later version.
|
|
//
|
|
// This program 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
|
|
// General Public License for more details.
|
|
//
|
|
// You should have received a copy of the GNU General Public License along
|
|
// with this program; if not, write to the Free Software Foundation, Inc.,
|
|
// 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
|
|
//
|
|
// Linking this library statically or dynamically with other modules is making
|
|
// a combined work based on this library. Thus, the terms and conditions of
|
|
// the GNU General Public License cover the whole combination.
|
|
//
|
|
|
|
#ifndef VMIME_ENCODER_HPP_INCLUDED
|
|
#define VMIME_ENCODER_HPP_INCLUDED
|
|
|
|
|
|
#include "vmime/base.hpp"
|
|
#include "vmime/propertySet.hpp"
|
|
#include "vmime/exception.hpp"
|
|
#include "vmime/utility/progressListener.hpp"
|
|
|
|
|
|
namespace vmime
|
|
{
|
|
|
|
|
|
/** Encode/decode data in different encodings.
|
|
*/
|
|
|
|
class encoder : public object
|
|
{
|
|
public:
|
|
|
|
encoder();
|
|
virtual ~encoder();
|
|
|
|
/** Encode data.
|
|
*
|
|
* @param in input data (decoded)
|
|
* @param out output stream for encoded data
|
|
* @param progress progress listener, or NULL if you do not
|
|
* want to receive progress notifications
|
|
* @return number of bytes written into output stream
|
|
*/
|
|
virtual const utility::stream::size_type encode(utility::inputStream& in, utility::outputStream& out, utility::progressListener* progress = NULL) = 0;
|
|
|
|
/** Decode data.
|
|
*
|
|
* @param in input data (encoded)
|
|
* @param out output stream for decoded data
|
|
* @param progress progress listener, or NULL if you do not
|
|
* want to receive progress notifications
|
|
* @return number of bytes written into output stream
|
|
*/
|
|
virtual const utility::stream::size_type decode(utility::inputStream& in, utility::outputStream& out, utility::progressListener* progress = NULL) = 0;
|
|
|
|
/** Return the properties of the encoder.
|
|
*
|
|
* @return properties of the encoder
|
|
*/
|
|
const propertySet& getProperties() const;
|
|
|
|
/** Return the properties of the encoder.
|
|
*
|
|
* @return properties of the encoder
|
|
*/
|
|
propertySet& getProperties();
|
|
|
|
/** Return a list of property names that can be set for
|
|
* this encoder.
|
|
*
|
|
* @return list of property names
|
|
*/
|
|
virtual const std::vector <string> getAvailableProperties() const;
|
|
|
|
/** Return the results returned by this encoder.
|
|
*
|
|
* @return results returned by the encoder
|
|
*/
|
|
const propertySet& getResults() const;
|
|
|
|
protected:
|
|
|
|
propertySet& getResults();
|
|
|
|
private:
|
|
|
|
propertySet m_props;
|
|
propertySet m_results;
|
|
};
|
|
|
|
|
|
} // vmime
|
|
|
|
|
|
#endif // VMIME_ENCODER_HPP_INCLUDED
|