ACF $AcfVersion:0$
Public Types | Public Member Functions | Protected Member Functions | List of all members
iser::CBinaryReadArchiveBase Class Reference

Base class for archive implementations reading data based on its binary representation. More...

#include <CBinaryReadArchiveBase.h>

Inheritance diagram for iser::CBinaryReadArchiveBase:
iser::CReadArchiveBase iser::CArchiveBase iser::IArchive istd::ILogger istd::IPolymorphic istd::IPolymorphic ifile::CFileReadArchive iser::CMemoryReadArchive ifile::CFileReadSecureArchive iser::CBitMemoryReadArchive

Public Types

enum  MessageId { MI_STRING_TOO_LONG = 0x3f320b0 }
 
typedef CReadArchiveBase BaseClass
 
- Public Types inherited from iser::IArchive
enum  MessageId { MI_TAG_ERROR = 0x3f320a0 , MI_TAG_SKIPPED }
 

Public Member Functions

virtual bool BeginTag (const CArchiveTag &tag) override
 Begins a tagged section in the archive.
 
virtual bool EndTag (const CArchiveTag &tag) override
 Ends a tagged section in the archive.
 
virtual bool Process (bool &value) override
 Processes (reads or writes) a boolean value.
 
virtual bool Process (char &value) override
 Process primitive type.
 
virtual bool Process (quint8 &value) override
 Process primitive type.
 
virtual bool Process (qint8 &value) override
 Process primitive type.
 
virtual bool Process (quint16 &value) override
 Process primitive type.
 
virtual bool Process (qint16 &value) override
 Process primitive type.
 
virtual bool Process (quint32 &value) override
 Process primitive type.
 
virtual bool Process (qint32 &value) override
 Process primitive type.
 
virtual bool Process (quint64 &value) override
 Process primitive type.
 
virtual bool Process (qint64 &value) override
 Process primitive type.
 
virtual bool Process (float &value) override
 Process primitive type.
 
virtual bool Process (double &value) override
 Process primitive type.
 
virtual bool Process (QByteArray &value) override
 Process primitive type.
 
virtual bool Process (QString &value) override
 Process primitive type.
 
- Public Member Functions inherited from iser::CReadArchiveBase
virtual bool IsStoring () const override
 Checks if this archive is in storing (writing) or loading (reading) mode.
 
virtual const IVersionInfoGetVersionInfo () const override
 Gets version information for the archived stream.
 
virtual bool ProcessBits (void *dataPtr, int bitsCount, int bytesCount) override
 Process binary data block.
 
- Public Member Functions inherited from iser::CArchiveBase
virtual bool IsTagSkippingSupported () const override
 Checks if skipping to the end of a tag on EndTag() is supported.
 
virtual bool BeginMultiTag (const CArchiveTag &tag, const CArchiveTag &subTag, int &count) override
 Begins a tagged section containing multiple elements of the same type.
 
- Public Member Functions inherited from iser::IArchive
template<typename Primitive >
bool TagAndProcess (const CArchiveTag &tag, Primitive &value)
 
virtual bool ProcessData (void *dataPtr, int size)=0
 Process binary data block.
 
- Public Member Functions inherited from istd::IPolymorphic
virtual ~IPolymorphic ()
 

Protected Member Functions

virtual int GetMaxStringLength () const
 Get maximal allowed string size.
 
- Protected Member Functions inherited from iser::CReadArchiveBase
bool SerializeAcfHeader ()
 Serialize standard header.
 
- Protected Member Functions inherited from iser::CArchiveBase
 CArchiveBase ()
 
- Protected Member Functions inherited from istd::ILogger
virtual void DecorateMessage (IInformationProvider::InformationCategory category, int id, int flags, QString &message, QString &messageSource) const
 Decorate message parts before outputting.
 
virtual bool IsLogConsumed (const IInformationProvider::InformationCategory *categoryPtr=NULL, const int *flagsPtr=NULL) const
 Check if any log message is consumed.
 
virtual bool SendLogMessage (IInformationProvider::InformationCategory category, int id, const QString &message, const QString &messageSource, int flags=0) const
 Send any message to log.
 

Additional Inherited Members

- Static Public Member Functions inherited from iser::CArchiveBase
static const CArchiveTagGetAcfRootTag ()
 
- Static Protected Attributes inherited from iser::CArchiveBase
static CArchiveTag s_acfRootTag
 

Detailed Description

Base class for archive implementations reading data based on its binary representation.

Definition at line 16 of file CBinaryReadArchiveBase.h.

Member Typedef Documentation

◆ BaseClass

Definition at line 19 of file CBinaryReadArchiveBase.h.

Member Enumeration Documentation

◆ MessageId

Enumerator
MI_STRING_TOO_LONG 

Definition at line 21 of file CBinaryReadArchiveBase.h.

Member Function Documentation

◆ BeginTag()

virtual bool iser::CBinaryReadArchiveBase::BeginTag ( const CArchiveTag tag)
overridevirtual

