javauis/mmapi_qt/baseline/src/cmmammfresolver.cpp
author Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
Tue, 31 Aug 2010 15:09:22 +0300
branchRCL_3
changeset 25 ae942d28ec0e
permissions -rw-r--r--
Revision: v2.2.11 Kit: 201035

/*
* Copyright (c) 2002 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:  This class is used for playing sounds
*
*/


//  INCLUDE FILES
#include <logger.h>


#include "cmmammfresolver.h"
#include "apgcli.h"
#include "apmrec.h"


#include "hxmetadatautil.h"
_LIT8(KMimetypeRM, "audio/x-pn-realaudio");
_LIT(KRVMimeType1, "video/x-pn-realvideo");
_LIT(KRVMimeType2, "video/x-realvideo");
_LIT(KRVMimeType3, "video/vnd.rn-realvideo");


// CONSTANTS

CMMAMMFResolver* CMMAMMFResolver::NewLC()
{
    CMMAMMFResolver* self = new(ELeave)CMMAMMFResolver();
    CleanupStack::PushL(self);
    self->ConstructL();
    return self;
}

void CMMAMMFResolver::ListImplementationsL()
{
    iControllerSelection->ListImplementationsL(*iImplementations);
    if (iImplementations->Count() > 0)
    {
        ResolveContentTypeL();
    }
}

RMMFControllerImplInfoArray* CMMAMMFResolver::Implementations()
{
    // ImplementationsOwnership method must not be called before this
    __ASSERT_DEBUG(iImplementations, User::Invariant());
    return iImplementations;
}

RMMFControllerImplInfoArray* CMMAMMFResolver::ImplementationsOwnership()
{
    // ImplementationsOwnership method must not be called many times
    __ASSERT_DEBUG(iImplementations, User::Invariant());

    RMMFControllerImplInfoArray* implementations = iImplementations;
    iImplementations = NULL; // ownership is transferred
    return implementations;
}

HBufC* CMMAMMFResolver::ContentTypeOwnership()
{
    HBufC* ct = iContentType;
    iContentType = NULL;
    return ct;
}

HBufC* CMMAMMFResolver::ContentType()
{
    return iContentType;
}

void CMMAMMFResolver::SetFileNameL(const TDesC* aFileName)
{
    HBufC* fn = NULL;
    if (aFileName)
    {
        fn = aFileName->AllocL();
    }
    delete iFileName;
    iFileName = fn;
}

HBufC* CMMAMMFResolver::FileNameOwnership()
{
    HBufC* fn = iFileName;
    iFileName = NULL;
    return fn;
}

