/usr/include/podofo/base/PdfXRefStreamParserObject.h is in libpodofo-dev 0.9.0-1.2+b2.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 | /***************************************************************************
* Copyright (C) 2009 by Dominik Seichter *
* domseichter@web.de *
* *
* This program is free software; you can redistribute it and/or modify *
* it under the terms of the GNU Library General Public License as *
* published by the Free Software Foundation; either version 2 of the *
* License, or (at your option) any later version. *
* *
* This program is distributed in the hope that it will be useful, *
* but WITHOUT ANY WARRANTY; without even the implied warranty of *
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the *
* GNU General Public License for more details. *
* *
* You should have received a copy of the GNU Library General Public *
* License along with this program; if not, write to the *
* Free Software Foundation, Inc., *
* 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. *
***************************************************************************/
#ifndef _PDF_XREF_STREAM_PARSER_OBJECT_H_
#define _PDF_XREF_STREAM_PARSER_OBJECT_H_
#include "PdfDefines.h"
#include "PdfParserObject.h"
#define W_ARRAY_SIZE 3
#define W_MAX_BYTES 4
namespace PoDoFo {
/**
* A utility class for PdfParser that can parse
* an XRef stream object.
*
* It is mainly here to make PdfParser more modular.
*/
class PdfXRefStreamParserObject : public PdfParserObject {
public:
/** Parse the object data from the given file handle starting at
* the current position.
* \param pCreator pointer to a PdfVecObjects to resolve object references
* \param rDevice an open reference counted input device which is positioned in
* front of the object which is going to be parsed.
* \param rBuffer buffer to use for parsing to avoid reallocations
* \param pOffsets XRef entries are stored into this array
*/
PdfXRefStreamParserObject(PdfVecObjects* pCreator, const PdfRefCountedInputDevice & rDevice,
const PdfRefCountedBuffer & rBuffer, PdfParser::TVecOffsets* pOffsets );
~PdfXRefStreamParserObject();
void Parse();
void ReadXRefTable();
/**
* \returns true if there is a previous XRefStream
*/
inline bool HasPrevious();
/**
* \returns the offset of the previous XRef table
*/
inline pdf_long GetPreviousOffset();
private:
/**
* Read the /Index key from the current dictionary
* and write uit to a vector.
*
* \param rvecIndeces store the indeces hare
* \param size default value from /Size key
*/
void GetIndeces( std::vector<pdf_int64> & rvecIndeces, pdf_int64 size );
/**
* Parse the stream contents
*
* \param nW /W key
* \param rvecIndeces indeces as filled by GetIndeces
*
* \see GetIndeces
*/
void ParseStream( const pdf_int64 nW[W_ARRAY_SIZE], const std::vector<pdf_int64> & rvecIndeces );
void ReadXRefStreamEntry( char* pBuffer, pdf_long, const pdf_int64 lW[W_ARRAY_SIZE], int nObjNo );
private:
pdf_long m_lNextOffset;
PdfParser::TVecOffsets* m_pOffsets;
};
// -----------------------------------------------------
//
// -----------------------------------------------------
inline bool PdfXRefStreamParserObject::HasPrevious()
{
return (m_lNextOffset != -1);
}
// -----------------------------------------------------
//
// -----------------------------------------------------
inline pdf_long PdfXRefStreamParserObject::GetPreviousOffset()
{
return m_lNextOffset;
}
};
#endif // _PDF_XREF_STREAM_PARSER_OBJECT_H_
|