mmserv/tms/tmsimpl/src/tmsmembuffer.cpp
changeset 0 71ca22bcf22a
child 9 f5c5c82a163e
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/mmserv/tms/tmsimpl/src/tmsmembuffer.cpp	Tue Feb 02 01:08:46 2010 +0200
@@ -0,0 +1,171 @@
+/*
+ * 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;
+    }
+