void CMMAMMFResolver::ResolveContentTypeL()
{
    LOG(EJavaMMAPI, EInfo, "+ CMMAMMFResolver::ResolveContentTypeL()");
    CMMFFormatSelectionParameters* fSelect = iRequiredPlayFormatSupport;
    if (!fSelect)
    {
        fSelect = iRequiredRecordFormatSupport;
    }
    // if there is no play or record formats this object is not
    // initialized correctly.
    __ASSERT_DEBUG(fSelect, User::Invariant());

    CMMFFormatSelectionParameters::TMatchDataType type =
        fSelect->MatchDataType();

    // if there is no implementation this method must not be called.
    __ASSERT_DEBUG(iImplementations->Count() > 0, User::Invariant());
    const RMMFFormatImplInfoArray* formats =
        Formats((*iImplementations)[ 0 ]);

    HBufC8* contentType = NULL;
    TInt formatsCount = formats->Count();

    if (type == CMMFFormatSelectionParameters::EMatchMimeType)
    {
        LOG(EJavaMMAPI, EInfo, "CMMAMMFResolver::ResolveContentTypeL - EMatchMimeType");
        // The match was based on a mime type.
        contentType = fSelect->MatchData().AllocLC();
    }
    else if (type == CMMFFormatSelectionParameters::EMatchFileExtension)
    {
        LOG(EJavaMMAPI, EInfo, "CMMAMMFResolver::ResolveContentTypeL - EMatchFileExtension");
        // The match was based on a file extension.
        RApaLsSession ls;
        TInt error;
        error = ls.Connect();
        TDataRecognitionResult result;
        error = ls.RecognizeData(*iFileName, KNullDesC8, result);
        ls.Close();

        if (iFileName && (iFileName->Right(3).Compare(KRaFileExtension()) == 0))
        {
            contentType = KMimetypeRM().AllocLC();
        }
        else if (iFileName && (iFileName->Right(3).Compare(KRmFileExtension()) == 0) &&
                 !(IsRealVideoTypeL(*iFileName)))
        {
            contentType = KMimetypeRM().AllocLC();
        }
        else if (!error && (result.iConfidence >= CApaDataRecognizerType::EProbable))
        {
            LOG1(EJavaMMAPI, EInfo, "CMMAMMFResolver::ResolveContentTypeL - Confidence : %d", result.iConfidence);
            contentType = result.iDataType.Des8().AllocLC();
        }


        else
        {
            // The probability is less, hence matching is done based on legacy style
            for (TInt format = 0; (format < formatsCount) &&
                    !contentType; format++)
            {
                const CMMFFormatImplementationInformation* info = (*formats)[ format ];
                if (info->SupportsFileExtension(fSelect->MatchData()))
                {
                    if (info->SupportedMimeTypes().Count() > 0)
                    {
                        contentType = info->SupportedMimeTypes()[ 0 ].AllocLC();
                    }
                }
            }
        }
    }
    else if (type == CMMFFormatSelectionParameters::EMatchHeaderData)
    {
        LOG(EJavaMMAPI, EInfo, "CMMAMMFResolver::ResolveContentTypeL - EMatchHeaderData");
        // The match was on a header data.
        RApaLsSession ls;
        TInt error;
        error = ls.Connect();
        TDataRecognitionResult result;
        error = ls.RecognizeData(KNullDesC, fSelect->MatchData() , result);
        ls.Close();
        if (!error && (result.iConfidence >= CApaDataRecognizerType::EProbable))
        {
            contentType = result.iDataType.Des8().AllocLC();
        }
        else
        {
            // The probability is less, hence matching is done based on legacy style
            for (TInt format = 0; (format < formatsCount) &&
                    !contentType; format++)
            {
                CMMFFormatImplementationInformation* info = (*formats)[ format ];
                if (info->SupportsHeaderDataL(fSelect->MatchData()))
                {
                    if (info->SupportedMimeTypes().Count() > 0)
                    {
                        contentType = info->SupportedMimeTypes()[ 0 ].AllocLC();
                    }
                }
            }
        }
    }
    else
    {
        LOG(EJavaMMAPI, EInfo, "CMMAMMFResolver::ResolveContentTypeL - KErrNotSupported");
        // EMatchAny is not supported
        User::Leave(KErrNotSupported);
    }

    // iContentType remains NULL if content type was not found.
    if (contentType)
    {
        LOG1(EJavaMMAPI, EInfo, "CMMAMMFResolver::ResolveContentTypeL - contentType : %s", contentType->Des().PtrZ());

        HBufC* ct = HBufC::NewL(contentType->Length());
        (ct->Des()).Copy(*contentType);
        CleanupStack::PopAndDestroy(contentType);
        delete iContentType;
        iContentType = ct;
    }
    else
    {
        //This situation should never occur
        LOG(EJavaMMAPI, EInfo, "CMMAMMFResolver::ResolveContentTypeL - contentType = NULL");
        User::Leave(KErrUnknown);
    }
    LOG(EJavaMMAPI, EInfo, "- CMMAMMFResolver::ResolveContentTypeL()");
}


