jamulus/src/buffer.h

109 lines
3.1 KiB
C
Raw Normal View History

/******************************************************************************\
* Copyright (c) 2004-2009
*
* Author(s):
* Volker Fischer
*
******************************************************************************
*
* 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, Inc.,
* 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
*
\******************************************************************************/
2007-09-08 12:45:14 +02:00
#if !defined ( BUFFER_H__3B123453_4344_BB23945IUHF1912__INCLUDED_ )
#define BUFFER_H__3B123453_4344_BB23945IUHF1912__INCLUDED_
#include "util.h"
#include "global.h"
2006-01-28 12:29:22 +01:00
/* Classes ********************************************************************/
class CNetBuf
{
public:
CNetBuf() {}
virtual ~CNetBuf() {}
2007-09-08 12:45:14 +02:00
void Init ( const int iNewBlockSize, const int iNewNumBlocks );
int GetSize() { return iMemSize / iBlockSize; }
bool Put ( const CVector<uint8_t>& vecbyData );
bool Get ( CVector<uint8_t>& vecbyData );
protected:
2007-09-08 12:45:14 +02:00
enum EBufState { BS_OK, BS_FULL, BS_EMPTY };
enum EClearType { CT_PUT, CT_GET };
void Clear ( const EClearType eClearType );
int GetAvailSpace() const;
int GetAvailData() const;
2006-01-28 12:29:22 +01:00
CVector<uint8_t> vecbyMemory;
int iMemSize;
int iBlockSize;
int iGetPos, iPutPos;
EBufState eBufState;
};
2006-01-28 12:29:22 +01:00
2007-09-08 12:45:14 +02:00
// conversion buffer (very simple buffer)
2009-07-28 22:31:23 +02:00
template<class TData> class CConvBuf
2006-01-28 12:29:22 +01:00
{
public:
2007-09-08 12:45:14 +02:00
CConvBuf() {}
virtual ~CConvBuf() {}
2006-01-28 12:29:22 +01:00
2009-07-28 22:31:23 +02:00
void Init ( const int iNewMemSize )
{
// set memory size
iMemSize = iNewMemSize;
2006-01-28 12:29:22 +01:00
2009-07-28 22:31:23 +02:00
// allocate and clear memory for actual data buffer
vecsMemory.Init ( iMemSize );
iPutPos = 0;
}
int GetSize() const { return iMemSize; }
2009-07-30 20:36:37 +02:00
bool Put ( const CVector<TData>& vecsData )
2009-07-28 22:31:23 +02:00
{
const int iVecSize = vecsData.Size();
// copy new data in internal buffer
int iCurPos = 0;
const int iEnd = iPutPos + iVecSize;
while ( iPutPos < iEnd )
{
vecsMemory[iPutPos++] = vecsData[iCurPos++];
}
// return "buffer is ready for readout" flag
return ( iEnd == iMemSize );
}
2009-07-30 20:36:37 +02:00
CVector<TData> Get()
2009-07-28 22:31:23 +02:00
{
iPutPos = 0;
return vecsMemory;
}
2006-01-28 12:29:22 +01:00
protected:
2009-07-28 22:31:23 +02:00
CVector<TData> vecsMemory;
int iMemSize;
int iPutPos;
2006-01-28 12:29:22 +01:00
};
2007-09-08 12:45:14 +02:00
#endif /* !defined ( BUFFER_H__3B123453_4344_BB23945IUHF1912__INCLUDED_ ) */