This file is indexed.

/usr/include/librevenge-0.0/librevenge-stream/RVNGStream.h is in librevenge-dev 0.0.4-4ubuntu1.

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
/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: t; c-basic-offset: 4 -*- */
/* librevenge
 * Version: MPL 2.0 / LGPLv2.1+
 *
 * This Source Code Form is subject to the terms of the Mozilla Public
 * License, v. 2.0. If a copy of the MPL was not distributed with this
 * file, You can obtain one at http://mozilla.org/MPL/2.0/.
 *
 * Major Contributor(s):
 * Copyright (C) 2004-2005 William Lachance (wrlach@gmail.com)
 *
 * For minor contributions see the git repository.
 *
 * Alternatively, the contents of this file may be used under the terms
 * of the GNU Lesser General Public License Version 2.1 or later
 * (LGPLv2.1+), in which case the provisions of the LGPLv2.1+ are
 * applicable instead of those above.
 */

#ifndef RVNGSTREAM_H
#define RVNGSTREAM_H

namespace librevenge
{

enum RVNG_SEEK_TYPE
{
	RVNG_SEEK_CUR,
	RVNG_SEEK_SET,
	RVNG_SEEK_END
};

class RVNGInputStream
{
public:
	RVNGInputStream() {}
	virtual ~RVNGInputStream() {}

	/**
	Analyses the content of the input stream to see whether it is an OLE2 storage.
	\return A boolean value that should be true if the input stream is an OLE2 storage
	and false if it is not the case
	*/
	virtual bool isStructured() = 0;

	virtual unsigned subStreamCount() = 0;

	virtual const char *subStreamName(unsigned id) = 0;

	virtual bool existsSubStream(const char *name) = 0;

	/**
	Extracts a \c named stream from an OLE2 storage.
	\return Should be a pointer to RVNGInputStream constructed from the \c named stream if it exists.
	\return Should be 0, if the \c named stream does not exist inside the OLE2 storage
	or if the input stream is not an OLE2 storage.
	*/
	virtual RVNGInputStream *getSubStreamByName(const char *name) = 0;

	virtual RVNGInputStream *getSubStreamById(unsigned id) = 0;

	/**
	Tries to read a given number of bytes starting from the current position inside the input stream.
	\param numBytes Number of bytes desired to be read.
	\param numBytesRead Number of bytes that were possible to be read.
	\return Should be a pointer to an array of numBytesRead bytes (unsigned char[numBytesRead]).
	\return Optionally it could be 0 if the desired number of bytes could not be read.
	*/
	virtual const unsigned char *read(unsigned long numBytes, unsigned long &numBytesRead) = 0;

	/**
	Moves to the next location inside the input stream.
	\param offset The offset of the location inside the input stream to move to.
	It is relative either to the current position or to the beginning of the input stream
	depending on the value of the \c seekType parameter.
	\param seekType Determines whether the \c offset is relative to the
	beginning of the input stream (\c RVNG_SEEK_SET) or to the current position (\c RVNG_SEEK_CUR).
	\return An integer value that should be 0 (zero) if the seek was successful and any other value
	if it failed (i.e. the requested \c offset is beyond the end of the input stream or before its beginning).
	*/
	virtual int seek(long offset, RVNG_SEEK_TYPE seekType) = 0;

	/**
	Returns the actual position inside the input stream.
	\return A long integer value that should correspond to the position of the next location to be read in the input stream.
	*/
	virtual long tell() = 0;

	/**
	Determines whether the current position is at the end of the stream.
	\return A boolean value that should be true if the next location to be read in the input stream
	is beyond its end. In all other cases, it should be false.
	*/
	virtual bool isEnd() = 0;
};

}

#endif
/* vim:set shiftwidth=4 softtabstop=4 noexpandtab: */