/usr/include/podofo/base/PdfObjectStreamParserObject.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 | /***************************************************************************
* Copyright (C) 2010 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_OBJECT_STREAM_PARSER_OBJECT_H_
#define _PDF_OBJECT_STREAM_PARSER_OBJECT_H_
#include "PdfDefines.h"
#include "PdfRefCountedBuffer.h"
namespace PoDoFo {
class PdfEncrypt;
class PdfParserObject;
class PdfVecObjects;
/**
* A utility class for PdfParser that can parse
* an object stream object.
*
* It is mainly here to make PdfParser more modular.
*/
class PdfObjectStreamParserObject {
public:
typedef std::vector<long long> ObjectIdList;
/**
* Create a new PdfObjectStreamParserObject from an existing
* PdfParserObject. The PdfParserObject will be removed and deleted.
* All objects from the object stream will be read into memory.
*
* \param pParser PdfParserObject for an object stream
* \param pVecObjects add loaded objecs to this vector of objects
* \param rBuffer use this allocated buffer for caching
* \param pEncrypt encryption object used to decrypt streams
*/
PdfObjectStreamParserObject(PdfParserObject* pParser, PdfVecObjects* pVecObjects, const PdfRefCountedBuffer & rBuffer, PdfEncrypt* pEncrypt );
~PdfObjectStreamParserObject();
void Parse(ObjectIdList const &);
private:
void ReadObjectsFromStream( char* pBuffer, pdf_long lBufferLen, long long lNum, long long lFirst, ObjectIdList const &);
private:
PdfParserObject* m_pParser;
PdfVecObjects* m_vecObjects;
PdfRefCountedBuffer m_buffer;
PdfEncrypt* m_pEncrypt;
};
};
#endif // _PDF_OBJECT_STREAM_PARSER_OBJECT_H_
|