/usr/include/shogun/lib/CircularBuffer.h is in libshogun-dev 3.1.1-1.
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 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 | /*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 3 of the License, or
* (at your option) any later version.
*
* Written (W) 2013 Engeniy Andreev (gsomix)
*/
#ifndef __CIRCULARBUFFER_H_
#define __CIRCULARBUFFER_H_
#include <shogun/base/SGObject.h>
#include <shogun/lib/SGVector.h>
#include <shogun/lib/Tokenizer.h>
namespace shogun
{
/** @brief Implementation of circular buffer
* This buffer has logical structure such as queue (FIFO).
* But this queue is cyclic: tape, ends of which are connected,
* just instead tape there is block of physical memory.
* So, if you push big block of data it can be situated
* both at the end and the begin of buffer's memory.
*
* w: http://en.wikipedia.org/wiki/Circular_buffer
*/
class CCircularBuffer : public CSGObject
{
public:
/** default constructor */
CCircularBuffer();
/** constructor
*
* @param buffer_size size of buffer
*/
CCircularBuffer(int32_t buffer_size);
/** destructor */
~CCircularBuffer();
/** set tokenizer
*
* @param tokenizer tokenizer
*/
void set_tokenizer(CTokenizer* tokenizer);
/** push data into buffer from memory block
*
* @param source source data
* @return number of bytes written
*/
int32_t push(SGVector<char> source);
/** push data into buffer from file
*
* @param source source file (stream)
* @param source_size size of data to read
*/
int32_t push(FILE* source, int32_t source_size);
/** remove characters from buffer
*
* @param num_chars number of characters that should be removed
* @return characters removed
*/
SGVector<char> pop(int32_t num_chars);
/** returns true or false based on whether
* there exists another token in the text
*
* @return if another token exists
*/
bool has_next();
/** method that returns the indices, start and end, of
* the next token in buffer
*
* @param start token's starting index
* @return token's ending index (inclusive)
*/
index_t next_token_idx(index_t &start);
/** remove characters from buffer
* similar with pop(), but but does not return a string.
*
* @param num_chars number of characters that should be skipped
*/
void skip_characters(int32_t num_chars);
/** @return number of free bytes in buffer */
int32_t available() const
{
return m_bytes_available;
}
/** @return number of bytes contained in buffer */
int32_t num_bytes_contained() const
{
return m_bytes_count;
}
/** clear buffer */
void clear();
/** @return object name */
virtual const char* get_name() const { return "CircularBuffer"; }
private:
/** class initialization */
void init();
/** append memory block to buffer */
int32_t append_chunk(const char* source, int32_t source_size,
bool from_buffer_begin);
/** append data from file to buffer */
int32_t append_chunk(FILE* source, int32_t source_size,
bool from_buffer_begin);
/** detach memory block from buffer */
void detach_chunk(char** dest, int32_t* dest_size, int32_t dest_offset, int32_t num_bytes,
bool from_buffer_begin);
/** returns true or false based on whether
* there exists another token in the text
*/
bool has_next_locally(char* begin, char* end);
/** method that returns the indices, start and end, of
* the next token in part of buffer
*/
index_t next_token_idx_locally(index_t &start, char* begin, char* end);
/** move pointer to another position */
void move_pointer(char** pointer, char* new_position);
private:
/** internal memory */
SGVector<char> m_buffer;
/** pointer to end of buffer's memory */
char* m_buffer_end;
/** begin of buffer */
char* m_begin_pos;
/** end of buffer */
char* m_end_pos;
/** tokenizer */
CTokenizer* m_tokenizer;
/** position at which the search starts */
index_t m_last_idx;
/** number of free bytes */
int32_t m_bytes_available;
/** number of bytes contained */
int32_t m_bytes_count;
};
}
#endif /* _CIRCULARBUFFER_H_ */
|