This file is indexed.

/usr/include/opencollada/COLLADAStreamWriter/COLLADASWBuffer.h is in opencollada-dev 0.1.0~20140703.ddf8f47+dfsg1-2.

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) 2008-2009 NetAllied Systems GmbH

	  This file is part of COLLADAStreamWriter.

    Licensed under the MIT Open Source License,
    for details please see LICENSE file or the website
    http://www.opensource.org/licenses/mit-license.php
*/

#ifndef __COLLADASW_BUFFER_H__
#define __COLLADASW_BUFFER_H__

#include "COLLADASWPrerequisites.h"

#include <string.h>

namespace COLLADASW
{

	//From Common Repo: Rev 31

	class Buffer 	
	{
	private:
		/** Pointer to the buffer.*/
		char* mBuffer;

		/** The size of the buffer.*/
		size_t mBufferSize;

		/** Pointer to the first unused byte in the buffer.*/
		char* mCurrentPos;

		/** Minimum size of data that will be flushed directly without copying to the buffer. The current buffer will 
		be flushed before. */
		size_t mDirectFlushSize;

		/** The flusher used to flush the buffer.*/
		IBufferFlusher* mFlusher;

	public:
		Buffer(size_t bufferSize, IBufferFlusher* flusher);

		virtual ~Buffer();

		/** The flusher used to flush the buffer.*/
		IBufferFlusher* getFlusher() const { return mFlusher; }

		/** Flushes the to using the buffer flusher.
		@return True on success, false otherwise. 
		@note Calling this method does not force to flusher to flush its data. To force this call flushFlusher instead.*/
		bool flushBuffer();

		/** Flushes the flusher. Call this to ensure that the data is really been handled by the flusher. 
		This method implicitly calls flushBuffer.*/
		bool flushFlusher();

		/** Copies @a length bytes into the buffer, starting at @a data .*/
		bool copyToBuffer( const char* data, size_t length);

		/** Copies @a c  into the buffer.*/
		bool copyToBuffer( char c);

		size_t getBufferSize() const { return mBufferSize; }

		/** The number of bytes currently in the buffer.*/
		size_t getBytesUsed() const { return mCurrentPos - mBuffer; }

		/** The number of bytes currently available in the buffer.*/
		size_t getBytesAvailable() const { return getBufferSize()-getBytesUsed(); }

		/** @return True, if the buffer does not contain any data, false otherwise.*/
		size_t isEmpty() const { return mBuffer == mCurrentPos; }

		/** Minimum size of data that will be flushed directly without copying to the buffer. The current buffer will 
		be flushed before. */
		size_t getDirectFlushSize() const { return mDirectFlushSize; }

		/** Minimum size of data that will be flushed directly without copying to the buffer. The current buffer will 
		be flushed before. If @a directFlushSize is larger than the buffer size, the direct flush size will be set
		to the buffer size. */
		void setDirectFlushSize(size_t directFlushSize);

	protected:

		/** Provides access to the current position of the buffer for derived classes. Might be useful for 
		implementations that want to write into the buffer directly. Use increaseCurrentPosition to tell the buffer
		how many bytes have been added to the buffer. Before writing into the buffer directly, use 
		getBytesAvailable to ensure there is enough space available.*/
		char* getCurrentPosition() { return mCurrentPos; }

		/** Shifts the current position in the buffer by @a addedBytes bytes. No check is performed if the 
		new position is beyond the buffers end.*/
		void increaseCurrentPosition( size_t addedBytes) { mCurrentPos += addedBytes; } 

		/** Shifts the current position in the buffer by 1 byte. No check is performed if the 
		new position is beyond the buffers end.*/
		void increaseCurrentPosition() { mCurrentPos++; } 

	private:
		/** Disable default copy ctor. */
		Buffer( const Buffer& pre );
		/** Disable default assignment operator. */
		const Buffer& operator= ( const Buffer& pre );

	};



} // namespace COLLADASW

#endif // __COLLADASW_BUFFER_H__