videoutils_plat/videoconnutility_api/tsrc/VCXTestCommon/src/CIptvTestVideoCreator.cpp
author Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
Thu, 17 Dec 2009 09:14:38 +0200
changeset 0 822a42b6c3f1
permissions -rw-r--r--
Revision: 200949 Kit: 200951

/*
* Copyright (c) 2008 Nokia Corporation and/or its subsidiary(-ies).
* All rights reserved.
* This component and the accompanying materials are made available
* under the terms of the License "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: 
*
*/


//  INCLUDES
#include <f32file.h>
#include <BAUTILS.H>

#include "CIptvTestVideoCreator.h"
#include "VCXTestLog.h"

// -----------------------------------------------------------------------------
//  NewL
// -----------------------------------------------------------------------------
//
EXPORT_C CIptvTestVideoCreator* CIptvTestVideoCreator::NewL()
    {
    CIptvTestVideoCreator* self;
    self = new (ELeave) CIptvTestVideoCreator();
    CleanupStack::PushL(self);
    self->ConstructL();
    CleanupStack::Pop(self);
    return self;
    }

// -----------------------------------------------------------------------------
//  CIptvTestVideoCreator
// -----------------------------------------------------------------------------
//
EXPORT_C CIptvTestVideoCreator::~CIptvTestVideoCreator()
    {
    delete iFileMan;
    iFileMan = NULL;
    iFs.Close();
    }

// -----------------------------------------------------------------------------
//  CIptvTestVideoCreator
// -----------------------------------------------------------------------------
//
EXPORT_C CIptvTestVideoCreator::CIptvTestVideoCreator()
    {

    }

// -----------------------------------------------------------------------------
//  ConstructL
// -----------------------------------------------------------------------------
//
EXPORT_C void CIptvTestVideoCreator::ConstructL()
    {
    User::LeaveIfError( iFs.Connect() );
    iFileMan = CFileMan::NewL( iFs );
    }

// -----------------------------------------------------------------------------
//  CreateVideoL
// -----------------------------------------------------------------------------
//
EXPORT_C void CIptvTestVideoCreator::CreateVideoL(CIptvTestVideoCreator::TIptvTestVideoType aVideoType, TDesC& aFileName, TInt aSize)
    {
    VCXLOGLO1(">>>CIptvTestVideoCreator::CreateVideoL");

    // Resolve source filename
    TBuf<256> srcFileName;

    GetVideoFile( srcFileName, aVideoType, _L("C") );
    if( !BaflUtils::FileExists(iFs, srcFileName) )
        {
        VCXLOGLO2("CIptvTestVideoCreator:: %S does not exist.", &srcFileName);
        GetVideoFile( srcFileName, aVideoType, _L("E") );
        if( !BaflUtils::FileExists(iFs, srcFileName) )
            {
            VCXLOGLO2("CIptvTestVideoCreator:: %S does not exist.", &srcFileName);
            VCXLOGLO2("CIptvTestVideoCreator:: test video file %S missing! PANIC.", &srcFileName);
            User::Panic(_L("Video files missing!"), KErrNotFound);
            }
        }
    
    BaflUtils::EnsurePathExistsL( iFs, aFileName.Left( aFileName.LocateReverse('\\') ) );

    BaflUtils::DeleteFile( iFs, aFileName );
    
    VCXLOGLO2("CIptvTestVideoCreator:: aSize = %d", aSize);
    
    TInt64 wantedSize( 0 );
    
    // Check the size
    if( aSize == KVcxTestLargeFile3GB ) {
        wantedSize = 3000000000;
    }
    else {
        wantedSize = aSize;
    }
    
    //wantedSize = wantedSize == 0 ? wantedSize -1 : wantedSize;
    
    VCXLOGLO2("CIptvTestVideoCreator:: Wanted file size: %Ld", wantedSize);

    // Read source file into memory, won't work on huge files.
    RFile64 srcFile;
    VCXLOGLO2("CIptvTestVideoCreator:: Opening %S", &srcFileName);
    User::LeaveIfError( srcFile.Open( iFs, srcFileName, EFileRead ) );
    CleanupClosePushL( srcFile );

    TInt64 srcSize(0);
    VCXLOGLO2("CIptvTestVideoCreator:: Getting size of %S", &srcFileName);
    User::LeaveIfError( srcFile.Size( srcSize ) );

    HBufC8* data = HBufC8::NewL( srcSize );
    TPtr8 ptr( data->Des() );
    srcFile.Read( ptr, srcSize );
    CleanupStack::PopAndDestroy( &srcFile );

    CleanupStack::PushL( data );

    // Write new file.
    RFile64 dstFile;
    VCXLOGLO1("CIptvTestVideoCreator:: Replace");
    User::LeaveIfError( dstFile.Replace( iFs, aFileName, EFileWrite ) );
    CleanupClosePushL(dstFile);

    if( wantedSize <= srcSize )
        {
        if( wantedSize == -1 )
            {
            VCXLOGLO2("CIptvTestVideoCreator:: Writing %Ld", srcSize);
            User::LeaveIfError( dstFile.Write( *data, srcSize ) );
            }
        else
            {
            VCXLOGLO2("CIptvTestVideoCreator:: Writing %Ld", wantedSize);
            User::LeaveIfError( dstFile.Write( *data, wantedSize ) );
            }
        }
    else
        {
        VCXLOGLO2("CIptvTestVideoCreator:: Writing %Ld", srcSize);
        User::LeaveIfError( dstFile.Write( *data, srcSize ) );

        const TInt KIptvTest200Kilos = 1024*200;
        HBufC8* buff = HBufC8::NewL( KIptvTest200Kilos );
        buff->Des().SetLength( KIptvTest200Kilos );
        CleanupStack::PushL( buff );
        TInt64 bytesToWrite = wantedSize - srcSize;
        while( bytesToWrite > 0 )
            {
            if( bytesToWrite >= KIptvTest200Kilos )
                {
                bytesToWrite -= KIptvTest200Kilos;
                User::LeaveIfError( dstFile.Write( *buff ) );
                }
            else
                {
                User::LeaveIfError( dstFile.Write( *buff, bytesToWrite ) );
                bytesToWrite = 0;
                }
            }
        CleanupStack::PopAndDestroy( buff );
        }

    CleanupStack::PopAndDestroy( &dstFile );
    CleanupStack::PopAndDestroy( data );

    VCXLOGLO1("<<<CIptvTestVideoCreator::CreateVideoL");
    }


