/usr/include/assa-3.5/assa/CharInBuffer.h is in libassa3.5-5-dev 3.5.1-3ubuntu1.
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 | // -*- c++ -*-
//------------------------------------------------------------------------------
// CharInBuffer.h
//------------------------------------------------------------------------------
// Copyright (C) 2002,2005 Vladislav Grinchenko
//
// This library 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.
//------------------------------------------------------------------------------
#ifndef CHAR_IN_BUFFER_H
#define CHAR_IN_BUFFER_H
/** @file CharInBuffer.h
A bucket for collecting character-based stream records of certain
length or terminated by designated character(s).
*/
#include <sys/types.h>
#include "assa/Assure.h"
#include "assa/Socket.h"
#include <string>
using std::string;
namespace ASSA {
/**
* CharInBuffer is a bucket for the character-based streams/messages.
* It helps in reading, parsing, and storing record-oriented character
* streams from Socket stream asynchronously. The record terminator can
* be multibyte. The terminator is detected and removed from the bucket.
* When terminator is detected, the block of characters collected in the bucket
* is ready to be processed further by the application according to its
* communication protocol.
* If either Socket read() error is encountered, or an overflow occurs
* (number of characters read exceeds the maximum limit), the object goes into
* the error state and won't accept further input, unless reset.
*/
class CharInBuffer
{
public:
/** Constructor
* @param size_ Maximum expected size before buffer overflow
* @param delimiter_ End-of-record character(s). Can be multi-byte.
*/
CharInBuffer (size_t size_, const string& delimiter_);
/** Read bytes from Socket stream until either record delimiter is
* detected, or EOF occured, or Socket stream is exhausted.
* @return Socket reference
*/
friend ASSA::Socket& operator>>(ASSA::Socket&, ASSA::CharInBuffer&);
/** Test the state of an object
* @return true if the object holds a complete message;
* false otherwise (eof, buffer overflow, or incomplete)
*/
operator void* () const;
/// Get the constant character pointer to the buffer
const char* c_str () const { return m_buffer.c_str (); }
/// Bytes in the buffer so far
size_t length () const { return m_buffer.length (); }
/// Bytes in the buffer so far
size_t size () const { return m_buffer.size (); }
/** Discard all accumulated characters and be ready to receive
* a new message.
*/
void reset ();
/// Write the state of an object to the log file.
void dump () const;
/** @enum state_t
* States: start, waiting, complete, error
*/
enum state_t {
start, /**< start state */
waiting, /**< incomplete record is in the buffer */
complete, /**< matched end-of-record - full record */
error /**< overflow or Socket I/O error */
};
/// Report the current state of the object
state_t state () const { return m_state; }
private:
/// Report the state name
static const char* state_name (state_t state_);
/// Go to the new state
void state (state_t new_state_) { m_state = new_state_; }
/// Remove the delimiter from the end of the buffer
void chop ();
private:
/// Internal state of an object
state_t m_state;
/// Buffer to store the bytes received
std::string m_buffer;
/// Maximum allowable size (delimiter included) before overflow occurs
size_t m_max_size;
/// Delimiter. Multibyte delimiter is allowed.
std::string m_delimiter;
};
} // end namespace ASSA
/*******************************************************************************
Inline member functions
*******************************************************************************/
using namespace ASSA;
inline
CharInBuffer::
operator void* () const
{
return (m_state == complete
? (void *) (-1) // good state
: (void *) 0); // bad state
}
inline void
CharInBuffer::
reset ()
{
m_buffer = "";
state (waiting);
}
inline void
CharInBuffer::
chop ()
{
m_buffer.replace (m_buffer.find (m_delimiter), m_delimiter.length (), "");
}
#endif /* CHAR_IN_BUFFER_H */
|