mirror of
https://invent.kde.org/graphics/okular
synced 2024-11-05 18:34:53 +00:00
59 lines
2 KiB
C++
59 lines
2 KiB
C++
// -*- 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 <QGlobalStatic>
|
|
|
|
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
|