devsound/devsoundrefplugin/tsrc/swcdwrap/TSU_MMF_SWCDWRAP_RecordHwDevObserver.cpp
author hgs
Fri, 08 Oct 2010 19:40:43 +0100
changeset 0 79dd3e2336a0
permissions -rw-r--r--
2010wk36_01
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
0
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
     1
// Copyright (c) 2003-2009 Nokia Corporation and/or its subsidiary(-ies).
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
     2
// All rights reserved.
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
     3
// This component and the accompanying materials are made available
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
     4
// under the terms of "Eclipse Public License v1.0"
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
     5
// which accompanies this distribution, and is available
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
     6
// at the URL "http://www.eclipse.org/legal/epl-v10.html".
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
     7
//
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
     8
// Initial Contributors:
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
     9
// Nokia Corporation - initial contribution.
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    10
//
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    11
// Contributors:
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    12
//
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    13
// Description:
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    14
//
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    15
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    16
// Test system includes
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    17
#include "TSU_MMF_SWCDWRAP_RecordHwDevObserver.h"
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    18
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    19
CTestRecordMMFHwDeviceObserver::CTestRecordMMFHwDeviceObserver(CMMFHwDevice* aHwDevice) : CTestMMFHwDeviceObserver(aHwDevice)
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    20
	{
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    21
	}
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    22
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    23
CTestRecordMMFHwDeviceObserver::~CTestRecordMMFHwDeviceObserver()
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    24
	{
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    25
	iSinkFile.Close();
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    26
	delete iFileWriter;
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    27
	}
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    28
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    29
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    30
TInt CTestRecordMMFHwDeviceObserver::WriteBufferDirectToFileAsync(const TDesC& aFileName, TUint aNumberOfBuffers)
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    31
	{
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    32
	TInt error = KErrNone;
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    33
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    34
	if (!iFileServerSession.Handle())
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    35
		{//open a handle to the file server
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    36
		error = iFileServerSession.Connect();
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    37
		}
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    38
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    39
	if (!error)
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    40
		{
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    41
		//make sure file to be recorded is deleted before we start
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    42
		error = iFileServerSession.Delete(aFileName); 
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    43
		if (error == KErrNotFound)
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    44
			error = KErrNone; //KErrNotFound is not an error, means file doesn't exist
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    45
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    46
		if (!error)
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    47
			{
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    48
			error = iSinkFile.Create(iFileServerSession, aFileName, EFileWrite);
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    49
			if (!error)
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    50
				{
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    51
				if (!iFileWriter)
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    52
					TRAP(error,iFileWriter = new(ELeave) CTestFileWriter(iSinkFile, this));	
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    53
				}
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    54
			if (!error)
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    55
				{
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    56
				iNumberOfBuffers = aNumberOfBuffers;
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    57
				}
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    58
			}
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    59
		}	
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    60
	return error; 
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    61
	}
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    62
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    63
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    64
void CTestRecordMMFHwDeviceObserver::FileWriteComplete(TInt aError)
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    65
	{
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    66
	if (aError == KErrNone)
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    67
		{
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    68
		TInt error = KErrNone;
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    69
		if (iCurrentBufferNumber >= iNumberOfBuffers)
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    70
			{
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    71
			error = iHwDevice->Stop();
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    72
			StopActiveScheduler();
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    73
			}
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    74
        else if (iCurrentHwDeviceDataBuffer->LastBuffer() || iCurrentHwDeviceDataBuffer->BufferSize()==0)
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    75
            {
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    76
            error = iHwDevice->Stop();
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    77
            StopActiveScheduler();
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    78
            }
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    79
		else
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    80
			{//tell hw device we've emptied it and get another buffer
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    81
			error = iHwDevice->ThisHwBufferEmptied(*iCurrentHwDeviceDataBuffer);
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    82
			}
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    83
		if (!iError) 
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    84
			iError = error; //log error in observer error
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    85
		}
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    86
	else
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    87
		{
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    88
		iError = aError;
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    89
		}
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    90
	}
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    91
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    92
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    93
TInt CTestRecordMMFHwDeviceObserver::EmptyThisHwBuffer(CMMFBuffer& aHwDataBuffer)
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    94
	{
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    95
	//called on recording when buffer needs to be written to file
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    96
	TInt error = KErrNone;
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    97
	iCurrentBufferNumber++;
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    98
	iCurrentHwDeviceDataBuffer = &(static_cast<CMMFDataBuffer&>(aHwDataBuffer));
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
    99
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   100
	if (iCurrentBufferNumber <= iNumberOfBuffers)
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   101
		{
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   102
		error = iFileWriter->Write(*iCurrentHwDeviceDataBuffer);
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   103
		}
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   104
	if (!iError) 
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   105
			iError = error; //log error in observer error
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   106
	return error;
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   107
	}
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   108
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   109
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   110
void CTestRecordMMFHwDeviceObserver::Stopped()
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   111
	{
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   112
	}
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   113
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   114
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   115
RFile& CTestRecordMMFHwDeviceObserver::WriteFile()
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   116
	{
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   117
	return iSinkFile;
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   118
	}
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   119
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   120
79dd3e2336a0 2010wk36_01
hgs
parents:
diff changeset
   121