os/mm/devsound/devsoundpluginsupport/src/sounddevice/SoundDeviceBody.inl
changeset 0 bde4ae8d615e
     1.1 --- /dev/null	Thu Jan 01 00:00:00 1970 +0000
     1.2 +++ b/os/mm/devsound/devsoundpluginsupport/src/sounddevice/SoundDeviceBody.inl	Fri Jun 15 03:10:57 2012 +0200
     1.3 @@ -0,0 +1,710 @@
     1.4 +// Copyright (c) 2001-2009 Nokia Corporation and/or its subsidiary(-ies).
     1.5 +// All rights reserved.
     1.6 +// This component and the accompanying materials are made available
     1.7 +// under the terms of "Eclipse Public License v1.0"
     1.8 +// which accompanies this distribution, and is available
     1.9 +// at the URL "http://www.eclipse.org/legal/epl-v10.html".
    1.10 +//
    1.11 +// Initial Contributors:
    1.12 +// Nokia Corporation - initial contribution.
    1.13 +//
    1.14 +// Contributors:
    1.15 +//
    1.16 +// Description:
    1.17 +//
    1.18 +
    1.19 +#ifndef SOUNDDEVICEBODY_INL
    1.20 +#define SOUNDDEVICEBODY_INL
    1.21 +
    1.22 +#include <mmf/plugin/devsoundplugin.h>
    1.23 +
    1.24 +/*
    1.25 + *  -doxygen comments moved to header-
    1.26 + *
    1.27 + *	Initializes CMMFDevSound::CBody object to play and record PCM16 raw audio data
    1.28 + *	with sampling rate of 8 KHz.
    1.29 + *
    1.30 + *	On completion of Initialization, calls InitializeComplete() on
    1.31 + *	aDevSoundObserver.
    1.32 + *
    1.33 + *	Leaves on failure.
    1.34 + *
    1.35 + *	@param	"aDevSoundObserver"
    1.36 + *			A reference to DevSound Observer instance.
    1.37 + *
    1.38 + *	@param	"aMode"
    1.39 + *			Mode for which this object will be used.
    1.40 + *
    1.41 + */
    1.42 +inline void CMMFDevSound::CBody::InitializeL(MDevSoundObserver& aDevSoundObserver, TMMFState aMode)
    1.43 +
    1.44 +	{
    1.45 +	iPlugin->InitializeL(aDevSoundObserver,aMode);
    1.46 +	}
    1.47 +
    1.48 +/*
    1.49 + *  -doxygen comments moved to header-
    1.50 + *
    1.51 + *	Initializes DevSound object for the mode aMode for processing audio data
    1.52 + *	with hardware device aHWDev.
    1.53 + *
    1.54 + *	On completion of Initialization, the observer will be notified via call back
    1.55 + *	InitializeComplete().
    1.56 + *
    1.57 + *	Leaves on failure.
    1.58 + *
    1.59 + *	@param	"aDevSoundObserver"
    1.60 + *			A reference to DevSound Observer instance.
    1.61 + *
    1.62 + *	@param	"aHWDev"
    1.63 + *			CMMFHwDevice implementation identifier.
    1.64 + *
    1.65 + *	@param	"aMode"
    1.66 + *			Mode for which this object will be used.
    1.67 + *
    1.68 + */
    1.69 +inline void CMMFDevSound::CBody::InitializeL(MDevSoundObserver& aDevSoundObserver, TUid aHWDev, TMMFState aMode)
    1.70 +	{
    1.71 +	iPlugin->InitializeL(aDevSoundObserver, aHWDev, aMode);
    1.72 +	}
    1.73 +
    1.74 +/*
    1.75 + *  -doxygen comments moved to header-
    1.76 + *
    1.77 + *	Initializes DevSound object for the mode aMode for processing audio data
    1.78 + *	with hardware device supporting FourCC aDesiredFourCC.
    1.79 + *
    1.80 + *	On completion of Initialization, the observer will be notified via call back
    1.81 + *	InitializeComplete().
    1.82 + *
    1.83 + *	Leaves on failure.
    1.84 + *
    1.85 + *	@param	"aDevSoundObserver"
    1.86 + *			A reference to DevSound Observer instance.
    1.87 + *
    1.88 + *	@param	"aDesiredFourCC"
    1.89 + *			CMMFHwDevice implementation FourCC.
    1.90 + *
    1.91 + *	@param	"aMode"
    1.92 + *			Mode for which this object will be used.
    1.93 + *
    1.94 + */
    1.95 +inline void CMMFDevSound::CBody::InitializeL(MDevSoundObserver& aDevSoundObserver, 
    1.96 +										  TFourCC aDesiredFourCC, TMMFState aMode)
    1.97 +	{
    1.98 +	iPlugin->InitializeL(aDevSoundObserver, aDesiredFourCC, aMode);
    1.99 +	}
   1.100 +
   1.101 +/*
   1.102 + *  -doxygen comments moved to header-
   1.103 + *
   1.104 + *	Returns the supported Audio settings.
   1.105 + *
   1.106 + *	@return	"TMMFCapabilities"
   1.107 + *			Device settings.
   1.108 + *
   1.109 + */
   1.110 +inline TMMFCapabilities CMMFDevSound::CBody::Capabilities()
   1.111 +	{
   1.112 +	return iPlugin->Capabilities();
   1.113 +	}
   1.114 +
   1.115 +/*
   1.116 + *  -doxygen comments moved to header-
   1.117 + *
   1.118 + *	Returns the current audio settings.
   1.119 + *
   1.120 + *	@return	"TMMFCapabilities"
   1.121 + *			Device settings.
   1.122 + *
   1.123 + */
   1.124 +inline TMMFCapabilities CMMFDevSound::CBody::Config() const
   1.125 +	{
   1.126 +	return iPlugin->Config();
   1.127 +	}
   1.128 +
   1.129 +/*
   1.130 + *  -doxygen comments moved to header-
   1.131 + *
   1.132 + *	Configure CMMFDevSound::CBody object for the settings in aConfig.
   1.133 + *
   1.134 + *	Use this to set sampling rate, Encoding and Mono/Stereo.
   1.135 + *
   1.136 + *	@param	"aConfig"
   1.137 + *			Attribute values to which CMMFDevSound::CBody object will be configured to.
   1.138 + *
   1.139 + */
   1.140 +inline void CMMFDevSound::CBody::SetConfigL(const TMMFCapabilities& aConfig)
   1.141 +	{
   1.142 +	iPlugin->SetConfigL(aConfig);
   1.143 +	}
   1.144 +
   1.145 +/*
   1.146 + *  -doxygen comments moved to header-
   1.147 + *
   1.148 + *	Returns an integer representing the maximum volume.
   1.149 + *
   1.150 + *	This is the maximum value which can be passed to CMMFDevSound::CBody::SetVolume.
   1.151 + *
   1.152 + *	@return	"TInt"
   1.153 + *			The maximum volume. This value is platform dependent but is always
   1.154 + *			greater than or equal to one.
   1.155 + *
   1.156 + */
   1.157 +inline TInt CMMFDevSound::CBody::MaxVolume()
   1.158 +	{
   1.159 +	return iPlugin->MaxVolume();
   1.160 +	}
   1.161 +
   1.162 +/*
   1.163 + *  -doxygen comments moved to header-
   1.164 + *
   1.165 + *	Returns an integer representing the current volume.
   1.166 + *
   1.167 + *	@return	"TInt"
   1.168 + *			The current volume level.
   1.169 + *
   1.170 + */
   1.171 +inline TInt CMMFDevSound::CBody::Volume()
   1.172 +	{
   1.173 +	return iPlugin->Volume();
   1.174 +	}
   1.175 +
   1.176 +/*
   1.177 + *  -doxygen comments moved to header-
   1.178 + *
   1.179 + *	Changes the current playback volume to a specified value.
   1.180 + *
   1.181 + *	The volume can be changed before or during playback and is effective
   1.182 + *	immediately.
   1.183 + *
   1.184 + *	@param	"aVolume"
   1.185 + *			The volume setting. This can be any value from zero to the value
   1.186 + *			returned by a call to CMMFDevSound::CBody::MaxVolume(). If the
   1.187 + *			volume is not within this range, the volume is automatically set to
   1.188 + *			minimum or maximum value based on the value that is being passed.
   1.189 + *			Setting a zero value mutes the sound. Setting the maximum value
   1.190 + *			results in the loudest possible sound.
   1.191 + *
   1.192 + */
   1.193 +inline void CMMFDevSound::CBody::SetVolume(TInt aVolume)
   1.194 +	{
   1.195 +	iPlugin->SetVolume(aVolume);
   1.196 +	}
   1.197 +
   1.198 +/*
   1.199 + *  -doxygen comments moved to header-
   1.200 + *
   1.201 + *	Returns an integer representing the maximum gain.
   1.202 + *
   1.203 + *	This is the maximum value which can be passed to CMMFDevSound::CBody::SetGain.
   1.204 + *
   1.205 + *	@return	"TInt"
   1.206 + *			The maximum gain. This value is platform dependent but is always
   1.207 + *			greater than or equal to one.
   1.208 + *
   1.209 + */
   1.210 +inline TInt CMMFDevSound::CBody::MaxGain()
   1.211 +	{
   1.212 +	return iPlugin->MaxGain();
   1.213 +	}
   1.214 +
   1.215 +/*
   1.216 + *  -doxygen comments moved to header-
   1.217 + *
   1.218 + *	Returns an integer representing the current gain.
   1.219 + *
   1.220 + *	@return	"TInt"
   1.221 + *			The current gain level.
   1.222 + *
   1.223 + */
   1.224 +inline TInt CMMFDevSound::CBody::Gain()
   1.225 +	{
   1.226 +	return iPlugin->Gain();
   1.227 +	}
   1.228 +
   1.229 +/*
   1.230 + *  -doxygen comments moved to header-
   1.231 + *
   1.232 + *	Changes the current recording gain to a specified value.
   1.233 + *
   1.234 + *	The gain can be changed before or during recording and is effective
   1.235 + *	immediately.
   1.236 + *
   1.237 + *	@param	"TInt aGain"
   1.238 + *			The gain setting. This can be any value from zero to the value
   1.239 + *			returned by a call to CMMFDevSound::CBody::MaxGain(). If the
   1.240 + *			volume is not within this range, the gain is automatically set to
   1.241 + *			minimum or maximum value based on the value that is being passed.
   1.242 + *			Setting a zero value mutes the sound. Setting the maximum value
   1.243 + *			results in the loudest possible sound.
   1.244 + *
   1.245 + */
   1.246 +inline void CMMFDevSound::CBody::SetGain(TInt aGain)
   1.247 +	{
   1.248 +	iPlugin->SetGain(aGain);
   1.249 +	}
   1.250 +
   1.251 +/*
   1.252 + *  -doxygen comments moved to header-
   1.253 + *
   1.254 + *	Returns the speaker balance set for playing.
   1.255 + *
   1.256 + *	Leaves on failure.
   1.257 + *
   1.258 + *	@param	"aLeftPrecentage"
   1.259 + *			On return contains the left speaker volume percentage.
   1.260 + *
   1.261 + *	@param	"aRightPercentage"
   1.262 + *			On return contains the right speaker volume percentage.
   1.263 + *
   1.264 + */
   1.265 +inline void CMMFDevSound::CBody::GetPlayBalanceL(TInt& aLeftPercentage, TInt& aRightPercentage)
   1.266 +	{
   1.267 +	iPlugin->GetPlayBalanceL(aLeftPercentage, aRightPercentage);
   1.268 +	}
   1.269 +
   1.270 +/*
   1.271 + *  -doxygen comments moved to header-
   1.272 + *
   1.273 + *	Sets the speaker balance for playing.
   1.274 + *
   1.275 + *	The speaker balance can be changed before or during playback and is
   1.276 + *	effective immediately.
   1.277 + *
   1.278 + *	@param	"aLeftPercentage"
   1.279 + *			On return contains left speaker volume perecentage. This can be any
   1.280 + *			value from zero to 100. Setting a zero value mutes the sound on left
   1.281 + *			speaker.
   1.282 + *
   1.283 + *	@param	"aRightPercentage"
   1.284 + *			On return contains right speaker volume perecentage. This can be any
   1.285 + *			value from zero to 100. Setting a zero value mutes the sound on
   1.286 + *			right speaker.
   1.287 + *
   1.288 + */
   1.289 +inline void CMMFDevSound::CBody::SetPlayBalanceL(TInt aLeftPercentage, TInt aRightPercentage)
   1.290 +	{
   1.291 +	iPlugin->SetPlayBalanceL(aLeftPercentage, aRightPercentage);
   1.292 +	}
   1.293 +
   1.294 +/*
   1.295 + *  -doxygen comments moved to header-
   1.296 + *
   1.297 + *	Returns the microphone gain balance set for recording.
   1.298 + *
   1.299 + *	Leaves on failure.
   1.300 + *
   1.301 + *	@param	"aLeftPercentage"
   1.302 + *			On return contains the left microphone gain percentage.
   1.303 + *
   1.304 + *	@param	"aRightPercentage"
   1.305 + *			On return contains the right microphone gain percentage.
   1.306 + *
   1.307 + */
   1.308 +inline void CMMFDevSound::CBody::GetRecordBalanceL(TInt& aLeftPercentage, TInt& aRightPercentage)
   1.309 +	{
   1.310 +	iPlugin->GetRecordBalanceL(aLeftPercentage, aRightPercentage);
   1.311 +	}
   1.312 +
   1.313 +/*
   1.314 + *  -doxygen comments moved to header-
   1.315 + *
   1.316 + *	Sets the microphone gain balance for recording.
   1.317 + *
   1.318 + *	The microphone gain balance can be changed before or during recording and
   1.319 + *	is effective immediately.
   1.320 + *
   1.321 + *	@param	"aLeftPercentage"
   1.322 + *			Left microphone gain precentage. This can be any value from zero to
   1.323 + *			100. Setting a zero value mutes the gain on left microphone.
   1.324 + *
   1.325 + *	@param	"aRightPercentage"
   1.326 + *			Right microphone gain precentage. This can be any value from zero to
   1.327 + *			100. Setting a zero value mutes the gain on right microphone.
   1.328 + *
   1.329 + */
   1.330 +inline void CMMFDevSound::CBody::SetRecordBalanceL(TInt aLeftPercentage, TInt aRightPercentage)
   1.331 +	{
   1.332 +	iPlugin->SetRecordBalanceL(aLeftPercentage, aRightPercentage);
   1.333 +	}
   1.334 +
   1.335 +/*
   1.336 + *  -doxygen comments moved to header-
   1.337 + *
   1.338 + *	Initializes audio device and start play process. This method queries and
   1.339 + *	acquires the audio policy before initializing audio device. If there was an
   1.340 + *	error during policy initialization, PlayError() method will be called on
   1.341 + *	the observer with error code KErrAccessDenied, otherwise BufferToBeFilled()
   1.342 + *	method will be called with a buffer reference. After reading data into the
   1.343 + *	buffer reference passed, the client should call PlayData() to play data.
   1.344 + *
   1.345 + *	The amount of data that can be played is specified in
   1.346 + *	CMMFBuffer::RequestSize(). Any data that is read into buffer beyond this
   1.347 + *	size will be ignored.
   1.348 + *
   1.349 + *	Leaves on failure.
   1.350 + *
   1.351 + */
   1.352 +inline void CMMFDevSound::CBody::PlayInitL()
   1.353 +	{
   1.354 +	iPlugin->PlayInitL();
   1.355 +	}
   1.356 +
   1.357 +/*
   1.358 + *  -doxygen comments moved to header-
   1.359 + *
   1.360 + *	Initializes audio device and start record process. This method queries and
   1.361 + *	acquires the audio policy before initializing audio device. If there was an
   1.362 + *	error during policy initialization, RecordError() method will be called on
   1.363 + *	the observer with error code KErrAccessDenied, otherwise BufferToBeEmptied()
   1.364 + *	method will be called with a buffer reference. This buffer contains recorded
   1.365 + *	or encoded data. After processing data in the buffer reference passed, the
   1.366 + *	client should call RecordData() to continue recording process.
   1.367 + *
   1.368 + *	The amount of data that is available is specified in
   1.369 + *	CMMFBuffer::RequestSize().
   1.370 + *
   1.371 + *	Leaves on failure.
   1.372 + *
   1.373 + */
   1.374 +inline void CMMFDevSound::CBody::RecordInitL()
   1.375 +	{
   1.376 +	iPlugin->RecordInitL();
   1.377 +	}
   1.378 +
   1.379 +/*
   1.380 + *  -doxygen comments moved to header-
   1.381 + *
   1.382 + *	Plays data in the buffer at the current volume. The client should fill
   1.383 + *	the buffer with audio data before calling this method. The Observer gets
   1.384 + *	reference to buffer along with callback BufferToBeFilled(). When playing of
   1.385 + *	the audio sample is complete, successfully or otherwise, the method
   1.386 + *	PlayError() on observer is called.
   1.387 + *
   1.388 + */
   1.389 +inline void CMMFDevSound::CBody::PlayData()
   1.390 +	{
   1.391 +	iPlugin->PlayData();
   1.392 +	}
   1.393 +
   1.394 +/*
   1.395 + *  -doxygen comments moved to header-
   1.396 + *
   1.397 + *	Contine the process of recording. Once the buffer is filled with recorded
   1.398 + *	data, the Observer gets reference to buffer along with callback
   1.399 + *	BufferToBeEmptied(). After processing the buffer (copying over to a
   1.400 + *	different buffer or writing to file) the client should call this
   1.401 + *	method to continue recording process.
   1.402 + *
   1.403 + */
   1.404 +inline void CMMFDevSound::CBody::RecordData()
   1.405 +	{
   1.406 +	iPlugin->RecordData();
   1.407 +	}
   1.408 +
   1.409 +/*
   1.410 + *  -doxygen comments moved to header-
   1.411 + *
   1.412 + *	Stops the ongoing operation (Play, Record, TonePlay, Convert)
   1.413 + *
   1.414 + */
   1.415 +inline void CMMFDevSound::CBody::Stop()
   1.416 +	{
   1.417 +	iPlugin->Stop();
   1.418 +	}
   1.419 +
   1.420 +/*
   1.421 + *  -doxygen comments moved to header-
   1.422 + *
   1.423 + *	Temporarily Stops the ongoing operation (Play, Record, TonePlay, Convert)
   1.424 + *
   1.425 + */
   1.426 +inline void CMMFDevSound::CBody::Pause()
   1.427 +	{
   1.428 +	iPlugin->Pause();
   1.429 +	}
   1.430 +
   1.431 +/*
   1.432 + *  -doxygen comments moved to header-
   1.433 + *
   1.434 + *	Returns the sample recorded so far.
   1.435 + *
   1.436 + *	@return "TInt"
   1.437 + *			Returns the samples recorded.
   1.438 + *
   1.439 + */
   1.440 +inline TInt CMMFDevSound::CBody::SamplesRecorded()
   1.441 +	{ 
   1.442 +	return iPlugin->SamplesRecorded();
   1.443 +	}
   1.444 +
   1.445 +/*
   1.446 + *  -doxygen comments moved to header-
   1.447 + *
   1.448 + *	Returns the sample played so far.
   1.449 + *
   1.450 + *	@return "TInt"
   1.451 + *			Returns the samples recorded.
   1.452 + *
   1.453 + */
   1.454 +inline TInt CMMFDevSound::CBody::SamplesPlayed()
   1.455 +	{ 
   1.456 +	return iPlugin->SamplesPlayed();
   1.457 +	}
   1.458 +
   1.459 +
   1.460 +/*
   1.461 + *  -doxygen comments moved to header-
   1.462 + *
   1.463 + *	Initializes audio device and start playing tone. Tone is played with
   1.464 + *	frequency and for duration specified.
   1.465 + *
   1.466 + *	Leaves on failure.
   1.467 + *
   1.468 + *	@param	"aFrequency"
   1.469 + *			Frequency at with the tone will be played.
   1.470 + *
   1.471 + *	@param	"aDuration"
   1.472 + *			The period over which the tone will be played. A zero value causes
   1.473 + *			the no tone to be played (Verify this with test app).
   1.474 + *
   1.475 + */
   1.476 +inline void CMMFDevSound::CBody::PlayToneL(TInt aFrequency, const TTimeIntervalMicroSeconds& aDuration)
   1.477 +	{
   1.478 +	iPlugin->PlayToneL(aFrequency, aDuration);
   1.479 +	}
   1.480 +
   1.481 +/*
   1.482 + *  -doxygen comments moved to header-
   1.483 + *
   1.484 + *	Initializes audio device and start playing a dual tone. 
   1.485 + *  The tone consists of two sine waves of different frequencies summed together
   1.486 + *  Dual Tone is played with specified frequencies and for specified duration.
   1.487 + *
   1.488 + *	@param	"aFrequencyOne"
   1.489 + *			First frequency of dual tone
   1.490 + *
   1.491 + *	@param	"aFrequencyTwo"
   1.492 + *			Second frequency of dual tone
   1.493 + *
   1.494 + *	@param	"aDuration"
   1.495 + *			The period over which the tone will be played. A zero value causes
   1.496 + *			the no tone to be played (Verify this with test app).
   1.497 + */
   1.498 +inline void CMMFDevSound::CBody::PlayDualToneL(TInt aFrequencyOne, TInt aFrequencyTwo, const TTimeIntervalMicroSeconds& aDuration)
   1.499 +	{
   1.500 +	iPlugin->PlayDualToneL(aFrequencyOne, aFrequencyTwo, aDuration);
   1.501 +	}
   1.502 +
   1.503 +/*
   1.504 + *  -doxygen comments moved to header-
   1.505 + *
   1.506 + *	Initializes audio device and start playing DTMF string aDTMFString.
   1.507 + *
   1.508 + *	Leaves on failure.
   1.509 + *
   1.510 + *	@param	"aDTMFString"
   1.511 + *			DTMF sequence in a descriptor.
   1.512 + *
   1.513 + */
   1.514 +inline void CMMFDevSound::CBody::PlayDTMFStringL(const TDesC& aDTMFString)
   1.515 +	{
   1.516 +	iPlugin->PlayDTMFStringL(aDTMFString);
   1.517 +	}
   1.518 +
   1.519 +/*
   1.520 + *  -doxygen comments moved to header-
   1.521 + *
   1.522 + *	Initializes audio device and start playing tone sequence.
   1.523 + *
   1.524 + *	Leaves on failure.
   1.525 + *
   1.526 + *	@param	"TDesC8& aData"
   1.527 + *			Tone sequence in a descriptor.
   1.528 + *
   1.529 + */
   1.530 +inline void CMMFDevSound::CBody::PlayToneSequenceL(const TDesC8& aData)
   1.531 +	{
   1.532 +	iPlugin->PlayToneSequenceL(aData);
   1.533 +	}
   1.534 +
   1.535 +/*
   1.536 + *  -doxygen comments moved to header-
   1.537 + *
   1.538 + *	Initializes audio device and start playing the specified pre-defined tone
   1.539 + *	sequence.
   1.540 + *
   1.541 + *	Leaves on failure.
   1.542 + *
   1.543 + *	@param	"aSequenceNumber"
   1.544 + *			The index identifying the specific pre-defined tone sequence. Index
   1.545 + *			values are relative to zero.
   1.546 + *			This can be any value from zero to the value returned by a call to
   1.547 + *			FixedSequenceCount() - 1.
   1.548 + *			The function raises a panic if sequence number is not within this
   1.549 + *			range.
   1.550 + *	@see	FixedSequenceCount()
   1.551 + *
   1.552 + */
   1.553 +inline void CMMFDevSound::CBody::PlayFixedSequenceL(TInt aSequenceNumber)
   1.554 +	{
   1.555 +	iPlugin->PlayFixedSequenceL(aSequenceNumber);
   1.556 +	}
   1.557 +
   1.558 +/*
   1.559 + *  -doxygen comments moved to header-
   1.560 + *
   1.561 + *	Defines the number of times the audio is to be repeated during the tone
   1.562 + *	playback operation.
   1.563 + *
   1.564 + *	A period of silence can follow each playing of tone. The tone playing can
   1.565 + *	be repeated indefinitely.
   1.566 + *
   1.567 + *	@param	" aRepeatCount"
   1.568 + *			The number of times the tone, together with the trailing silence,
   1.569 + *			is to be repeated. If this is set to KMdaRepeatForever, then the
   1.570 + *			tone, together with the trailing silence, is repeated indefinitely
   1.571 + *			or until Stop() is called. If this is set to zero, then the tone is
   1.572 + *			not repeated.
   1.573 + *
   1.574 + *			Supported only during tone playing.
   1.575 + *
   1.576 + */
   1.577 +inline void CMMFDevSound::CBody::SetToneRepeats(TInt aRepeatCount,
   1.578 +				const TTimeIntervalMicroSeconds& aRepeatTrailingSilence)
   1.579 +	{
   1.580 +	iPlugin->SetToneRepeats(aRepeatCount, aRepeatTrailingSilence);
   1.581 +	}
   1.582 +
   1.583 +/*
   1.584 + *  -doxygen comments moved to header-
   1.585 + *
   1.586 + *	Defines the duration of tone on, tone off and tone pause to be used during the
   1.587 + *	DTMF tone playback operation.
   1.588 + *
   1.589 + *	Supported only during tone playing.
   1.590 + *
   1.591 + *	@param	"aToneOnLength"
   1.592 + *			The period over which the tone will be played. If this is set to
   1.593 + *			zero, then the tone is not played.
   1.594 + *
   1.595 + *	@param	"aToneOffLength"
   1.596 + *			The period over which the no tone will be played.
   1.597 + *
   1.598 + *	@param	"aPauseLength"
   1.599 + *			The period over which the tone playing will be paused.
   1.600 + *
   1.601 + */
   1.602 +inline void CMMFDevSound::CBody::SetDTMFLengths(TTimeIntervalMicroSeconds32& aToneOnLength,
   1.603 +								TTimeIntervalMicroSeconds32& aToneOffLength,
   1.604 +								TTimeIntervalMicroSeconds32& aPauseLength) 
   1.605 +	{
   1.606 +	iPlugin->SetDTMFLengths(aToneOnLength, aToneOffLength, aPauseLength);
   1.607 +	}
   1.608 +
   1.609 +/*
   1.610 + *  -doxygen comments moved to header-
   1.611 + *
   1.612 + *	Defines the period over which the volume level is to rise smoothly from
   1.613 + *	nothing to the normal volume level.
   1.614 + *
   1.615 + *	@param	"aRampDuration"
   1.616 + *			The period over which the volume is to rise. A zero value causes 
   1.617 + *			the tone sample to be played at the normal level for the full
   1.618 + *			duration of the playback. A value, which is longer than the duration
   1.619 + *			of the tone sample, that the sample never reaches its normal
   1.620 + *			volume level.
   1.621 + *
   1.622 + *
   1.623 + */
   1.624 +inline void CMMFDevSound::CBody::SetVolumeRamp(const TTimeIntervalMicroSeconds& aRampDuration)
   1.625 +	{	
   1.626 +	iPlugin->SetVolumeRamp(aRampDuration);
   1.627 +	}
   1.628 +
   1.629 +/*
   1.630 + *  -doxygen comments moved to header-
   1.631 + *
   1.632 + *	Defines the priority settings that should be used for this instance.
   1.633 + *
   1.634 + *	@param	"aPrioritySettings"
   1.635 + *			An class type representing the client's priority, priority 
   1.636 + *			preference and state.
   1.637 + *
   1.638 + */
   1.639 +inline void CMMFDevSound::CBody::SetPrioritySettings(const TMMFPrioritySettings& aPrioritySettings)
   1.640 +	{
   1.641 +	iPlugin->SetPrioritySettings(aPrioritySettings);
   1.642 +	}
   1.643 +
   1.644 +inline TAny* CMMFDevSound::CBody::CustomInterface(TUid aInterface)
   1.645 +	{
   1.646 +	return iPlugin->CustomInterface(aInterface);
   1.647 +	}
   1.648 +
   1.649 +/*
   1.650 + *  -doxygen comments moved to header-
   1.651 + *
   1.652 + *	Returns the number of available pre-defined tone sequences.
   1.653 + *
   1.654 + *	This is the number of fixed sequence supported by DevSound by default.
   1.655 + *
   1.656 + *	@return	"TInt"
   1.657 + *			The fixed sequence count. This value is implementation dependent
   1.658 + *			but is always greater than or equal to zero.
   1.659 + *
   1.660 + */
   1.661 +inline TInt CMMFDevSound::CBody::FixedSequenceCount()
   1.662 +	{
   1.663 +	return iPlugin->FixedSequenceCount();
   1.664 +	}
   1.665 +
   1.666 +/*
   1.667 + *  -doxygen comments moved to header-
   1.668 + *
   1.669 + *	Returns the name assigned to a specific pre-defined tone sequence.
   1.670 + *
   1.671 + *	This is the number of fixed sequence supported by DevSound by default.
   1.672 + *
   1.673 + *	The function raises a panic if sequence number specified invalid.
   1.674 + *
   1.675 + *	@return	"TDesC&"
   1.676 + *			A reference to a Descriptor containing the fixed sequence
   1.677 + *			name indexed by aSequenceNumber.
   1.678 + *
   1.679 + *	@param	"aSequenceNumber"
   1.680 + *			The index identifying the specific pre-defined tone sequence. Index
   1.681 + *			values are relative to zero.
   1.682 + *			This can be any value from zero to the value returned by a call to
   1.683 + *			FixedSequenceCount() - 1.
   1.684 + *			The function raises a panic if sequence number is not within this
   1.685 + *			range.
   1.686 + *
   1.687 + *	@see	FixedSequenceCount()
   1.688 + *
   1.689 + */
   1.690 +inline const TDesC& CMMFDevSound::CBody::FixedSequenceName(TInt aSequenceNumber)
   1.691 +	{
   1.692 +	return iPlugin->FixedSequenceName(aSequenceNumber);
   1.693 +	}
   1.694 +
   1.695 +
   1.696 +/*
   1.697 + *  -doxygen comments in header-
   1.698 + */
   1.699 +inline void CMMFDevSound::CBody::GetSupportedInputDataTypesL(RArray<TFourCC>& aSupportedDataTypes,const TMMFPrioritySettings& aPrioritySettings) const
   1.700 +	{
   1.701 +	iPlugin->GetSupportedInputDataTypesL(aSupportedDataTypes, aPrioritySettings);
   1.702 +	}
   1.703 +
   1.704 +
   1.705 +/*
   1.706 + *  -doxygen comments in header-
   1.707 + */
   1.708 +inline void CMMFDevSound::CBody::GetSupportedOutputDataTypesL(RArray<TFourCC>& aSupportedDataTypes, const TMMFPrioritySettings& aPrioritySettings) const
   1.709 +	{
   1.710 +	iPlugin->GetSupportedOutputDataTypesL(aSupportedDataTypes, aPrioritySettings);
   1.711 +	}
   1.712 +
   1.713 +#endif // SOUNDDEVICEBODY_INL