icinga2/lib/base/stream.cpp

200 lines
3.8 KiB
C++
Raw Normal View History

/******************************************************************************
* Icinga 2 *
* Copyright (C) 2012 Icinga Development Team (http://www.icinga.org/) *
* *
* 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 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 General Public License *
* along with this program; if not, write to the Free Software Foundation *
2012-05-11 13:33:57 +02:00
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA. *
******************************************************************************/
2013-03-16 21:18:53 +01:00
#include "base/stream.h"
#include "base/objectlock.h"
#include "base/utility.h"
2013-03-15 18:21:29 +01:00
#include <boost/algorithm/string/trim.hpp>
2012-03-28 13:24:49 +02:00
using namespace icinga;
2012-11-22 12:04:32 +01:00
Stream::Stream(void)
2013-03-10 05:10:51 +01:00
: m_Connected(false), m_ReadEOF(false), m_WriteEOF(false)
2012-11-22 12:04:32 +01:00
{ }
Stream::~Stream(void)
{
ASSERT(!m_Running);
2012-11-22 12:04:32 +01:00
}
2013-03-02 09:07:47 +01:00
/**
* @threadsafety Always.
*/
2012-11-22 12:04:32 +01:00
bool Stream::IsConnected(void) const
{
2013-03-02 09:07:47 +01:00
ObjectLock olock(this);
2012-11-22 12:04:32 +01:00
return m_Connected;
}
2013-03-10 03:09:01 +01:00
/**
* @threadsafety Always.
*/
2013-03-10 05:10:51 +01:00
bool Stream::IsReadEOF(void) const
2013-03-10 03:09:01 +01:00
{
ObjectLock olock(this);
2013-03-10 05:10:51 +01:00
return m_ReadEOF;
}
/**
* @threadsafety Always.
*/
bool Stream::IsWriteEOF(void) const
{
ObjectLock olock(this);
return m_WriteEOF;
2013-03-10 03:09:01 +01:00
}
2013-03-02 09:07:47 +01:00
/**
* @threadsafety Always.
*/
2012-11-22 12:04:32 +01:00
void Stream::SetConnected(bool connected)
{
2013-03-10 05:10:51 +01:00
bool changed;
2013-03-02 09:07:47 +01:00
{
ObjectLock olock(this);
2013-03-10 05:10:51 +01:00
changed = (m_Connected != connected);
2013-03-02 09:07:47 +01:00
m_Connected = connected;
}
2012-11-22 12:04:32 +01:00
2013-03-10 05:10:51 +01:00
if (changed) {
if (connected)
OnConnected(GetSelf());
else
OnClosed(GetSelf());
}
2012-11-22 12:04:32 +01:00
}
2013-03-10 03:09:01 +01:00
/**
* @threadsafety Always.
*/
2013-03-10 05:10:51 +01:00
void Stream::SetReadEOF(bool eof)
2013-03-10 03:09:01 +01:00
{
2013-03-10 05:10:51 +01:00
ObjectLock olock(this);
m_ReadEOF = eof;
}
/**
* @threadsafety Always.
*/
void Stream::SetWriteEOF(bool eof)
{
ObjectLock olock(this);
m_WriteEOF = eof;
2013-03-10 03:09:01 +01:00
}
/**
2013-03-02 09:07:47 +01:00
* Checks whether an exception is available for this stream and re-throws
2012-11-22 12:04:32 +01:00
* the exception if there is one.
2013-03-02 09:07:47 +01:00
*
* @threadsafety Always.
*/
2012-11-22 12:04:32 +01:00
void Stream::CheckException(void)
{
2013-03-02 09:07:47 +01:00
ObjectLock olock(this);
2012-11-22 12:04:32 +01:00
if (m_Exception)
rethrow_exception(m_Exception);
}
2013-03-02 09:07:47 +01:00
/**
* @threadsafety Always.
*/
2012-11-22 12:04:32 +01:00
void Stream::SetException(boost::exception_ptr exception)
{
2013-03-02 09:07:47 +01:00
ObjectLock olock(this);
2012-11-22 12:04:32 +01:00
m_Exception = exception;
}
2013-03-02 09:07:47 +01:00
/**
* @threadsafety Always.
*/
2012-11-22 12:04:32 +01:00
boost::exception_ptr Stream::GetException(void)
{
return m_Exception;
}
2013-03-02 09:07:47 +01:00
/**
* @threadsafety Always.
*/
2012-11-22 12:04:32 +01:00
void Stream::Start(void)
{
2013-03-02 09:07:47 +01:00
ObjectLock olock(this);
2012-11-22 12:04:32 +01:00
m_Running = true;
}
2013-03-02 09:07:47 +01:00
/**
* @threadsafety Always.
*/
2012-11-22 12:04:32 +01:00
void Stream::Close(void)
2012-03-28 13:24:49 +02:00
{
2013-03-04 15:52:42 +01:00
{
ObjectLock olock(this);
2013-03-02 09:07:47 +01:00
2013-03-04 15:52:42 +01:00
m_Running = false;
}
2012-11-22 12:04:32 +01:00
SetConnected(false);
2012-03-28 13:24:49 +02:00
}
bool Stream::ReadLine(String *line, size_t maxLength)
{
2013-03-10 05:10:51 +01:00
char *buffer = new char[maxLength];
size_t rc = Peek(buffer, maxLength);
2013-03-10 05:10:51 +01:00
if (rc == 0)
return false;
2013-03-10 03:09:01 +01:00
for (size_t i = 0; i < rc; i++) {
if (buffer[i] == '\n') {
*line = String(buffer, &(buffer[i]));
2013-03-10 03:09:01 +01:00
boost::algorithm::trim_right(*line);
2013-03-10 05:10:51 +01:00
Read(NULL, i + 1);
delete buffer;
return true;
}
}
2013-03-10 05:10:51 +01:00
if (IsReadEOF()) {
*line = String(buffer, buffer + rc);
boost::algorithm::trim_right(*line);
Read(NULL, rc);
delete buffer;
return true;
}
delete buffer;
return false;
}