diff -r 000000000000 -r 71ca22bcf22a mmserv/tms/tmsimpl/src/tmsvolumeeffectbodyimpl.cpp --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/mmserv/tms/tmsimpl/src/tmsvolumeeffectbodyimpl.cpp Tue Feb 02 01:08:46 2010 +0200 @@ -0,0 +1,180 @@ +/* + * 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 +#include +#include "tmscallproxy.h" +#include "tmsqueuehandler.h" +#include "tmsvolumeeffectbodyimpl.h" + +using namespace TMS; + +TMSVolumeEffectBodyImpl::TMSVolumeEffectBodyImpl() : + iObserver(NULL), + iProxy(NULL), + iParentEffect(NULL) + { + } + +TMSVolumeEffectBodyImpl::~TMSVolumeEffectBodyImpl() + { + } + +gint TMSVolumeEffectBodyImpl::Create(TMSVolumeEffectBody*& bodyimpl) + { + gint ret(TMS_RESULT_INSUFFICIENT_MEMORY); + TMSVolumeEffectBodyImpl* self = new TMSVolumeEffectBodyImpl; + if (self) + { + ret = self->PostConstruct(); + if (ret != TMS_RESULT_SUCCESS) + { + delete self; + self = NULL; + } + } + bodyimpl = self; + return ret; + } + +gint TMSVolumeEffectBodyImpl::PostConstruct() + { + gint ret(TMS_RESULT_SUCCESS); + return ret; + } + +gint TMSVolumeEffectBodyImpl::AddObserver(TMSEffectObserver& obsrvr, + gpointer user_data) + { + gint ret(TMS_RESULT_SUCCESS); + if (!iObserver) + { + iObserver = &obsrvr; + iUserData = user_data; + } + else + { + ret = TMS_RESULT_ALREADY_EXIST; + } + return ret; + } + +gint TMSVolumeEffectBodyImpl::RemoveObserver(TMSEffectObserver& obsrvr) + { + gint ret(TMS_RESULT_SUCCESS); + if (&obsrvr == iObserver) + { + iObserver = NULL; + } + else + { + ret = TMS_RESULT_DOES_NOT_EXIST; + } + return ret; + } + +gint TMSVolumeEffectBodyImpl::GetLevel(guint& level) + { + gint ret(TMS_RESULT_SUCCESS); + if (iProxy) + { + ret = iProxy->GetVolume(level); + } + else + { + ret = TMS_RESULT_DOES_NOT_EXIST; + } + return ret; + } + +gint TMSVolumeEffectBodyImpl::SetLevel(const guint level) + { + gint ret(TMS_RESULT_SUCCESS); + if (iProxy) + { + ret = iProxy->SetVolume(level); + } + else + { + ret = TMS_RESULT_DOES_NOT_EXIST; + } + return ret; + } + +gint TMSVolumeEffectBodyImpl::GetMaxLevel(guint& level) + { + gint ret(TMS_RESULT_SUCCESS); + if (iProxy) + { + ret = iProxy->GetMaxVolume(level); + } + else + { + ret = TMS_RESULT_DOES_NOT_EXIST; + } + return ret; + } + +gint TMSVolumeEffectBodyImpl::GetType(TMSEffectType& effecttype) + { + gint ret(TMS_RESULT_SUCCESS); + effecttype = TMS_EFFECT_VOLUME; + return ret; + } + +gint TMSVolumeEffectBodyImpl::SetParentEffect(TMSEffect*& parenteffect) + { + gint ret(TMS_RESULT_SUCCESS); + iParentEffect = NULL; + iParentEffect = parenteffect; + return ret; + } + +void TMSVolumeEffectBodyImpl::SetProxy(TMSCallProxy* aProxy, + gpointer queuehandler) + { + iProxy = aProxy; + if (queuehandler) + { + ((CQueueHandler*) queuehandler)->AddObserver(*this, TMS_EFFECT_VOLUME); + } + } + +void TMSVolumeEffectBodyImpl::QueueEvent(TInt aEventType, TInt aError, + void* /*user_data*/) + { + TMSSignalEvent event; + + event.type = TMS_EVENT_EFFECT_VOL_CHANGED; + event.reason = aError; + + switch (aEventType) + { + case TMS_EVENT_EFFECT_VOL_CHANGED: + { + if (iObserver && iParentEffect) + { + iObserver->EffectsEvent(iParentEffect, event); + } + } + break; + default: + break; + } + } + +// End of file