Logo Search packages:      
Sourcecode: libpodofo version File versions  Download package

PdfInputStream.h

/***************************************************************************
 *   Copyright (C) 2007 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_INPUT_STREAM_H_
#define _PDF_INPUT_STREAM_H_

#include "PdfDefines.h"

namespace PoDoFo {

class PdfInputDevice;

/** An interface for reading blocks of data from an 
 *  a data source.
 */     
00033 class PODOFO_API PdfInputStream {
 public:

    virtual ~PdfInputStream() { };

    /** Read data from the input stream
     *  
     *  \param pBuffer the data will be stored into this buffer
     *  \param lLen    the size of the buffer and number of bytes
     *                 that will be read
     *
     *  \returns the number of bytes read, -1 if an error ocurred
     *           and zero if no more bytes are available for reading.
     */
    virtual pdf_long Read( char* pBuffer, pdf_long lLen ) = 0;

};

/** An input stream that reads data from a file
 */
00053 class PODOFO_API PdfFileInputStream : public PdfInputStream {
 public:
    
    /** Open a file for reading data
     *  
     *  \param pszFilename the filename of the file to read
     */
    PdfFileInputStream( const char* pszFilename );

#ifdef _WIN32
    /** Open a file for reading data
     *  
     *  \param pszFilename the filename of the file to read
     *
     *  This is an overloaded member function to allow working
     *  with unicode characters. On Unix systes you can also path
     *  UTF-8 to the const char* overload.
     */
    PdfFileInputStream( const wchar_t* pszFilename );
#endif // _WIN32

    ~PdfFileInputStream();

    /** Read data from the input stream
     *  
     *  \param pBuffer the data will be stored into this buffer
     *  \param lLen    the size of the buffer and number of bytes
     *                 that will be read
     *
     *  \returns the number of bytes read, -1 if an error ocurred
     *           and zero if no more bytes are available for reading.
     */
    virtual pdf_long Read( char* pBuffer, pdf_long lLen );

    /** Get the length of the file.
     *  \return the file length
     */
    pdf_long GetFileLength();

 private:
    FILE* m_hFile;
};

/** An input stream that reads data from a memory buffer
 */
00098 class PODOFO_API PdfMemoryInputStream : public PdfInputStream {
 public:
    
    /** Open a file for reading data
     *  
     *  \param pBuffer buffer to read from
     *  \param lBufferLen length of the buffer
     */
    PdfMemoryInputStream( const char* pBuffer, pdf_long lBufferLen );
    ~PdfMemoryInputStream();

    /** Read data from the input stream
     *  
     *  \param pBuffer the data will be stored into this buffer
     *  \param lLen    the size of the buffer and number of bytes
     *                 that will be read
     *
     *  \returns the number of bytes read, -1 if an error ocurred
     *           and zero if no more bytes are available for reading.
     */
    virtual pdf_long Read( char* pBuffer, pdf_long lLen );

 private:
    const char* m_pBuffer;
    const char* m_pCur;
    pdf_long        m_lBufferLen;
};

/** An input stream that reads data from an input device
 */
00128 class PODOFO_API PdfDeviceInputStream : public PdfInputStream {
 public:
    
    /** 
     *  Read from an alread opened input device
     * 
     *  \param pDevice an input device
     */
    PdfDeviceInputStream( PdfInputDevice* pDevice );
    ~PdfDeviceInputStream();

    /** Read data from the input stream
     *  
     *  \param pBuffer the data will be stored into this buffer
     *  \param lLen    the size of the buffer and number of bytes
     *                 that will be read
     *
     *  \returns the number of bytes read, -1 if an error ocurred
     *           and zero if no more bytes are available for reading.
     */
    virtual pdf_long Read( char* pBuffer, pdf_long lLen );

 private:
    PdfInputDevice* m_pDevice;
};

};

#endif // _PDF_INPUT_STREAM_H_

Generated by  Doxygen 1.6.0   Back to index