template<typename SRCTYPE, typename DSTTYPE>
class maxon::StreamConversionHelper< SRCTYPE, DSTTYPE >
This class implements a helper function for sequential access when using stream conversions Usually with stream conversions you get an arbitrary number of bytes within the ConvertImpl callback. This means you cannot longer read data in a classic linear fashion since you might not get enough bytes to finish your reading.
For example something simple like
void * buf
Definition: abstract.h:289
is not possible whithout checking for the remaning bytes left. In case of insufficient number of available bytes you have to store your current variable heap and continue reading in subsequent calls of ConvertImpl.
While this might be possible for simple algorithms it can get quite complex or even imposible when trying to read more elaborate data files which are for example arranged in hierarchies with chunks or subchunks. Or think about using an external complex library for accessing a data format like Alembic or TIFF. In this case you can not change the code structure - only replacing a ReadBytes access is possible.
StreamConversionHelper frees you from dealing with stream bytes deliverd in arbitrary chunks. First you simply overlad StreamConversionHelper template by specifying your source and dest datatype (here both Char) and fill the DoIt routine with your normal code e.g. reading the file (in this example decompressing a LZ4 stream)
class Lz4StreamConversionHelper : public StreamConversionHelper<Char, Char>
{
public:
virtual Result<void>
DoIt()
{
Lz4Decompress();
}
};
virtual Result< void > DoIt()=0
In this example if you want to read 4 bytes (aka Chars) within the DoIt routine you simply write
Result< void > Read(SRCTYPE *buf, Int count)
Definition: streamconversion_helper.h:335
char Char
signed 8 bit character
Definition: apibase.h:183
#define iferr_return
Definition: resultbase.h:1531
Second you put the helper object somewhere on the stack - ideally as a static variable in your main StreamConversion class and initialize it everytime ConvertImpl is called by simply calling AppendStream - boom you are done.
class Lz4BaseImpl :
public Component<Lz4BaseImpl, StreamConversionInterface>
{
public:
Result<Int> ConvertImpl(
const Block<const Generic>& xsrc, WritableArrayInterface<Generic>& xdst,
Int dstLimitHint,
Bool inputFinished,
Bool& outputFinished)
{
const Block<const Char>&
src =
reinterpret_cast<const Block<const Char>&
> (xsrc);
WritableArrayInterface<Char>& dst = reinterpret_cast<WritableArrayInterface<Char>&>(xdst);
if (inputFinished)
outputFinished = true;
return helper.GetCurrentPosition();
}
protected:
Lz4StreamConversionHelper helper;
};
Int64 Int
signed 32/64 bit int, size depends on the platform
Definition: apibase.h:187
bool Bool
boolean type, possible values are only false/true, 8 bit
Definition: apibase.h:180
const ARG & src
Definition: apibase.h:2706
ComponentWithBase< C, ComponentRoot, INTERFACES... > Component
Definition: objectbase.h:2815
#define MAXON_COMPONENT(KIND,...)
Definition: objectbase.h:2229
#define iferr_scope
Definition: resultbase.h:1396