// -----------------------------------------------------------------------------
//  CreateVideosL
// -----------------------------------------------------------------------------
//
EXPORT_C void CIptvTestVideoCreator::CreateVideosL(CIptvTestVideoCreator::TIptvTestVideoType aVideoType, TDesC& aFileName, TInt aCount, RPointerArray<HBufC>& aFileArray )
    {
    VCXLOGLO1(">>>CIptvTestVideoCreator::CreateVideosL");

    // Resolve source filename
    TBuf<256> srcFileName;

    GetVideoFile( srcFileName, aVideoType, _L("C") );

    if( !BaflUtils::FileExists(iFs, srcFileName) )
        {
        VCXLOGLO2("CIptvTestVideoCreator:: %S does not exist.", &srcFileName);
        GetVideoFile( srcFileName, aVideoType, _L("E") );
        if( !BaflUtils::FileExists(iFs, srcFileName) )
            {
            VCXLOGLO2("CIptvTestVideoCreator:: %S does not exist.", &srcFileName);
            VCXLOGLO2("CIptvTestVideoCreator:: test video file %S missing! PANIC.", &srcFileName);
            // Comment next line if you want dummy files to be created. They won't be recognized by MDS.
            User::Panic(_L("Video files missing!"), KErrNotFound);
            }
        }

    TBool fileExists = BaflUtils::FileExists(iFs, srcFileName);

    HBufC* newFileName = HBufC::NewL( 256 );
    CleanupStack::PushL( newFileName );

    newFileName->Des().Copy( aFileName.Left( aFileName.LocateReverse('\\') ) );
    BaflUtils::EnsurePathExistsL(iFs, *newFileName);

    TInt dotPos = aFileName.LocateReverse('.');

    for( TInt i = 0; i < aCount; i++ )
        {
        newFileName->Des().Copy( aFileName.Left( dotPos ) );
        newFileName->Des().Append( _L("_") );
        newFileName->Des().AppendNum( i );
        newFileName->Des().Append( aFileName.Right( aFileName.Length() - dotPos ) );

        HBufC* fileForClient = newFileName->Des().AllocL();
        aFileArray.Append( fileForClient );

        if( fileExists )
            {
            User::LeaveIfError( iFileMan->Copy(srcFileName, *newFileName) );
            VCXLOGLO2("CIptvTestVideoCreator:: copy file: '%S'", newFileName);
            }
        else
            {
            VCXLOGLO2("CIptvTestVideoCreator:: new fake file: '%S'", newFileName);
            RFile file;
            CleanupClosePushL(file);
            User::LeaveIfError( file.Replace(iFs, *newFileName, EFileWrite) );
            User::LeaveIfError( file.SetSize( 1024*10 ) );
            CleanupStack::PopAndDestroy( &file );
            }
        User::After( 100000 ); // Wait tenth of a second.
        }

    CleanupStack::PopAndDestroy( newFileName );

    VCXLOGLO1("<<<CIptvTestVideoCreator::CreateVideosL");
    }