TBool CMMAMMFResolver::IsRealVideoTypeL(const TDesC& aFileName)
{
    TBool result = EFalse;

    CHXMetaDataUtility *putil;
    putil = CHXMetaDataUtility::NewL();
    CleanupStack::PushL(putil);
    TRAPD(err, putil->OpenFileL(aFileName));
    ELOG1(EJavaMMAPI, "MMA:CMMAMMFResolver::IsRealVideoTypeL, err = %d", err);

    if (err != KErrNone)
    {
        CleanupStack::Pop(putil);
        putil->ResetL();
        delete putil;
        return EFalse;
    }

    TUint count = 0;
    putil->GetMetaDataCount(count);

    TUint i;
    HXMetaDataKeys::EHXMetaDataId  id;

    for (i = 0; i < count; i++)
    {
        HBufC* pDes = NULL;

        putil->GetMetaDataAt(i, id, pDes);

        if (id == HXMetaDataKeys::EHXMimeType)
        {
            if (IsRealMimeTypeSupported(*pDes))
            {
                result = ETrue;
            }
        }
    }

    CleanupStack::Pop(putil);

    putil->ResetL();
    delete putil;

    return result;
}


TBool CMMAMMFResolver::IsRealMimeTypeSupported(const TDesC& aMimeType)
{
    TBool match = EFalse;

    if (!aMimeType.Compare(KRVMimeType1()))
    {
        match = ETrue;
        return match;
    }
    if (!aMimeType.Compare(KRVMimeType2()))
    {
        match = ETrue;
        return match;
    }
    if (!aMimeType.Compare(KRVMimeType3()))
    {
        match = ETrue;
        return match;
    }

    return match;
}


void CMMAMMFResolver::GetSupportedContentTypesL(CDesC16Array& aMimeTypeArray)
{
    iControllerSelection->ListImplementationsL(*iImplementations);

    TInt impCount = iImplementations->Count();
    for (TInt i = 0; i < impCount; i++)
    {
        const RMMFFormatImplInfoArray* formats = Formats((*iImplementations)[ i ]);
        TInt formatsCount(formats->Count());
        for (TInt format = 0; format < formatsCount; format++)
        {
            const CMMFFormatImplementationInformation* info = (*formats)[ format ];
            const CDesC8Array& supportedMimes = info->SupportedMimeTypes();
            TInt mimeCount = supportedMimes.Count();
            for (TInt mime = 0; mime < mimeCount; mime++)
            {
                // must convert from 8 bits to 16 bits
                HBufC* tmpBuf = HBufC::NewLC(supportedMimes[ mime ].Length());
                tmpBuf->Des().Copy(supportedMimes[ mime ]);
                aMimeTypeArray.AppendL(*tmpBuf);
                CleanupStack::PopAndDestroy(tmpBuf);
            }
        }
    }
}


void CMMAMMFResolver::SetRequiredPlayFormatSupportL(
    CMMFFormatSelectionParameters& aRequiredSupport)
{
    iControllerSelection->SetRequiredPlayFormatSupportL(aRequiredSupport);
    iRequiredPlayFormatSupport = &aRequiredSupport;
}

void CMMAMMFResolver::SetRequiredRecordFormatSupportL(
    CMMFFormatSelectionParameters& aRequiredSupport)
{
    iControllerSelection->SetRequiredRecordFormatSupportL(aRequiredSupport);
    iRequiredRecordFormatSupport = &aRequiredSupport;
}

const RMMFFormatImplInfoArray* CMMAMMFResolver::Formats(CMMFControllerImplementationInformation* aImplementation)
{
    const RMMFFormatImplInfoArray* formats = NULL;
    if (iRequiredPlayFormatSupport)
    {
        formats = &(aImplementation->PlayFormats());
    }
    else
    {
        // if there is no play or record formats this object is not
        // initialized correctly.
        __ASSERT_DEBUG(iRequiredRecordFormatSupport, User::Invariant());

        formats = &(aImplementation->RecordFormats());
    }
    return formats;
}

CMMFControllerPluginSelectionParameters*
CMMAMMFResolver::SelectionParameters()
{
    return iControllerSelection;
}

CMMAMMFResolver::~CMMAMMFResolver()
{
    if (iImplementations)
    {
        iImplementations->ResetAndDestroy();
    }
    delete iImplementations;
    delete iContentType;
    delete iControllerSelection;
    delete iFileName;
}


CMMAMMFResolver::CMMAMMFResolver()
{
}


void CMMAMMFResolver::ConstructL()
{
    iImplementations = new(ELeave)RMMFControllerImplInfoArray();
    iControllerSelection = CMMFControllerPluginSelectionParameters::NewL();
}


//  END OF FILE