// -*- Mode: C++; c-basic-offset: 2; indent-tabs-mode: nil; c-brace-offset: 0; -*- /* This file is part of KDVI SPDX-FileCopyrightText: 2001 Stefan Kebekus (kebekus@kde.org) SPDX-License-Identifier: GPL-2.0-or-later */ /** * Byte reading routines which read big endian numbers from memory and * convert them to native integers. * * @author Stefan Kebekus (kebekus@kde.org) * **/ #ifndef _bigEndianByteReader_H #define _bigEndianByteReader_H #include class bigEndianByteReader { public: /** Set this pointer to the location where the number resides which you want to read. */ quint8 *command_pointer; /** This pointer marks the end of the memory area where bytes can be read. It should point to the first byte which CANNOT be read. The idea is to have a safety net which protects us against SEGFAULTs. This is also used in virtual fonts, where the macro does not have an EOP command at the end of the macro. */ quint8 *end_pointer; /** If command_pointer >= end_pointer, this method return EOP (=140) and exists. Otherwise, the method returns the unsigned byte and increases the command_pointer by one. */ quint8 readUINT8(); /** Similar to the method above, only that the method reads a big endian 2-byte word and increases the pointer by two. */ quint16 readUINT16(); /** Similar to the method above, only that the method reads a big endian 4-byte word and increases the pointer by four. */ quint32 readUINT32(); void writeUINT32(quint32 a); /** Similar to the method above, only that the method reads a big endian number of length size, where 1 <= size <= 4. Note that the value 3 is allowed (and is actually used in DVI files)!!! */ quint32 readUINT(quint8 size); /** Similar to the method above, only that the method reads a SIGNED number */ qint32 readINT(quint8); }; #endif // ifndef _bigEndianByteReader_H