Begins a tagged section in the archive.

Tags organize data into logical units with names and descriptions. Every BeginTag() must be matched with an EndTag() call. Tags can be nested to create hierarchical data structures.

Parameters
tagThe tag object describing this section. Use static CArchiveTag instances to avoid repeated construction overhead.
Returns
true if the tag was successfully opened, false on error
Note
Always match BeginTag() with EndTag()
Check the return value and propagate errors
For collections, use BeginMultiTag() instead
static iser::CArchiveTag personTag("Person", "Person data");
if (archive.BeginTag(personTag)) {
archive.Process(name);
archive.Process(age);
archive.EndTag(personTag);
}
Process tag used to group data in archive stream.
Definition CArchiveTag.h:22
See also
EndTag(), BeginMultiTag(), CArchiveTag

Implements iser::IArchive.

Reimplemented in ifile::CFileReadArchive.

◆ EndTag()

virtual bool iser::CBinaryReadArchiveBase::EndTag ( const CArchiveTag tag)
overridevirtual

Ends a tagged section in the archive.

Must be called after BeginTag() or BeginMultiTag() to close the section. If tag skipping is supported and not all data was read, this will skip to the end of the tag section, enabling forward compatibility.

Parameters
tagThe same tag object passed to BeginTag() or BeginMultiTag()
Returns
true if successful, false on error
Note
Always call EndTag() even if errors occurred within the tag
The tag parameter must match the one used in BeginTag()
If IsTagSkippingSupported() returns false, you must read all data before calling EndTag()
static iser::CArchiveTag dataTag("Data", "My data");
if (archive.BeginTag(dataTag)) {
bool success = archive.Process(myData);
archive.EndTag(dataTag); // Always call, even if Process failed
if (!success) return false;
}
See also
BeginTag(), BeginMultiTag(), IsTagSkippingSupported()

Implements iser::IArchive.

Reimplemented in ifile::CFileReadArchive.

◆ GetMaxStringLength()

virtual int iser::CBinaryReadArchiveBase::GetMaxStringLength ( ) const
protectedvirtual

Get maximal allowed string size.

Reimplemented in ifile::CFileReadArchive, and iser::CMemoryReadArchive.

◆ Process() [1/14]

virtual bool iser::CBinaryReadArchiveBase::Process ( bool &  value)
overridevirtual

Processes (reads or writes) a boolean value.

Parameters
value[in/out] For writing: the value to store For reading: receives the loaded value
Returns
true if successful, false on error
See also
IsStoring(), Process() overloads for other types

Implements iser::IArchive.

◆ Process() [2/14]

virtual bool iser::CBinaryReadArchiveBase::Process ( char &  value)
overridevirtual

Process primitive type.

Implements iser::IArchive.

◆ Process() [3/14]

virtual bool iser::CBinaryReadArchiveBase::Process ( double &  value)
overridevirtual

Process primitive type.

Implements iser::IArchive.

◆ Process() [4/14]

virtual bool iser::CBinaryReadArchiveBase::Process ( float &  value)
overridevirtual

Process primitive type.

Implements iser::IArchive.

◆ Process() [5/14]

virtual bool iser::CBinaryReadArchiveBase::Process ( QByteArray &  value)
overridevirtual

Process primitive type.

Implements iser::IArchive.

◆ Process() [6/14]

virtual bool iser::CBinaryReadArchiveBase::Process ( qint16 &  value)
overridevirtual

Process primitive type.

Implements iser::IArchive.

◆ Process() [7/14]

virtual bool iser::CBinaryReadArchiveBase::Process ( qint32 &  value)
overridevirtual

Process primitive type.

Implements iser::IArchive.

◆ Process() [8/14]

virtual bool iser::CBinaryReadArchiveBase::Process ( qint64 &  value)
overridevirtual

Process primitive type.

Implements iser::IArchive.

◆ Process() [9/14]

virtual bool iser::CBinaryReadArchiveBase::Process ( qint8 &  value)
overridevirtual

Process primitive type.

Implements iser::IArchive.

◆ Process() [10/14]

virtual bool iser::CBinaryReadArchiveBase::Process ( QString &  value)
overridevirtual

Process primitive type.

Implements iser::IArchive.

◆ Process() [11/14]

virtual bool iser::CBinaryReadArchiveBase::Process ( quint16 &  value)
overridevirtual

Process primitive type.

Implements iser::IArchive.

◆ Process() [12/14]

virtual bool iser::CBinaryReadArchiveBase::Process ( quint32 &  value)
overridevirtual

Process primitive type.

Implements iser::IArchive.

◆ Process() [13/14]

virtual bool iser::CBinaryReadArchiveBase::Process ( quint64 &  value)
overridevirtual

Process primitive type.

Implements iser::IArchive.

◆ Process() [14/14]

virtual bool iser::CBinaryReadArchiveBase::Process ( quint8 &  value)
overridevirtual

Process primitive type.

Implements iser::IArchive.


The documentation for this class was generated from the following file: