/*
* Copyright (c) 2009 Nokia Corporation and/or its subsidiary(-ies).
* All rights reserved.
* This component and the accompanying materials are made available
* under the terms of "Eclipse Public License v1.0"
* which accompanies this distribution, and is available
* at the URL "http://www.eclipse.org/legal/epl-v10.html".
*
* Initial Contributors:
* Nokia Corporation - initial contribution.
*
* Contributors:
*
* Description: Telephony Multimedia Service
*
*/
#include <stdlib.h>
#include "tmsutility.h"
#include "tmsmembuffer.h"
using namespace TMS;
TMSMemBuffer::TMSMemBuffer() :
iOwnsBuffer(FALSE)
{
}
TMSMemBuffer::~TMSMemBuffer()
{
if (iOwnsBuffer)
{
free(iDataPtr);
}
}
gint TMSMemBuffer::Create(guint size, TMSBuffer*& bodyimpl)
{
gint ret(TMS_RESULT_INSUFFICIENT_MEMORY);
TRACE_PRN_FN_ENT;
TMSMemBuffer* self = new TMSMemBuffer;
if (self)
{
ret = self->PostConstruct(size);
if (ret != TMS_RESULT_SUCCESS)
{
delete self;
self = NULL;
}
}
bodyimpl = self;
TRACE_PRN_FN_EXT;
return ret;
}
gint TMSMemBuffer::Create(guint size, guint8* dataptr, TMSBuffer*& tmsbuffer)
{
gint ret(TMS_RESULT_INSUFFICIENT_MEMORY);
TRACE_PRN_FN_ENT;
TMSMemBuffer* self = new TMSMemBuffer;
if (self)
{
self->iDataPtr = dataptr;
ret = TMS_RESULT_SUCCESS;
}
self->iOwnsBuffer = FALSE;
self->iBufferSize = size;
tmsbuffer = self;
TRACE_PRN_FN_EXT;
return ret;
}
gint TMSMemBuffer::PostConstruct(guint size)
{
gint ret(TMS_RESULT_SUCCESS);
TRACE_PRN_FN_ENT;
iDataPtr = (guint8*) malloc(size);
if (!iDataPtr)
{
ret = TMS_RESULT_INSUFFICIENT_MEMORY;
}
iOwnsBuffer = TRUE;
iBufferSize = size;
TRACE_PRN_FN_EXT;
return ret;
}
gint TMSMemBuffer::GetType(TMSBufferType& buffertype)
{
gint ret(TMS_RESULT_SUCCESS);
buffertype = TMS_BUFFER_MEMORY;
return ret;
}
// Implementation of TMSBuffer interface begins
/**
Gets the timestamp on the Buffer so that the framework can
determine the time at which this buffer has to be rendered
by the output device sink.
@param ts
timestamp in microseconds
*/
gint TMSMemBuffer::GetTimeStamp(guint64& ts)
{
gint ret(TMS_RESULT_SUCCESS);
ts = iTimeStamp;
return ret;
}
/**
Sets the timestamp on the Buffer so that the framework can
determine the time at which this buffer has to be rendered
by the output device sink.
@param ts
timestamp in milliseconds
*/
gint TMSMemBuffer::SetTimeStamp(const guint64 ts)
{
gint ret(TMS_RESULT_SUCCESS);
iTimeStamp = ts;
return ret;
}
/**
Gets the size of data in the buffer specified by the client.
@param size
size of data in bytes
*/
gint TMSMemBuffer::GetDataSize(guint& size)
{
gint ret(TMS_RESULT_SUCCESS);
size = iBufferSize;
return ret;
}
/**
Sets the size of data in the buffer after the client
fill it.
@param size
size of data in bytes
*/
gint TMSMemBuffer::SetDataSize(const guint size)
{
gint ret(TMS_RESULT_SUCCESS);
iBufferSize = size;
return ret;
}
/**
Gets the pointer to the memory location associated with this
buffer where the data is stored.
@param bufptr
ptr to the data stored in the buffer.
*/
gint TMSMemBuffer::GetDataPtr(guint8*& bufptr)
{
gint ret(TMS_RESULT_SUCCESS);
bufptr = iDataPtr;
return ret;
}