mmlibs/mmfw/Recogniser/src/filereader.cpp
author hgs
Thu, 07 Oct 2010 22:34:12 +0100
changeset 0 b8ed18f6c07b
permissions -rw-r--r--
2010wk40
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
0
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
     1
// Copyright (c) 2006-2009 Nokia Corporation and/or its subsidiary(-ies).
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
     2
// All rights reserved.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
     3
// This component and the accompanying materials are made available
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
     4
// under the terms of "Eclipse Public License v1.0"
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
     5
// which accompanies this distribution, and is available
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
     6
// at the URL "http://www.eclipse.org/legal/epl-v10.html".
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
     7
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
     8
// Initial Contributors:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
     9
// Nokia Corporation - initial contribution.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    10
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    11
// Contributors:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    12
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    13
// Description:
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    14
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    15
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    16
#include "readers.h"
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    17
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    18
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    19
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    20
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    21
CFileReader::CFileReader(RFile* aFile)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    22
 :	CBufferReader(iFileBuffer, CReader::EFile),
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    23
 	iFile(aFile)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    24
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    25
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    26
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    27
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    28
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    29
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    30
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    31
CFileReader::~CFileReader()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    32
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    33
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    34
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    35
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    36
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    37
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    38
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    39
CFileReader* CFileReader::NewLC(RFile* aFile)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    40
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    41
	CFileReader* self = new(ELeave) CFileReader(aFile);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    42
	CleanupStack::PushL(self);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    43
	self->ConstructL();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    44
	return self;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    45
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    46
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    47
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    48
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    49
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    50
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    51
void CFileReader::ConstructL()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    52
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    53
	TInt pos = 0;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    54
	User::LeaveIfError(iFile->Seek(ESeekStart, pos));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    55
	User::LeaveIfError(iFile->Read(iFileBuffer));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    56
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    57
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    58
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    59
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    60
// Checks if there is aAmount of data left in the buffer.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    61
// It is important to call the base-class implementation first
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    62
// to ensure correct operation.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    63
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    64
TBool CFileReader::CheckEnoughData(TInt aAmount)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    65
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    66
	if (CBufferReader::CheckEnoughData(aAmount))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    67
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    68
		return ETrue;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    69
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    70
		
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    71
	// Try to read more data.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    72
	TInt bufPos = CBufferReader::Position();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    73
	TInt err = PhysicallySeekAndRead(bufPos - iFileBuffer.Length());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    74
	if (err == KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    75
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    76
		// The read may have succeeded but that 
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    77
		// still doesn't mean we have enough data.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    78
		return (aAmount <= iFileBuffer.Length());
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    79
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    80
	
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    81
	return EFalse;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    82
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    83
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    84
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    85
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    86
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    87
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    88
void CFileReader::Reset()
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    89
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    90
	CBufferReader::Reset(); // This will reset iBufPos.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    91
	
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    92
	if (iFilePos != 0)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    93
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    94
		// We need to seek to the start and fill the buffer.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    95
		iFilePos = 0;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    96
		TInt filepos = 0;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    97
		TInt err = iFile->Seek(ESeekStart, filepos);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    98
		if (err == KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    99
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   100
			err = iFile->Read(iFileBuffer);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   101
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   102
			
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   103
		if (err != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   104
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   105
			iFileBuffer.Zero();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   106
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   107
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   108
	else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   109
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   110
		// There's no need to seek and read.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   111
		iFilePos = 0;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   112
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   113
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   114
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   115
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   116
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   117
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   118
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   119
void CFileReader::SeekL(TInt aOffset)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   120
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   121
	TInt err = CReader::Seek(aOffset);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   122
	if (err == KErrUnderflow)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   123
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   124
		TInt bufPos = CBufferReader::Position();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   125
		aOffset += bufPos - iFileBuffer.Length();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   126
		User::LeaveIfError(PhysicallySeekAndRead(aOffset));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   127
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   128
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   129
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   130
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   131
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   132
// It could be possible for a 64-bit field in formats such as MPEG4
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   133
// to have values that would fit in a 32-bit variable. In this case
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   134
// we can use it for seeking. This function checks if a 64-bit value
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   135
// is compatible with RFile's 32-bit operations.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   136
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   137
void CFileReader::SeekL(TInt64 aOffset)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   138
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   139
	if (aOffset < KMinTInt64)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   140
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   141
		User::Leave(KErrNotSupported);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   142
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   143
		
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   144
	if (aOffset > KMaxTInt64)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   145
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   146
		User::Leave(KErrNotSupported);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   147
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   148
	
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   149
	if (aOffset < (TInt64)KMaxTInt)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   150
	    {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   151
        TInt low = (TInt)I64LOW(aOffset);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   152
        SeekL(low);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   153
	    }
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   154
	else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   155
	    {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   156
        TInt err = CReader::Seek(aOffset);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   157
        if (err == KErrUnderflow)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   158
            {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   159
            TInt64 bufPos = CBufferReader::Position();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   160
            aOffset += bufPos - iFileBuffer.Length();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   161
            User::LeaveIfError(PhysicallySeekAndRead(aOffset));
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   162
            }
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   163
	    }
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   164
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   165
	
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   166
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   167
// This function seeks forward/backward aOffset bytes
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   168
// and fills the buffer from that point.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   169
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   170
TInt CFileReader::PhysicallySeekAndRead(TInt aOffset)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   171
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   172
	TInt err;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   173
	
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   174
	// New buffer contents so read from the start of it.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   175
	CBufferReader::Reset();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   176
	
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   177
	iFilePos = aOffset;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   178
	err = iFile->Seek(ESeekCurrent, aOffset);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   179
	
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   180
	if (err != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   181
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   182
		return err;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   183
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   184
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   185
	err = iFile->Read(iFileBuffer);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   186
	if (err != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   187
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   188
		return err;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   189
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   190
	return (iFileBuffer.Length() == 0 ? KErrEof : KErrNone);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   191
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   192
TInt CFileReader::PhysicallySeekAndRead(TInt64 aOffset)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   193
    {
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   194
    TInt err;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   195
    // New buffer contents so read from the start of it.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   196
    CBufferReader::Reset();
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   197
    
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   198
    iFilePos = aOffset;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   199
    RFile64* tempfile;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   200
    tempfile = static_cast<RFile64*> (iFile);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   201
 
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   202
    err = tempfile->Seek(ESeekCurrent, iFilePos);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   203
	if (err != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   204
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   205
		return err;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   206
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   207
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   208
	err = iFile->Read(iFileBuffer);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   209
	if (err != KErrNone)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   210
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   211
		return err;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   212
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   213
		
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   214
	return (iFileBuffer.Length() == 0 ? KErrEof : KErrNone);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   215
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
   216