qtms/src/qtmsmembuffer.cpp
author hgs
Fri, 25 Jun 2010 17:07:52 -0500
changeset 40 4a1905d205a2
parent 32 edd273b3192a
child 50 762d760dcfdf
permissions -rw-r--r--
201025

/*
 * Copyright (c) 2010 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: QT Bindings for TMS
 *
 */

#include <qtms.h>
#include <tmsbuffer.h>
#include "tmsutility.h"
#include "qtmsmembuffer.h"

using namespace QTMS;
using namespace TMS;

QTMSMemBuffer::QTMSMemBuffer()
    {
    iTmsBuffer = NULL;
    iOwnsBuffer = FALSE;
    }

QTMSMemBuffer::~QTMSMemBuffer()
    {
    if (iOwnsBuffer)
        {
        free(iDataPtr);
        }
    }

gint QTMSMemBuffer::Create(QTMSBuffer*& buffer, TMS::TMSBuffer*& tmsbuffer)
    {
    gint ret(QTMS_RESULT_INSUFFICIENT_MEMORY);
    TRACE_PRN_FN_ENT;
    QTMSMemBuffer* self = new QTMSMemBuffer();
    if (self)
        {
        self->iTmsBuffer = tmsbuffer;
        tmsbuffer->GetDataPtr(self->iDataPtr);
        tmsbuffer->GetDataSize(self->iBufferSize);
        tmsbuffer->GetTimeStamp(self->iTimeStamp);
        self->iOwnsBuffer = FALSE;
        }
    buffer = self;
    TRACE_PRN_FN_EXT;
    return ret;
    }

gint QTMSMemBuffer::GetType(QTMSBufferType& buffertype)
    {
    gint ret(TMS_RESULT_SUCCESS);
    buffertype = QTMS_BUFFER_MEMORY;
    return ret;
    }

/**
 * 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 QTMSMemBuffer::GetTimeStamp(guint64& ts)
    {
    gint ret(QTMS_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 QTMSMemBuffer::SetTimeStamp(const guint64 ts)
    {
    gint ret(QTMS_RESULT_SUCCESS);
    iTimeStamp = ts;
    ret = iTmsBuffer->SetTimeStamp(ts);
    return ret;
    }

/**
 * Gets the size of data in the buffer specified by the client.
 *
 * @param size size of data in bytes
 *
 */
gint QTMSMemBuffer::GetDataSize(guint& size)
    {
    gint ret(QTMS_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 QTMSMemBuffer::SetDataSize(const guint size)
    {
    gint ret(QTMS_RESULT_SUCCESS);
    ret = iTmsBuffer->SetDataSize(size);
    iBufferSize = size; //TODO: should realloc when new size > old 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 QTMSMemBuffer::GetDataPtr(guint8*& bufptr)
    {
    gint ret(QTMS_RESULT_SUCCESS);
    bufptr = iDataPtr;
    return ret;
    }