#ifndef DECODER_H #define DECODER_H #include #include #include #include class DecoderBase { public: typedef boost::shared_ptr p; virtual size_t decode(const uint8_t *input, size_t input_size, uint8_t *output, size_t output_size) = 0; virtual ~DecoderBase() {} }; //! Input filter to hold a decoder in a filter chain. class DecoderFilter : public boost::iostreams::multichar_input_filter { private: DecoderBase::p decoder; public: typedef boost::shared_ptr p; DecoderFilter(DecoderBase::p decoder_); template std::streamsize read(Source& src, char *s, std::streamsize n) { char src_data[0x2000]; std::streamsize src_read = boost::iostreams::read(src, src_data, 0x2000); if(src_read < 0) src_read = 0; return decoder->decode((const uint8_t*)src_data, src_read, (uint8_t*)s, n); } }; namespace decoder { void init(); DecoderFilter::p get_decoder(const std::string& name); }; #endif