// -----------------------------------------------------------------------------
//  GetVideoFile
// -----------------------------------------------------------------------------
//
EXPORT_C void CIptvTestVideoCreator::GetVideoFile( TDes& aFileName, CIptvTestVideoCreator::TIptvTestVideoType aVideoType, const TDesC& aDrive )
    {
    VCXLOGLO1(">>>CIptvTestVideoCreator::GetVideoFile");
    aFileName.Copy( aDrive );

    _LIT(KIptvTestVideoBasePath, ":\\testing\\data\\");

    aFileName.Append( KIptvTestVideoBasePath );
    
    VCXLOGLO2("CIptvTestVideoCreator::GetVideoFile -- using %S", &aFileName);

    switch (aVideoType)
        {
        case CIptvTestVideoCreator::IptvTestVideo3Gp:
            {
            aFileName.Append( _L("video_3gp.xxx") );
            }
            break;

        case CIptvTestVideoCreator::IptvTestVideo3Gp2:
            {
            aFileName.Append( _L("video_3gp2.xxx") );
            }
            break;

        case CIptvTestVideoCreator::IptvTestVideoMp2:
            {
            aFileName.Append( _L("video_mp2.xxx") );
            }
            break;

        case CIptvTestVideoCreator::IptvTestVideoMpeg1:
            {
            aFileName.Append( _L("video_mpeg1.xxx") );
            }
            break;

        case CIptvTestVideoCreator::IptvTestVideoMpeg2:
            {
            aFileName.Append( _L("video_mpeg2.xxx") );
            }
            break;

        case CIptvTestVideoCreator::IptvTestVideoSuperVideoCd:
            {
            aFileName.Append( _L("video_supervideocd.xxx") );
            }
            break;

        case CIptvTestVideoCreator::IptvTestVideoMp3:
            {
            aFileName.Append( _L("video_mp3.xxx") );
            }
            break;

        case CIptvTestVideoCreator::IptvTestVideoAppleMpeg:
            {
            aFileName.Append( _L("video_applempeg.xxx") );
            }
            break;

        case CIptvTestVideoCreator::IptvTestVideoMpeg4:
            {
            aFileName.Append( _L("video_mpeg4.xxx") );
            }
            break;

        case CIptvTestVideoCreator::IptvTestVideoMpegAvc:
            {
            aFileName.Append( _L("video_mpegavc.xxx") );
            }
            break;

        case CIptvTestVideoCreator::IptvTestVideoQuicktime:
            {
            aFileName.Append( _L("video_quicktime.xxx") );
            }
            break;

        case CIptvTestVideoCreator::IptvTestVideoRealVideo:
            {
            aFileName.Append( _L("video_realvideo.xxx") );
            }
            break;

        case CIptvTestVideoCreator::IptvTestVideoAvi:
            {
            aFileName.Append( _L("video_avi.xxx") );
            }
            break;

        case CIptvTestVideoCreator::IptvTestVideoWmv:
            {
            aFileName.Append( _L("video_wmv.xxx") );
            }
            break;

        case CIptvTestVideoCreator::IptvTestVideoAviAC3:
            {
            aFileName.Append( _L("video_aviac3.xxx") );
            }
            break;            
        default:
            User::Panic(_L("IptvMyVideosApiTest: Unknown video type!"), KErrCorrupt);
        }
    VCXLOGLO1("<<<CIptvTestVideoCreator::GetVideoFile");
    }

// End of File