mmlibs/mmfw/Recogniser/src/others.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 "parsers.h"
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    17
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    18
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    19
// This file format is treated differently from all the others in that if the
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    20
// file extension is not recognised then the file is not recognised.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    21
// Only once the extension is recognised does it try to match any header data.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    22
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    23
void TRAMParser::DoRecognise(const TDesC& aFileExt, CReader& aReader, TMatch& aMatch)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    24
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    25
	TBool extMatch = (aFileExt.MatchF(TPtrC(KExtRAM)) != KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    26
	if (extMatch)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    27
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    28
		aMatch.iMime = KMimeRAM;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    29
		TPtrC8 header = MAKE_TPtrC8(KSigRAM);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    30
		
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    31
		if (aReader.Match(header))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    32
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    33
			aMatch.iConfidence = KConfProbable;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    34
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    35
		else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    36
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    37
			aMatch.iConfidence = KConfPossible;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    38
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    39
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    40
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    41
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    42
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    43
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    44
// SDP and XPS have almost identical header signatures, so when it comes to
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    45
// recognise an SDP file with a bad extension, it can be incorrectly identified
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    46
// as an XPS file.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    47
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    48
void TSDPParser::DoRecognise(const TDesC& aFileExt, CReader& aReader, TMatch& aMatch)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    49
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    50
	TBool extMatch = (aFileExt.MatchF(TPtrC(KExtSDP)) != KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    51
	if (extMatch)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    52
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    53
		aMatch.iMime = KMimeSDP;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    54
		TPtrC8 header = MAKE_TPtrC8(KSigSDP);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    55
		
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    56
		if (aReader.Match(header))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    57
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    58
			aMatch.iConfidence = KConfProbable;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    59
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    60
		else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    61
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    62
			aMatch.iConfidence = KConfPossible;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    63
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    64
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    65
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    66
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    67
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    68
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    69
// See TSDPParser::DoRecognise comment.
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    70
//
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    71
void TXPSParser::DoRecognise(const TDesC& aFileExt, CReader& aReader, TMatch& aMatch)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    72
	{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    73
	TBool extMatch = (aFileExt.MatchF(TPtrC(KExtXPS)) != KErrNotFound);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    74
	if (extMatch)
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    75
		{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    76
		aMatch.iMime = KMimeXPS;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    77
		TPtrC8 header = MAKE_TPtrC8(KSigXPS);
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    78
		
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    79
		if (aReader.Match(header))
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    80
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    81
			aMatch.iConfidence = KConfProbable;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    82
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    83
		else
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    84
			{
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    85
			aMatch.iConfidence = KConfPossible;
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    86
			}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    87
		}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    88
	}
b8ed18f6c07b 2010wk40
hgs
parents:
diff changeset
    89