filemanager/Engine/src/CFileManagerUtils.cpp
author Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
Fri, 12 Mar 2010 15:41:37 +0200
branchRCL_3
changeset 7 8812206c49a0
parent 5 1e73d2d04cbc
child 9 60626d494346
permissions -rw-r--r--
Revision: 201006 Kit: 201008

/*
* Copyright (c) 2002-2007 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:  Util methods for File Manager
*
*/



// INCLUDE FILES
#include <AknUtils.h>
#include <StringLoader.h>
#include <CDirectoryLocalizer.h>
#include <CommonContentPolicy.h>
#include <bautils.h>
#include <caf/caf.h>
#include <DcfCommon.h>
#include <FileManagerEngine.rsg>
#ifdef RD_MULTIPLE_DRIVE
#include <driveinfo.h>
#endif // RD_MULTIPLE_DRIVE
#if defined( __KEEP_DRM_CONTENT_ON_PHONE ) && defined ( FILE_MANAGER_USE_DISTRIBUTABLECHECKER )
 #include <distributablechecker.h>
#endif // __KEEP_DRM_CONTENT_ON_PHONE && FILE_MANAGER_USE_DISTRIBUTABLECHECKER
#include "GflmUtils.h"
#include <drmutility.h>
#include "CFileManagerUtils.h"
#include "CFilemanagerMimeIconArray.h"
#include "Cfilemanagerfolderarray.h"
#include "CGflmNavigatorModel.h"
#include "CFileManagerItemProperties.h"
#include "CFileManagerCommonDefinitions.h"
#include "CGflmGroupItem.h"
#include "CGflmFileSystemItem.h"
#include "CGflmDriveItem.h"
#include "CFileManagerFeatureManager.h"

// CONSTANTS
_LIT( KFlk, "flk:" );
_LIT( KLdf, "ldf:" );

#ifdef RD_MULTIPLE_DRIVE
const TInt KDriveNameArrayLen = 2;
const TInt KDriveLetterIndex = 0;
const TInt KDriveNameIndex = 1;
enum TFmgrDriveNameType
    {
    EFmgrDeviceMemory = 0,
    EFmgrMassStorage,
    EFmgrNamedMemoryCard,
    EFmgrDefaultMemoryCard,
    EFmgrDefaultUsbMemory,
    EFmgrDriveNameTypeCount // Must be the last
    };

typedef TInt TFmgrDriveNameLayoutText[ EFmgrDriveNameTypeCount ];
const TFmgrDriveNameLayoutText KFmgrDriveNames[] =
{
    { // CFileManagerUtils::EMainLayout
    R_QTN_FMGR_MAIN_DEVICE_MEMORY,      // EFmgrDeviceMemory
    R_QTN_FMGR_MAIN_MASS_STORAGE,       // EFmgrMassStorage
    R_QTN_FMGR_MAIN_NAMED_MEMORY_CARD,  // EFmgrNamedMemoryCard
    R_QTN_FMGR_MAIN_MEMORY_CARD_DEFAULT, // EFmgrDefaultMemoryCard
    R_QTN_FMGR_MAIN_USB_DEFAULT          // EFmgrDefaultUsbMemory
    },
    { // CFileManagerUtils::ETitleLayout
    R_QTN_FMGR_TITLE_DEVICE_MEMORY,      // EFmgrDeviceMemory
    R_QTN_FMGR_TITLE_MASS_STORAGE,       // EFmgrMassStorage
    R_QTN_FMGR_TITLE_NAMED_MEMORY_CARD,  // EFmgrNamedMemoryCard
    R_QTN_FMGR_TITLE_MEMORY_CARD_DEFAULT, // EFmgrDefaultMemoryCard
    R_QTN_FMGR_TITLE_USB_DEFAULT,         // EFmgrDefaultUsbMemory
    }
};
#endif // RD_MULTIPLE_DRIVE


// ============================ MEMBER FUNCTIONS ===============================

// -----------------------------------------------------------------------------
// CFileManagerUtils::CFileManagerUtils
// C++ default constructor can NOT contain any code, that
// might leave.
// -----------------------------------------------------------------------------
//
CFileManagerUtils::CFileManagerUtils(
        RFs& aFs,
        CGflmNavigatorModel& aNavigator,
        CFileManagerFeatureManager& aFeatureManager ) :
    iFs( aFs ),
    iNavigator( aNavigator ),
    iFeatureManager( aFeatureManager )
    {
    }

