#ifndef DECODER_H #define DECODER_H #include #include #include #include #include #include #include class DecoderBase { public: virtual size_t decode(const uint8_t *input, size_t input_size, uint8_t *output, size_t output_size) = 0; }; class DecoderFilter : public boost::iostreams::multichar_input_filter { private: DecoderBase& decoder; public: DecoderFilter(DecoderBase& decoder_) : decoder(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(); DecoderBase *get_decoder(const std::string& name); }; #endif