// -----------------------------------------------------------------------------
// CFileManagerUtils::ConstructL
// Symbian 2nd phase constructor can leave.
// -----------------------------------------------------------------------------
//
void CFileManagerUtils::ConstructL()
    {
    // Check and set value to indicate if the feature is supported
    iDrmFullSupported = iFeatureManager.IsDrmFullSupported();

    iMimeIconMapper = CFileManagerMimeIconArray::NewL(
        R_FILEMANAGER_MIME_ICON_MAPPER, iNavigator );

#ifdef RD_MULTIPLE_DRIVE
    iDefaultFolders = CFileManagerFolderArray::NewL( *this );
#else // RD_MULTIPLE_DRIVE
    iDefaultFolders = CFileManagerFolderArray::NewL(
        R_FILEMANAGER_DEFAULT_FOLDERS, *this );
    iDefaultFolders->CreateFolders();
#endif // RD_MULTIPLE_DRIVE

    }

// -----------------------------------------------------------------------------
// CFileManagerUtils::NewL
// Two-phased constructor.
// -----------------------------------------------------------------------------
//
CFileManagerUtils* CFileManagerUtils::NewL(
        RFs& aFs,
        CGflmNavigatorModel& aNavigator,
        CFileManagerFeatureManager& aFeatureManager )
    {
    CFileManagerUtils* self =
        new( ELeave ) CFileManagerUtils( aFs, aNavigator, aFeatureManager );

    CleanupStack::PushL( self );
    self->ConstructL();
    CleanupStack::Pop( self );

    return self;
    }

// -----------------------------------------------------------------------------
// CFileManagerUtils::~CFileManagerUtils
//
// -----------------------------------------------------------------------------
//
CFileManagerUtils::~CFileManagerUtils()
    {
#if defined( __KEEP_DRM_CONTENT_ON_PHONE ) && defined ( FILE_MANAGER_USE_DISTRIBUTABLECHECKER )
    delete iDistributableChecker;
#endif // __KEEP_DRM_CONTENT_ON_PHONE && FILE_MANAGER_USE_DISTRIBUTABLECHECKER
    delete iMimeIconMapper;
    delete iDefaultFolders;
    delete iCommonContentPolicy;
    }
    
// -----------------------------------------------------------------------------
// CFileManagerUtils::Fs() const
//
// -----------------------------------------------------------------------------
//
RFs& CFileManagerUtils::Fs() const
    {
    return iFs;
    }

// -----------------------------------------------------------------------------
// CFileManagerUtils::IsForwardLockedFile
// -----------------------------------------------------------------------------
//
TBool CFileManagerUtils::IsForwardLockedFile( const TDesC& aFullPath )
    {
    if ( iDrmFullSupported )
        {
        return EFalse;  // Full DRM is used
        }
    TBool ret( EFalse );

    if ( !iCommonContentPolicy )
        {
        TRAPD( err, iCommonContentPolicy = CCommonContentPolicy::NewL() );
        if ( err != KErrNone )
            {
            _LIT( KReason, "No Common Content Policy" );
            User::Panic( KReason, err );
            }
        }

    if( iCommonContentPolicy )
        {
        TRAPD( err, ret = iCommonContentPolicy->IsClosedFileL( aFullPath ) );
        if ( err != KErrNone )
            {
            ret = EFalse;
            }
        }

    return ret;
    }

// -----------------------------------------------------------------------------
// CFileManagerUtils::IsDrmProtectedFile
// -----------------------------------------------------------------------------
//
TBool CFileManagerUtils::IsDrmProtectedFile( const TDesC& aFullPath ) const
    {
    if ( !iDrmFullSupported )
        {
        return EFalse; // Partial DRM is used
        }
#if 0
    // Check from file extension, this is the fastest possible check
    _LIT( KOdfExt, ".odf" );
    _LIT( KDcfExt, ".dcf" );
    TParsePtrC parse( aFullPath );
    TPtrC ext( parse.Ext() );
    return ( !ext.CompareF( KOdfExt ) || !ext.CompareF( KDcfExt ) );
#else
    // Do similar quick check than in old DRMCommon
   
    RFile64 drmFile;
    
    User::LeaveIfError( drmFile.Open( 
        iFs, aFullPath, EFileRead | EFileShareReadersOrWriters ) );
    CleanupClosePushL( drmFile );
    DRM::CDrmUtility *drmCheck = DRM::CDrmUtility::NewLC();
       
    TBool isProtected( EFalse );        
    TRAP_IGNORE( isProtected = drmCheck->IsProtectedL( drmFile ) ); 
    
    CleanupStack::PopAndDestroy( drmCheck );
    CleanupStack::PopAndDestroy( &drmFile );
       
    return isProtected;
#endif
    }

// -----------------------------------------------------------------------------
// CFileManagerUtils::ResolveIconL
//
// -----------------------------------------------------------------------------
//
TInt CFileManagerUtils::ResolveIconL( const TDesC& aFullPath ) const
    {
    TInt iconId( EFileManagerOtherFileIcon );
    if ( HasFinalBackslash( aFullPath ) )
        {
        // Do not check for subfolders for remote drives
        iconId = EFileManagerFolderIcon;
        if ( !IsRemoteDrive( aFullPath ) )
            {
            if ( HasSubFolders( aFullPath ) )
                {
                iconId = EFileManagerFolderSubIcon;
                }
            else if ( !HasFiles( aFullPath ) )
                {
                iconId = EFileManagerFolderEmptyIcon;
                }
            }
        }
    else
        {
        iconId = iMimeIconMapper->ResolveIconL( aFullPath );
        }
    return iconId;
    }

// -----------------------------------------------------------------------------
// CFileManagerUtils::DefaultFolder
//
// -----------------------------------------------------------------------------
//
TBool CFileManagerUtils::DefaultFolder( const TDesC& aFullPath ) const
    {
    return iDefaultFolders->Contains( aFullPath );
    }

// -----------------------------------------------------------------------------
// CFileManagerUtils::IsDrmLocalDataFile
//
// -----------------------------------------------------------------------------
//
TBool CFileManagerUtils::IsDrmLocalDataFile( const TDesC& aFullPath ) const
    {
    if ( !iDrmFullSupported )
        {
        return EFalse; // Partial DRM is used
        }

    TBool isFlk( EFalse );
    TBool isLdf( EFalse );
    TRAP_IGNORE( IsFlkOrLdfFileL( aFullPath, isFlk, isLdf ) );
    return isLdf;
    }

// -----------------------------------------------------------------------------
// CFileManagerUtils::CanDelete
//
// -----------------------------------------------------------------------------
//
TBool CFileManagerUtils::CanDelete( const TDesC& aFileName ) const
    {
    TEntry entry;
    TBool ret( EFalse );
    TBool fileOpen( EFalse );
    if ( KErrNone == iFs.Entry( aFileName, entry ) &&
        KErrNone == iFs.IsFileOpen( aFileName, fileOpen ) )
        {
        if ( !entry.IsReadOnly() && !entry.IsSystem() && !fileOpen )
            {
            ret = ETrue;
            }
        }
    return ret;
    }

// -----------------------------------------------------------------------------
// CFileManagerUtils::FileTypeL
//
// -----------------------------------------------------------------------------
//
TUint32 CFileManagerUtils::FileTypeL( const TDesC& aFullPath )
    {
    TUint32 fileType( CFileManagerItemProperties::ENotDefined );

    _LIT( KRootFolder, "?:\\" );
    if ( !aFullPath.MatchF( KRootFolder ) )
        {
        // RFs::Entry cannot be used for root folders
        fileType |= CFileManagerItemProperties::EFolder;
        }
    else if ( !IsRemoteDrive( aFullPath ) )
        {
        // Full check for local and removable drives
        TEntry entry;
        User::LeaveIfError( iFs.Entry( aFullPath, entry ) );

        if ( HasFinalBackslash( aFullPath ) || entry.IsDir() )
            {
            fileType |= CFileManagerItemProperties::EFolder;

            if ( DefaultFolder( aFullPath ) )
                {
                fileType |= CFileManagerItemProperties::EDefault;
                }
            }
        else
            {
            fileType |= CFileManagerItemProperties::EFile;

            if ( IsDrmProtectedFile( aFullPath) )
                {
                fileType |= CFileManagerItemProperties::EDrmProtected;
                if ( IsDrmLocalDataFile( aFullPath ) )
                    {
                    fileType |= CFileManagerItemProperties::EDrmLocalDataFile;
                    }
                }
            if ( IsForwardLockedFile( aFullPath ) )
                {
                fileType |= CFileManagerItemProperties::EForwardLocked;
                }
            // MimeIcon mapper knowledge is used to determine file type
            TInt id( iMimeIconMapper->ResolveIconL( aFullPath ) );
            if ( id == EFileManagerLinkFileIcon )
                {
                fileType |= CFileManagerItemProperties::ELink;
                }
            if ( id == EFileManagerPlaylistFileIcon )
                {
                fileType |= CFileManagerItemProperties::EPlaylist;
                }

            TBool fileOpen( EFalse );
            if ( iFs.IsFileOpen( aFullPath, fileOpen ) == KErrNone )
                {
                if ( fileOpen )
                    {
                    fileType |= CFileManagerItemProperties::EOpen;
                    }
                }
            if ( fileOpen || entry.IsReadOnly() || entry.IsSystem() )
                {
                fileType |= CFileManagerItemProperties::EReadOnly;
                }
            }
        }
    else
        {
        // Simple check for remote drives
        if ( HasFinalBackslash( aFullPath ) )
            {
            fileType |= CFileManagerItemProperties::EFolder;
            }
        else
            {
            fileType |= CFileManagerItemProperties::EFile;
            if ( IsDrmProtectedFile( aFullPath) )
                {
                fileType |= CFileManagerItemProperties::EDrmProtected;
                }
            }
        }
        
    return fileType;
    }

// -----------------------------------------------------------------------------
// CFileManagerUtils::ResolveIconL
//
// -----------------------------------------------------------------------------
//
TInt CFileManagerUtils::ResolveIconL( CGflmGroupItem& aItem ) const
    {
    TInt iconId( EFileManagerOtherFileIcon );
    if ( aItem.GetIconId( iconId ) == KErrNone )
        {
        // Use already mapped icon
        return iconId;
        }

    // Map icon
    switch ( aItem.Type() )
        {
        case CGflmGroupItem::EFile:
            {
            CGflmFileSystemItem& fsItem =
                static_cast< CGflmFileSystemItem& >( aItem );
            HBufC* fullPath = fsItem.FullPathLC();
            iconId = iMimeIconMapper->ResolveIconL( *fullPath );
            fsItem.SetIconId( iconId );
            CleanupStack::PopAndDestroy( fullPath );
            break;
            }
        case CGflmGroupItem::EDirectory:
            {
            CGflmFileSystemItem& fsItem =
                static_cast< CGflmFileSystemItem& >( aItem );
            HBufC* fullPath = fsItem.FullPathLC();

            // Do not check for subfolders for remote drives
            iconId = EFileManagerFolderIcon;
            if ( !IsRemoteDrive( *fullPath ) )
                {
                if ( HasSubFolders( *fullPath ) )
                    {
                    iconId = EFileManagerFolderSubIcon;
                    }
                else if ( !HasFiles( *fullPath ) )
                    {
                    iconId = EFileManagerFolderEmptyIcon;
                    }
                }
            fsItem.SetIconId( iconId );
            CleanupStack::PopAndDestroy( fullPath );
            break;
            }
        case CGflmGroupItem::EDrive: // Fall through
        case CGflmGroupItem::EGlobalActionItem:
            {
            break;
            }
        default:
            {
            User::Leave( KErrNotFound );
            break;
            }
        }

    return iconId;
    }

// -----------------------------------------------------------------------------
// CFileManagerUtils::HasAny
// 
// -----------------------------------------------------------------------------
//
TBool CFileManagerUtils::HasAny(
        RFs& aFs, const TDesC& aFullPath,  TUint aAttMask )
    {
    RDir dir;
    TBool ret( EFalse );
    if ( dir.Open( aFs, aFullPath, aAttMask ) != KErrNone )
        {
        return EFalse;
        }
    TEntry entry;
    if ( dir.Read( entry ) == KErrNone )
        {
        ret = ETrue;
        }
    dir.Close();
    return ret;
    }

// -----------------------------------------------------------------------------
// CFileManagerUtils::HasSubFolders
// 
// -----------------------------------------------------------------------------
//
TBool CFileManagerUtils::HasSubFolders( const TDesC& aFullPath ) const
    {
    return HasAny( iFs, aFullPath, KEntryAttDir | KEntryAttMatchExclusive );
    }

// -----------------------------------------------------------------------------
// CFileManagerUtils::HasFiles
// 
// -----------------------------------------------------------------------------
//
TBool CFileManagerUtils::HasFiles( const TDesC& aFullPath ) const
    {
    return HasAny( iFs, aFullPath, KEntryAttNormal );
    }

// -----------------------------------------------------------------------------
// CFileManagerUtils::IsRemoteDrive
// 
// -----------------------------------------------------------------------------
//
TBool CFileManagerUtils::IsRemoteDrive( const TDesC& aPath ) const
    {
    TBool ret( EFalse );
    
    if ( aPath.Length() )
        {
        CGflmDriveItem* drvItem = iNavigator.DriveFromPath( aPath );
        if ( drvItem )
            {
            const TVolumeInfo& vol( drvItem->VolumeInfo() );
            if ( vol.iDrive.iDriveAtt & KDriveAttRemote )
                {
                ret = ETrue;
                }
            }
        }
    return ret;
    }

// -----------------------------------------------------------------------------
// CFileManagerUtils::CreateDefaultFolders
// 
// -----------------------------------------------------------------------------
//
void CFileManagerUtils::CreateDefaultFolders(
        const TInt aDrive, const TBool aForced ) const
    {
    iDefaultFolders->CreateFolders( aDrive, aForced );
    }

// -----------------------------------------------------------------------------
// CFileManagerUtils::IsDistributableFile
// 
// -----------------------------------------------------------------------------
//
TInt CFileManagerUtils::IsDistributableFile(
        const TDesC& aFullPath, TBool& aIsProtected )
    {
#if defined( __KEEP_DRM_CONTENT_ON_PHONE ) && defined ( FILE_MANAGER_USE_DISTRIBUTABLECHECKER )
    if ( !iDistributableChecker )
        {
        TRAPD( err, iDistributableChecker = CDistributableChecker::NewL() );        
        if ( err != KErrNone )
            {
            _LIT( KReason, "No Distributablechecker" );
            User::Panic( KReason, err );
            }
        }
    return iDistributableChecker->Check( aFullPath, aIsProtected );
#else // __KEEP_DRM_CONTENT_ON_PHONE && FILE_MANAGER_USE_DISTRIBUTABLECHECKER
    aIsProtected = EFalse;
    TBool isFlk( EFalse );
    TBool isLdf( EFalse );
    TRAPD( err, IsFlkOrLdfFileL( aFullPath, isFlk, isLdf ) );
    // Do similar check than in old DRMCommon
    aIsProtected = ( isFlk || isLdf );
    return err;
#endif // __KEEP_DRM_CONTENT_ON_PHONE && FILE_MANAGER_USE_DISTRIBUTABLECHECKER
    }

// -----------------------------------------------------------------------------
// CFileManagerUtils::MimeTypeL
// 
// -----------------------------------------------------------------------------
//
TPtrC CFileManagerUtils::MimeTypeL( const TDesC& aFullPath ) const
    {
    return iNavigator.ResolveMimeTypeL( aFullPath );
    }

// -----------------------------------------------------------------------------
// CFileManagerUtils::DriveList
// 
// -----------------------------------------------------------------------------
//
void CFileManagerUtils::DriveList(
        RArray< TInt >& aDrives, const TInt aAttMask ) const
    {
    aDrives.Reset();
    TDriveList drivesList;
    if ( iFs.DriveList( drivesList ) != KErrNone )
        {
        return;
        }
    for ( TInt i( 0 ); i < KMaxDrives; i++ )
        {
        if ( drivesList[ i ] )
            {
            TBool append( EFalse );
            TDriveInfo drvInfo;
            if ( iFs.Drive( drvInfo, i ) == KErrNone )
                {
                if ( drvInfo.iDriveAtt & aAttMask )
                    {
                    append = ETrue;
                    }
                }
            if ( append )
                {
                aDrives.Append( i );
                }
            }
        }
    }

// -----------------------------------------------------------------------------
// CFileManagerUtils::IsRemovableDrive
// 
// -----------------------------------------------------------------------------
//
TBool CFileManagerUtils::IsRemovableDrive( const TDesC& aPath ) const
    {
    return IsDrive( iFs, aPath, KDriveAttRemovable );
    }

// -----------------------------------------------------------------------------
// CFileManagerUtils::GetFullPath
// -----------------------------------------------------------------------------
//
void CFileManagerUtils::GetFullPath(
        const TDesC& aDir, const TEntry& aEntry, TDes& aFullPath )
    {
    GflmUtils::GetFullPath( aDir, aEntry, aFullPath );
    }

// -----------------------------------------------------------------------------
// CFileManagerUtils::StripFinalBackslash
// -----------------------------------------------------------------------------
//
EXPORT_C TPtrC CFileManagerUtils::StripFinalBackslash( const TDesC& aPath )
    {
    return GflmUtils::StripFinalBackslash( aPath );
    }

// -----------------------------------------------------------------------------
// CFileManagerUtils::EnsureFinalBackslash
// -----------------------------------------------------------------------------
//
EXPORT_C void CFileManagerUtils::EnsureFinalBackslash( TDes& aPath )
    {
    GflmUtils::EnsureFinalBackslash( aPath );
    }

// -----------------------------------------------------------------------------
// CFileManagerUtils::StripDirectionalCharsLC
// -----------------------------------------------------------------------------
//
HBufC* CFileManagerUtils::StripDirectionalCharsLC( const TDesC& aText )
    {
    HBufC* text = aText.AllocLC();
    TPtr ptr( text->Des() );
    AknTextUtils::StripCharacters( ptr, KFmgrDirectionalChars );
    return text;
    }

// -----------------------------------------------------------------------------
// CFileManagerUtils::IsFlkOrLdfFileL
// -----------------------------------------------------------------------------
//
void CFileManagerUtils::IsFlkOrLdfFileL(
        const TDesC& aFullPath, TBool& aIsFlk, TBool& aIsLdf )
    {
    aIsFlk = EFalse;
    aIsLdf = EFalse;
    ContentAccess::CContent* content =
        ContentAccess::CContent::CContent::NewLC(
            aFullPath, EContentShareReadOnly );
    HBufC* contentId = HBufC::NewLC( KMaxFileName );
    TPtr ptrContentId( contentId->Des() );
    TInt err( content->GetStringAttribute(
        ContentAccess::EContentID, ptrContentId ) );
    if ( err != KErrNone && err != KErrCANotSupported )
        {
        User::Leave( err );
        }
    if ( !ptrContentId.Left( KFlk().Length() ).Compare( KFlk ) )
        {
        aIsFlk = ETrue;
        }
    else if ( !ptrContentId.Left( KLdf().Length() ).Compare( KLdf ) )
        {
        aIsLdf = ETrue;
        }
    CleanupStack::PopAndDestroy( contentId );
    CleanupStack::PopAndDestroy( content );
    }

// -----------------------------------------------------------------------------
// CFileManagerUtils::HasFinalBackslash
// -----------------------------------------------------------------------------
//
EXPORT_C TBool CFileManagerUtils::HasFinalBackslash( const TDesC& aPath )
    {
    return GflmUtils::HasFinalBackslash( aPath );
    }

// -----------------------------------------------------------------------------
// CFileManagerUtils::IsInternalDrive
// -----------------------------------------------------------------------------
//
TBool CFileManagerUtils::IsInternalDrive( RFs& aFs, const TInt aDrive )
    {
    return IsDrive( aFs, aDrive, KDriveAttInternal );
    }

// -----------------------------------------------------------------------------
// CFileManagerUtils::IsFromInternalToRemovableDrive
// -----------------------------------------------------------------------------
//
EXPORT_C TBool CFileManagerUtils::IsFromInternalToRemovableDrive(
        RFs& aFs, const TDesC& aSrcPath, const TDesC& aDstPath )
    {
    TInt srcDrv = TDriveUnit( aSrcPath );
    TInt dstDrv = TDriveUnit( aDstPath );
    if ( srcDrv == dstDrv )
        {
        return EFalse;
        }
    return ( IsInternalDrive( aFs, srcDrv ) &&
             !IsInternalDrive( aFs, dstDrv ) );
    }

// -----------------------------------------------------------------------------
// CFileManagerUtils::RemoveReadOnlyAttribute
// -----------------------------------------------------------------------------
//
TInt CFileManagerUtils::RemoveReadOnlyAttribute(
        RFs& aFs, const TDesC& aFullPath, const TEntry& aEntry )
    {
    TInt ret( KErrNone );
    if( aEntry.IsReadOnly() )
        {
        ret = aFs.SetEntry(
        aFullPath, aEntry.iModified, 0, KEntryAttReadOnly );
        }
    return ret;
    }

// -----------------------------------------------------------------------------
// CFileManagerUtils::RemoveReadOnlyAttribute
// -----------------------------------------------------------------------------
//
TInt CFileManagerUtils::RemoveReadOnlyAttribute(
        RFs& aFs, const TDesC& aFullPath )
    {
    TEntry entry;
    TInt ret( aFs.Entry( aFullPath, entry ) );
    if ( ret == KErrNone )
        {
        ret = RemoveReadOnlyAttribute( aFs, aFullPath, entry );
        }
    return ret;
    }

#ifdef RD_MULTIPLE_DRIVE
// -----------------------------------------------------------------------------
// CFileManagerUtils::GetDriveNameArrayLC
// -----------------------------------------------------------------------------
//
CDesCArray* CFileManagerUtils::GetDriveNameArrayLC(
        const TInt aDrive, TUint& aDriveStatus ) const
    {
    CGflmDriveItem* drvItem = iNavigator.DriveFromId( aDrive );
    if ( !drvItem )
        {
        User::Leave( KErrNotFound );
        }
    aDriveStatus = drvItem->DriveStatus();
    CDesCArray* ret = new( ELeave ) CDesCArrayFlat( KDriveNameArrayLen );
    CleanupStack::PushL( ret );
    ret->AppendL( TDriveUnit( aDrive ).Name() );

    if ( aDriveStatus & DriveInfo::EDriveInternal )
        {
        // Device memory and mass storage drives
        return ret;
        }
    // Other drives
    TPtrC drvName( drvItem->Name() );
    if ( drvName.Length() )
        {
        ret->AppendL( drvName );
        }    
    return ret;
    }

// -----------------------------------------------------------------------------
// CFileManagerUtils::GetDriveNameL
// -----------------------------------------------------------------------------
//
HBufC* CFileManagerUtils::GetDriveNameL(
        const TInt aDrive, const TDriveNameLayout aLayout ) const
    {
    if ( aLayout < 0 || aLayout >= ELayoutCount )
        {
        User::Leave( KErrArgument );
        }
    TUint driveStatus( 0 );
    CDesCArray* array = GetDriveNameArrayLC( aDrive, driveStatus );
    HBufC* ret = NULL;
    if ( driveStatus & DriveInfo::EDriveInternal )
        {
        // Device memory and mass storage drives
        if ( driveStatus & DriveInfo::EDriveExternallyMountable )
            {
            ret = StringLoader::LoadL(
                KFmgrDriveNames[ aLayout ][ EFmgrMassStorage ],
                array->MdcaPoint( KDriveLetterIndex ) );
            }
        else
            {
            ret = StringLoader::LoadL(
                KFmgrDriveNames[ aLayout ][ EFmgrDeviceMemory ],
                array->MdcaPoint( KDriveLetterIndex ) );
            }
        }
    else if ( driveStatus & DriveInfo::EDriveRemovable )
        {
        // Physically removable drives
        if ( array->MdcaCount() > 1 )
            {
            ret = StringLoader::LoadL(
                KFmgrDriveNames[ aLayout ][ EFmgrNamedMemoryCard ],
                *array );
            }
        else
            {
            TInt driveType( EFmgrDefaultMemoryCard );
            if ( driveStatus & DriveInfo::EDriveUsbMemory )
                {
                driveType = EFmgrDefaultUsbMemory;
                }
            ret = StringLoader::LoadL(
                    KFmgrDriveNames[ aLayout ][ driveType ],
                array->MdcaPoint( KDriveLetterIndex ) );
            }
        }
    else if ( array->MdcaCount() > 1 )
        {
        // Other drives
        ret = array->MdcaPoint( KDriveNameIndex ).AllocL();
        }
    else
        {
        User::Leave( KErrNotFound );
        }
    CleanupStack::PopAndDestroy( array );
    return ret;
    }

// -----------------------------------------------------------------------------
// CFileManagerUtils::GetFormattedDriveNameLC
// -----------------------------------------------------------------------------
//
HBufC* CFileManagerUtils::GetFormattedDriveNameLC(
        const TInt aDrive,
        const TInt aTextIdForDefaultName,
        const TInt aTextIdForName ) const
    {
    TUint driveStatus( 0 );
    HBufC* ret = NULL;
    CDesCArray* array = GetDriveNameArrayLC( aDrive, driveStatus );
    if ( aTextIdForName && array->MdcaCount() > 1 )
        {
        ret = StringLoader::LoadL(
            aTextIdForName,
            *array );
        }
    else if ( aTextIdForDefaultName )
        {
			if( driveStatus & DriveInfo::EDriveUsbMemory )
				{
				CDesCArray* usbLetterName = new ( ELeave ) CDesCArrayFlat( KDriveNameArrayLen );
				CleanupStack::PushL( usbLetterName );
				
				TPtrC16 driveletter=array->MdcaPoint( KDriveLetterIndex );
				usbLetterName->AppendL( driveletter );
				
				if(array->MdcaCount() > 1 )
					{
					TPtrC16 drivename=array->MdcaPoint( KDriveNameIndex );
					usbLetterName->AppendL( drivename );
					}
				else
					{
					TPtrC16 drivename=_L("");
					usbLetterName->AppendL( drivename );
					}
				
				
				ret = StringLoader::LoadL(
				aTextIdForDefaultName,*usbLetterName );
	
				CleanupStack::PopAndDestroy( usbLetterName );
			}
		else
			{
			ret = StringLoader::LoadL(aTextIdForDefaultName, array->MdcaPoint(
					KDriveLetterIndex));
            	}
        }
    else if (  array->MdcaCount() > 1 )
        {
        ret = array->MdcaPoint( KDriveNameIndex ).AllocL();
        }
    else
        {
        User::Leave( KErrNotFound );
        }
    CleanupStack::PopAndDestroy( array );
    CleanupStack::PushL( ret );
    return ret;
    }

#endif // RD_MULTIPLE_DRIVE

// -----------------------------------------------------------------------------
// CFileManagerUtils::IsRemoteDrive
// -----------------------------------------------------------------------------
EXPORT_C TBool CFileManagerUtils::IsRemoteDrive(
        RFs& aFs, const TDesC& aPath )
    {
    return IsDrive( aFs, aPath, KDriveAttRemote );
    }

// -----------------------------------------------------------------------------
// CFileManagerUtils::IsDrive
// -----------------------------------------------------------------------------
TBool CFileManagerUtils::IsDrive(
        RFs& aFs, const TDesC& aPath, const TUint aAttMask )
    {
    TInt drv( 0 );
    if ( aPath.Length() &&
        RFs::CharToDrive( aPath[ 0 ], drv ) == KErrNone )
        {
        return IsDrive( aFs, drv, aAttMask );
        }
    return EFalse;
    }

// -----------------------------------------------------------------------------
// CFileManagerUtils::IsDrive
// -----------------------------------------------------------------------------
TBool CFileManagerUtils::IsDrive(
        RFs& aFs, const TInt aDrive, const TUint aAttMask )
    {
    TDriveInfo drvInfo;
    if ( aFs.Drive( drvInfo, aDrive ) == KErrNone )
        {
        if ( drvInfo.iDriveAtt & aAttMask )
            {
            return ETrue;
            }
        }
    return EFalse;
    }

// ------------------------------------------------------------------------------
// CFileManagerUtils::LocalizedName
//
// ------------------------------------------------------------------------------
//
TPtrC CFileManagerUtils::LocalizedName( const TDesC& aFullPath ) const
    {
    return iNavigator.LocalizedName( aFullPath );
    }

// -----------------------------------------------------------------------------
// CFileManagerUtils::IsNameFoundL
// -----------------------------------------------------------------------------
//
TBool CFileManagerUtils::IsNameFoundL( const TDesC& aFullPath ) const
    {
    TParsePtrC parse( CFileManagerUtils::StripFinalBackslash( aFullPath ) );
    TPtrC baseDir( parse.DriveAndPath() );
    TPtrC currentDir( iNavigator.CurrentDirectory() );
    TBool ret( EFalse );
    HBufC* name1 = CFileManagerUtils::StripDirectionalCharsLC( parse.NameAndExt() );
    // Remove white spaces from end, file server also ignores those
    name1->Des().TrimRight();
    if ( !parse.PathPresent() ||
         ( currentDir.Length() && !currentDir.CompareF( baseDir ) ) )
        {
        TBool searchmode  = iNavigator.SearchMode();
        iNavigator.EnableSearchMode( EFalse );
        // Do check from current directory, all items are cached
        TInt count( iNavigator.MdcaCount() );
        for( TInt i( 0 ); i < count; ++i )
            {
            CGflmGroupItem* item = iNavigator.Item( i );
            TInt itemType( item->Type() );
            switch (itemType )
                {
                case CGflmGroupItem::EFile: // FALLTHROUGH
                case CGflmGroupItem::EDirectory:
                    {
                    // Compare with file system name
                    CGflmFileSystemItem* fsItem =
                        static_cast< CGflmFileSystemItem* >( item );
                    HBufC* name2 = CFileManagerUtils::StripDirectionalCharsLC(
                        fsItem->Entry().iName );
                    ret = !( name1->CompareF( *name2 ) );
                    CleanupStack::PopAndDestroy( name2 );
                    if ( !ret && itemType == CGflmGroupItem::EDirectory )
                        {
                        // Compare with localized name
                        name2 = CFileManagerUtils::StripDirectionalCharsLC(
                            fsItem->Name() );
                        if ( name2->Length() )
                            {
                            ret = !( name1->CompareF( *name2 ) );
                            }
                        CleanupStack::PopAndDestroy( name2 );
                        }
                    break;
                    }                    
                default:
                    {
                    break;
                    }
                }
            if ( ret )
                {
                break;
                }
            }
        iNavigator.EnableSearchMode( searchmode );
        }
    else
        {
        // Do check from any directory
        HBufC* buffer = HBufC::NewLC(
            Max( KMaxFileName, aFullPath.Length() + KFmgrBackslashSpace ) );
        TPtr ptr( buffer->Des() );
        ptr.Copy( aFullPath );
        CFileManagerUtils::EnsureFinalBackslash( ptr );
        ret = ( BaflUtils::FolderExists( iFs, ptr ) ||
                BaflUtils::FileExists( iFs,
                    CFileManagerUtils::StripFinalBackslash( aFullPath ) ) );
        if ( !ret &&
             !IsRemoteDrive( aFullPath ) &&
             BaflUtils::PathExists( iFs, baseDir ) )
            {
            // Check directory for localized items on local drives
            CDir* dir = NULL;
            User::LeaveIfError( iFs.GetDir(
                baseDir, KEntryAttMatchMask | KEntryAttNormal, ESortNone, dir ) );
            CleanupStack::PushL( dir );
            ptr.Zero();
            TInt count( dir->Count() );
            for ( TInt i ( 0 ); i < count; ++i )
                {
                HBufC* name2 = NULL;
                const TEntry& entry( ( *dir )[ i ] );
                if( entry.IsDir() )
                    {
                    // Compare with localized name
                    CFileManagerUtils::GetFullPath( baseDir, entry, ptr );
                    TPtrC ptr2( iNavigator.LocalizedName( ptr ) );
                    if ( ptr2.Length() )
                        {
                        name2 = CFileManagerUtils::StripDirectionalCharsLC( ptr2 );
                        }
                    }
                if ( !name2 )
                    {
                    // Compare with file system name
                    name2 = CFileManagerUtils::StripDirectionalCharsLC( entry.iName );
                    }
                ret = !( name1->CompareF( *name2 ) );
                CleanupStack::PopAndDestroy( name2 );
                if ( ret )
                    {
                    break;
                    }
                }
            CleanupStack::PopAndDestroy( dir );
            }
        CleanupStack::PopAndDestroy( buffer );
        }
    CleanupStack::PopAndDestroy( name1 );
    return ret;
    }
// -----------------------------------------------------------------------------
// CFileManagerUtils::FlushCache
// -----------------------------------------------------------------------------
//
void CFileManagerUtils::FlushCache() const
    {
    iNavigator.FlushCache();
    }

//  End of File