filemanager/src/inc/fmutils.cpp
author hgs
Tue, 24 Aug 2010 10:24:14 +0800
changeset 37 15bc28c9dd51
child 46 d58987eac7e8
permissions -rw-r--r--
201033
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
37
hgs
parents:
diff changeset
     1
/*
hgs
parents:
diff changeset
     2
* Copyright (c) 2009 Nokia Corporation and/or its subsidiary(-ies).
hgs
parents:
diff changeset
     3
* All rights reserved.
hgs
parents:
diff changeset
     4
* This component and the accompanying materials are made available
hgs
parents:
diff changeset
     5
* under the terms of "Eclipse Public License v1.0"
hgs
parents:
diff changeset
     6
* which accompanies this distribution, and is available
hgs
parents:
diff changeset
     7
* at the URL "http://www.eclipse.org/legal/epl-v10.html".
hgs
parents:
diff changeset
     8
*
hgs
parents:
diff changeset
     9
* Initial Contributors:
hgs
parents:
diff changeset
    10
* Nokia Corporation - initial contribution.
hgs
parents:
diff changeset
    11
*
hgs
parents:
diff changeset
    12
* Contributors:
hgs
parents:
diff changeset
    13
*     Zhiqiang Yang <zhiqiang.yang@nokia.com>
hgs
parents:
diff changeset
    14
* 
hgs
parents:
diff changeset
    15
* Description:
hgs
parents:
diff changeset
    16
*     The source file of the file manager utilities
hgs
parents:
diff changeset
    17
*/
hgs
parents:
diff changeset
    18
hgs
parents:
diff changeset
    19
#include "fmutils.h"
hgs
parents:
diff changeset
    20
hgs
parents:
diff changeset
    21
#include <QDir>
hgs
parents:
diff changeset
    22
#include <QFileInfo>
hgs
parents:
diff changeset
    23
hgs
parents:
diff changeset
    24
#include <hbglobal.h>
hgs
parents:
diff changeset
    25
hgs
parents:
diff changeset
    26
/*!
hgs
parents:
diff changeset
    27
    Used to get drive type for convenience.
hgs
parents:
diff changeset
    28
*/
hgs
parents:
diff changeset
    29
FmDriverInfo::DriveType FmDriverInfo::driveType()
hgs
parents:
diff changeset
    30
{
hgs
parents:
diff changeset
    31
    FmDriverInfo::DriveType driveType;
hgs
parents:
diff changeset
    32
    if( mDriveState & FmDriverInfo::EDriveRemovable ) {
hgs
parents:
diff changeset
    33
        // if drive is removable, it may be mass, usb, or remote drive
hgs
parents:
diff changeset
    34
        if( mDriveState & FmDriverInfo::EDriveMassStorage ) {
hgs
parents:
diff changeset
    35
            driveType = FmDriverInfo::EDriveTypeMassStorage;
hgs
parents:
diff changeset
    36
        } else if( mDriveState & FmDriverInfo::EDriveUsbMemory ) {
hgs
parents:
diff changeset
    37
            driveType = FmDriverInfo::EDriveTypeUsbMemory;
hgs
parents:
diff changeset
    38
        } else if( mDriveState & FmDriverInfo::EDriveRemote ){
hgs
parents:
diff changeset
    39
            driveType = FmDriverInfo::EDriveTypeRemote;
hgs
parents:
diff changeset
    40
        } else {
hgs
parents:
diff changeset
    41
            driveType = FmDriverInfo::EDriveTypeMemoryCard;
hgs
parents:
diff changeset
    42
        }
hgs
parents:
diff changeset
    43
    } else if( mDriveState & FmDriverInfo::EDriveRom ) {
hgs
parents:
diff changeset
    44
        driveType = FmDriverInfo::EDriveTypeRom;
hgs
parents:
diff changeset
    45
    } else if( mDriveState & FmDriverInfo::EDriveRam ) {
hgs
parents:
diff changeset
    46
        driveType = FmDriverInfo::EDriveTypeRam;
hgs
parents:
diff changeset
    47
    } else {
hgs
parents:
diff changeset
    48
        // if drive type is not recognized in previous condition,
hgs
parents:
diff changeset
    49
        // it should be an un-existed drive or phone memory
hgs
parents:
diff changeset
    50
        if( mDriveState & EDriveNotPresent ){
hgs
parents:
diff changeset
    51
            // if come here, means 2 conditions:
hgs
parents:
diff changeset
    52
            //  1 this drive is not exist( FmUtils::queryDriverInfo will give EDriveNotPresent to mDriveState )
hgs
parents:
diff changeset
    53
            //  2 un-mounted removable drive
hgs
parents:
diff changeset
    54
            // removable drive filted in previous condifiton. So, give EDriveTypeNotExist 
hgs
parents:
diff changeset
    55
            driveType = FmDriverInfo::EDriveTypeNotExist;
hgs
parents:
diff changeset
    56
        } else {
hgs
parents:
diff changeset
    57
            // drive is existed, only remain the type of EDriveTypePhoneMemory
hgs
parents:
diff changeset
    58
            driveType = FmDriverInfo::EDriveTypePhoneMemory;
hgs
parents:
diff changeset
    59
        }
hgs
parents:
diff changeset
    60
    }
hgs
parents:
diff changeset
    61
    
hgs
parents:
diff changeset
    62
    return driveType;
hgs
parents:
diff changeset
    63
}
hgs
parents:
diff changeset
    64
hgs
parents:
diff changeset
    65
/*!
hgs
parents:
diff changeset
    66
    return drive name for \a path
hgs
parents:
diff changeset
    67
*/
hgs
parents:
diff changeset
    68
QString FmUtils::getDriveNameFromPath( const QString &path )
hgs
parents:
diff changeset
    69
{
hgs
parents:
diff changeset
    70
    // fillPathWithSplash make sure path length will be at least 3 if it is not empty.
hgs
parents:
diff changeset
    71
    QString checkedPath( fillPathWithSplash( path ) );
hgs
parents:
diff changeset
    72
    if( checkedPath.length() < 3 ) {
hgs
parents:
diff changeset
    73
        return QString();
hgs
parents:
diff changeset
    74
    }
hgs
parents:
diff changeset
    75
    return checkedPath.left( 3 );
hgs
parents:
diff changeset
    76
}
hgs
parents:
diff changeset
    77
hgs
parents:
diff changeset
    78
/*!
hgs
parents:
diff changeset
    79
    return drive letter for \a path
hgs
parents:
diff changeset
    80
*/
hgs
parents:
diff changeset
    81
QString FmUtils::getDriveLetterFromPath( const QString &path )
hgs
parents:
diff changeset
    82
{
hgs
parents:
diff changeset
    83
	if( path.length() <2 ) {
hgs
parents:
diff changeset
    84
        return QString();
hgs
parents:
diff changeset
    85
    }
hgs
parents:
diff changeset
    86
    return path.left( 1 );
hgs
parents:
diff changeset
    87
}
hgs
parents:
diff changeset
    88
hgs
parents:
diff changeset
    89
/*!
hgs
parents:
diff changeset
    90
    return formatted string for size.
hgs
parents:
diff changeset
    91
*/
hgs
parents:
diff changeset
    92
QString FmUtils::formatStorageSize( quint64 size )
hgs
parents:
diff changeset
    93
{
hgs
parents:
diff changeset
    94
	if ( size < 1000 ) {
hgs
parents:
diff changeset
    95
		return QString::number( size ) + " B";
hgs
parents:
diff changeset
    96
	} else if ( size < 1000 * 1000 ) {
hgs
parents:
diff changeset
    97
		return QString::number( size / 1024.0, 'f', 2 ) + " KB";
hgs
parents:
diff changeset
    98
	} else if ( size < 1000 * 1000 * 1000 ) {
hgs
parents:
diff changeset
    99
		return QString::number( size / (1024.0 * 1024.0), 'f', 1 ) + " MB";
hgs
parents:
diff changeset
   100
	} else {
hgs
parents:
diff changeset
   101
	    return QString::number( size / ( 1024.0 * 1024.0 * 1024.0 ), 'f', 1 ) + " GB";	    
hgs
parents:
diff changeset
   102
	}
hgs
parents:
diff changeset
   103
}
hgs
parents:
diff changeset
   104
hgs
parents:
diff changeset
   105
/*!
hgs
parents:
diff changeset
   106
    Judge if a path is drive path, not a folder or a file.
hgs
parents:
diff changeset
   107
    For example, true for C:\ while false for C:\data
hgs
parents:
diff changeset
   108
*/
hgs
parents:
diff changeset
   109
bool FmUtils::isDrive( const QString &path )
hgs
parents:
diff changeset
   110
{
hgs
parents:
diff changeset
   111
   bool ret( false );
hgs
parents:
diff changeset
   112
   if( path.length() <= 3 && path.length() >=2 ) {
hgs
parents:
diff changeset
   113
       ret = true;
hgs
parents:
diff changeset
   114
   }
hgs
parents:
diff changeset
   115
   
hgs
parents:
diff changeset
   116
   return ret;   
hgs
parents:
diff changeset
   117
}
hgs
parents:
diff changeset
   118
hgs
parents:
diff changeset
   119
/*!
hgs
parents:
diff changeset
   120
    All "/" and "\" in \a path will be changed to QDir::separator
hgs
parents:
diff changeset
   121
    \sa fillPathWithSplash, fillPathWithSplash will append QDir::separator in the end
hgs
parents:
diff changeset
   122
*/
hgs
parents:
diff changeset
   123
QString FmUtils::formatPath( const QString &path  )
hgs
parents:
diff changeset
   124
{
hgs
parents:
diff changeset
   125
    QString formatPath;
hgs
parents:
diff changeset
   126
    if( path.isEmpty() ) {
hgs
parents:
diff changeset
   127
        return formatPath;
hgs
parents:
diff changeset
   128
    }
hgs
parents:
diff changeset
   129
    
hgs
parents:
diff changeset
   130
    foreach( const QChar &ch, path ) {
hgs
parents:
diff changeset
   131
        if( ch == QChar('\\') || ch == QChar('/') ) {
hgs
parents:
diff changeset
   132
            formatPath.append( QDir::separator() );
hgs
parents:
diff changeset
   133
        } else {
hgs
parents:
diff changeset
   134
            formatPath.append( ch );
hgs
parents:
diff changeset
   135
        }
hgs
parents:
diff changeset
   136
    }
hgs
parents:
diff changeset
   137
hgs
parents:
diff changeset
   138
    return formatPath;
hgs
parents:
diff changeset
   139
}
hgs
parents:
diff changeset
   140
hgs
parents:
diff changeset
   141
/*!
hgs
parents:
diff changeset
   142
    Fill splash in the end of \a filePath. And all "/" and "\" will be changed to QDir::separator
hgs
parents:
diff changeset
   143
    Please do not call this function if path is a file.
hgs
parents:
diff changeset
   144
    Use \a formatPath instead, \a formatPath will not append QDir::separator in the end.
hgs
parents:
diff changeset
   145
    \sa formatPath only changed "/" and "\" to QDir::separator
hgs
parents:
diff changeset
   146
*/
hgs
parents:
diff changeset
   147
QString FmUtils::fillPathWithSplash( const QString &filePath )
hgs
parents:
diff changeset
   148
{
hgs
parents:
diff changeset
   149
    QString newFilePath;
hgs
parents:
diff changeset
   150
    if( filePath.isEmpty() ) {
hgs
parents:
diff changeset
   151
        return newFilePath;
hgs
parents:
diff changeset
   152
    }
hgs
parents:
diff changeset
   153
hgs
parents:
diff changeset
   154
    newFilePath = formatPath( filePath );
hgs
parents:
diff changeset
   155
    
hgs
parents:
diff changeset
   156
    if( newFilePath.right( 1 )!= QDir::separator() ){
hgs
parents:
diff changeset
   157
        newFilePath.append( QDir::separator() );
hgs
parents:
diff changeset
   158
    }
hgs
parents:
diff changeset
   159
    return newFilePath;
hgs
parents:
diff changeset
   160
}
hgs
parents:
diff changeset
   161
hgs
parents:
diff changeset
   162
/*!
hgs
parents:
diff changeset
   163
    Remove splash in the end of \a filePath.
hgs
parents:
diff changeset
   164
*/
hgs
parents:
diff changeset
   165
QString FmUtils::removePathSplash( const QString &filePath )
hgs
parents:
diff changeset
   166
{
hgs
parents:
diff changeset
   167
    QString newFilePath( filePath );
hgs
parents:
diff changeset
   168
    if( filePath.right( 1 ) == QChar( '/' ) || filePath.right(1) == QString( "\\" ) ) {
hgs
parents:
diff changeset
   169
        newFilePath = filePath.left( filePath.length() - 1 );
hgs
parents:
diff changeset
   170
    }
hgs
parents:
diff changeset
   171
    return newFilePath;
hgs
parents:
diff changeset
   172
}
hgs
parents:
diff changeset
   173
hgs
parents:
diff changeset
   174
/*!
hgs
parents:
diff changeset
   175
    fill \a driveList of drives can be shown in driveListView
hgs
parents:
diff changeset
   176
*/
hgs
parents:
diff changeset
   177
void FmUtils::getDriveList( QStringList &driveList, bool isHideUnAvailableDrive )
hgs
parents:
diff changeset
   178
{
hgs
parents:
diff changeset
   179
    if( isHideUnAvailableDrive ) {
hgs
parents:
diff changeset
   180
        FM_LOG( QString( "getDriveList HideUnAvailableDrive_true" ) );
hgs
parents:
diff changeset
   181
    } else {
hgs
parents:
diff changeset
   182
        FM_LOG( QString( "getDriveList HideUnAvailableDrive_false" ) );
hgs
parents:
diff changeset
   183
    }
hgs
parents:
diff changeset
   184
    QFileInfoList infoList = QDir::drives();
hgs
parents:
diff changeset
   185
hgs
parents:
diff changeset
   186
    foreach( const QFileInfo &fileInfo, infoList ) {
hgs
parents:
diff changeset
   187
        QString driveName = fileInfo.absolutePath();
hgs
parents:
diff changeset
   188
        if( checkDriveAccessFilter( driveName ) ) {
hgs
parents:
diff changeset
   189
            if( !isHideUnAvailableDrive ) {
hgs
parents:
diff changeset
   190
                driveList.append( driveName );
hgs
parents:
diff changeset
   191
            }
hgs
parents:
diff changeset
   192
            else if ( isDriveAvailable( driveName ) ) {
hgs
parents:
diff changeset
   193
                driveList.append( driveName );
hgs
parents:
diff changeset
   194
            }
hgs
parents:
diff changeset
   195
        }
hgs
parents:
diff changeset
   196
    }
hgs
parents:
diff changeset
   197
    return;
hgs
parents:
diff changeset
   198
}
hgs
parents:
diff changeset
   199
hgs
parents:
diff changeset
   200
/*!
hgs
parents:
diff changeset
   201
    return the combined string of drive name and volume( e.g. C: Phone memory for C drive)
hgs
parents:
diff changeset
   202
    \a driveName the drive name.
hgs
parents:
diff changeset
   203
    If set \a isFillWithDefaultVolume true, fill result with default volume if drive volume is empty.
hgs
parents:
diff changeset
   204
*/
hgs
parents:
diff changeset
   205
QString FmUtils::fillDriveVolume( QString driveName, bool isFillWithDefaultVolume )
hgs
parents:
diff changeset
   206
{
hgs
parents:
diff changeset
   207
    QString ret;
hgs
parents:
diff changeset
   208
    if( driveName.isEmpty() ) {
hgs
parents:
diff changeset
   209
        return ret;
hgs
parents:
diff changeset
   210
    }
hgs
parents:
diff changeset
   211
    QString tempDriveName = fillPathWithSplash( driveName );
hgs
parents:
diff changeset
   212
hgs
parents:
diff changeset
   213
    QString checkedDriveName( removePathSplash( driveName ) );
hgs
parents:
diff changeset
   214
    
hgs
parents:
diff changeset
   215
    FmDriverInfo driverInfo = FmUtils::queryDriverInfo( tempDriveName );
hgs
parents:
diff changeset
   216
    QString volumeName = driverInfo.volumeName();
hgs
parents:
diff changeset
   217
    
hgs
parents:
diff changeset
   218
    if( volumeName.isEmpty() && isFillWithDefaultVolume ){
hgs
parents:
diff changeset
   219
        switch ( driverInfo.driveType() )
hgs
parents:
diff changeset
   220
            {
hgs
parents:
diff changeset
   221
            case FmDriverInfo::EDriveTypeMassStorage:
hgs
parents:
diff changeset
   222
                ret = hbTrId( "txt_fmgr_dblist_1_mass_storage" ).arg( checkedDriveName );
hgs
parents:
diff changeset
   223
                break;
hgs
parents:
diff changeset
   224
            case FmDriverInfo::EDriveTypeUsbMemory:
hgs
parents:
diff changeset
   225
                ret = hbTrId( "txt_fmgr_dblist_1_usb_memory" ).arg( checkedDriveName );
hgs
parents:
diff changeset
   226
                break;
hgs
parents:
diff changeset
   227
            case FmDriverInfo::EDriveTypeMemoryCard:
hgs
parents:
diff changeset
   228
                ret = hbTrId( "txt_fmgr_dblist_1_memory_card" ).arg( checkedDriveName );
hgs
parents:
diff changeset
   229
                break;
hgs
parents:
diff changeset
   230
            case FmDriverInfo::EDriveTypePhoneMemory:
hgs
parents:
diff changeset
   231
                ret = hbTrId( "txt_fmgr_dblist_1_device_memory" ).arg( checkedDriveName );
hgs
parents:
diff changeset
   232
                break;
hgs
parents:
diff changeset
   233
            case FmDriverInfo::EDriveTypeNotExist:// no such drive
hgs
parents:
diff changeset
   234
            default:// do not need get volume for other drive types, e.g. Ram, Rom
hgs
parents:
diff changeset
   235
                break;
hgs
parents:
diff changeset
   236
            }    
hgs
parents:
diff changeset
   237
    }
hgs
parents:
diff changeset
   238
    
hgs
parents:
diff changeset
   239
    if( ret.isEmpty() ) {
hgs
parents:
diff changeset
   240
        // ret is not got. fill ret as default method
hgs
parents:
diff changeset
   241
        // txt_fmgr_dblist_1_2 is not correct, can not use.
hgs
parents:
diff changeset
   242
        ret = hbTrId( "%1 %2" ).arg( checkedDriveName ).arg( volumeName );
hgs
parents:
diff changeset
   243
    }
hgs
parents:
diff changeset
   244
    return ret;
hgs
parents:
diff changeset
   245
}
hgs
parents:
diff changeset
   246
hgs
parents:
diff changeset
   247
/*!
hgs
parents:
diff changeset
   248
    return the default volume for drive
hgs
parents:
diff changeset
   249
    \a driveName the drive.
hgs
parents:
diff changeset
   250
    \sa getVolumeNameWithDefaultNameIfNull
hgs
parents:
diff changeset
   251
*/
hgs
parents:
diff changeset
   252
QString FmUtils::getDefaultVolumeName( const QString &driveName )
hgs
parents:
diff changeset
   253
{
hgs
parents:
diff changeset
   254
    QString defaultVolumeName;
hgs
parents:
diff changeset
   255
    FmDriverInfo driverInfo = FmUtils::queryDriverInfo( driveName );
hgs
parents:
diff changeset
   256
          
hgs
parents:
diff changeset
   257
    switch ( driverInfo.driveType() )
hgs
parents:
diff changeset
   258
        {
hgs
parents:
diff changeset
   259
        case FmDriverInfo::EDriveTypeMassStorage:
hgs
parents:
diff changeset
   260
            defaultVolumeName = hbTrId("Mass storage"); 
hgs
parents:
diff changeset
   261
            break;
hgs
parents:
diff changeset
   262
        case FmDriverInfo::EDriveTypeUsbMemory:
hgs
parents:
diff changeset
   263
            defaultVolumeName = hbTrId("USB memory"); 
hgs
parents:
diff changeset
   264
            break;
hgs
parents:
diff changeset
   265
        case FmDriverInfo::EDriveTypeMemoryCard:
hgs
parents:
diff changeset
   266
            defaultVolumeName = hbTrId("Memory card");
hgs
parents:
diff changeset
   267
            break;
hgs
parents:
diff changeset
   268
        case FmDriverInfo::EDriveTypePhoneMemory:
hgs
parents:
diff changeset
   269
            defaultVolumeName = hbTrId("Device memory");
hgs
parents:
diff changeset
   270
            break;
hgs
parents:
diff changeset
   271
        case FmDriverInfo::EDriveTypeNotExist:// no such drive, break and return empty string
hgs
parents:
diff changeset
   272
        default:// do not have default volume for other drive types, e.g. Ram, Rom
hgs
parents:
diff changeset
   273
            break;
hgs
parents:
diff changeset
   274
        }   
hgs
parents:
diff changeset
   275
    return defaultVolumeName;
hgs
parents:
diff changeset
   276
}
hgs
parents:
diff changeset
   277
hgs
parents:
diff changeset
   278
/*!
hgs
parents:
diff changeset
   279
    get the volume name of the drive, if it is null, then return the default name.
hgs
parents:
diff changeset
   280
    \a driveName the drive letter.
hgs
parents:
diff changeset
   281
    \a defaultName whether it is the default name.
hgs
parents:
diff changeset
   282
    return the volume name.
hgs
parents:
diff changeset
   283
*/
hgs
parents:
diff changeset
   284
QString FmUtils::getVolumeNameWithDefaultNameIfNull( const QString &driveName, bool &defaultName )
hgs
parents:
diff changeset
   285
{
hgs
parents:
diff changeset
   286
    // do not re-use FmUtils::getDefaultVolumeName to save one time for call FmUtils::queryDriverInfo
hgs
parents:
diff changeset
   287
    FmDriverInfo driverInfo = FmUtils::queryDriverInfo( driveName );
hgs
parents:
diff changeset
   288
          
hgs
parents:
diff changeset
   289
    QString volumeName = driverInfo.volumeName();    
hgs
parents:
diff changeset
   290
    //save the volume status, whether it is default name
hgs
parents:
diff changeset
   291
    defaultName = false;
hgs
parents:
diff changeset
   292
    //volume name may be null if not set, it will be set at least for one time in the following while cycling.
hgs
parents:
diff changeset
   293
    if ( volumeName.isEmpty() ) {
hgs
parents:
diff changeset
   294
        switch ( driverInfo.driveType() )
hgs
parents:
diff changeset
   295
            {
hgs
parents:
diff changeset
   296
            case FmDriverInfo::EDriveTypeMassStorage:
hgs
parents:
diff changeset
   297
                volumeName = hbTrId("Mass storage"); 
hgs
parents:
diff changeset
   298
                break;
hgs
parents:
diff changeset
   299
            case FmDriverInfo::EDriveTypeUsbMemory:
hgs
parents:
diff changeset
   300
                volumeName = hbTrId("USB memory"); 
hgs
parents:
diff changeset
   301
                break;
hgs
parents:
diff changeset
   302
            case FmDriverInfo::EDriveTypeMemoryCard:
hgs
parents:
diff changeset
   303
                volumeName = hbTrId("Memory card");
hgs
parents:
diff changeset
   304
                break;
hgs
parents:
diff changeset
   305
            case FmDriverInfo::EDriveTypePhoneMemory:
hgs
parents:
diff changeset
   306
                volumeName = hbTrId("Device memory");
hgs
parents:
diff changeset
   307
                break;
hgs
parents:
diff changeset
   308
            case FmDriverInfo::EDriveTypeNotExist:// no such drive
hgs
parents:
diff changeset
   309
            default:// do not need get volume for other drive types, e.g. Ram, Rom
hgs
parents:
diff changeset
   310
                break;
hgs
parents:
diff changeset
   311
            }   
hgs
parents:
diff changeset
   312
        if( !volumeName.isEmpty() ) {
hgs
parents:
diff changeset
   313
             defaultName = true;
hgs
parents:
diff changeset
   314
        }
hgs
parents:
diff changeset
   315
    }
hgs
parents:
diff changeset
   316
    return volumeName;
hgs
parents:
diff changeset
   317
}
hgs
parents:
diff changeset
   318
hgs
parents:
diff changeset
   319
/*!
hgs
parents:
diff changeset
   320
    Check if two path are the same.
hgs
parents:
diff changeset
   321
*/
hgs
parents:
diff changeset
   322
bool FmUtils::isPathEqual( const QString &pathFst, const QString &pathLast )
hgs
parents:
diff changeset
   323
{
hgs
parents:
diff changeset
   324
    QString fst( fillPathWithSplash( pathFst ) );
hgs
parents:
diff changeset
   325
    QString last( fillPathWithSplash( pathLast ) );
hgs
parents:
diff changeset
   326
    if( fst.compare( last, Qt::CaseInsensitive ) == 0 ) {
hgs
parents:
diff changeset
   327
        return true;
hgs
parents:
diff changeset
   328
    }
hgs
parents:
diff changeset
   329
    return false;
hgs
parents:
diff changeset
   330
}
hgs
parents:
diff changeset
   331
hgs
parents:
diff changeset
   332
/*!
hgs
parents:
diff changeset
   333
    Check if a name is illegal for folder/file naming rule.
hgs
parents:
diff changeset
   334
*/
hgs
parents:
diff changeset
   335
bool FmUtils::checkFolderFileName( const QString& name )
hgs
parents:
diff changeset
   336
{
hgs
parents:
diff changeset
   337
    // trim space firest, because there may be some spaces after "." ,  it is also not valid
hgs
parents:
diff changeset
   338
    QString trimmedName( name.trimmed() );
hgs
parents:
diff changeset
   339
	if( trimmedName.isEmpty() ) {
hgs
parents:
diff changeset
   340
		return false;
hgs
parents:
diff changeset
   341
	}
hgs
parents:
diff changeset
   342
    if( trimmedName.endsWith( QChar('.'),  Qt::CaseInsensitive ) ) {
hgs
parents:
diff changeset
   343
        return false;
hgs
parents:
diff changeset
   344
    }
hgs
parents:
diff changeset
   345
    if( trimmedName.contains( QChar('\\'), Qt::CaseInsensitive ) ||
hgs
parents:
diff changeset
   346
        trimmedName.contains( QChar('/'),  Qt::CaseInsensitive ) ||
hgs
parents:
diff changeset
   347
        trimmedName.contains( QChar(':'),  Qt::CaseInsensitive ) ||
hgs
parents:
diff changeset
   348
        trimmedName.contains( QChar('*'),  Qt::CaseInsensitive ) ||
hgs
parents:
diff changeset
   349
        trimmedName.contains( QChar('?'),  Qt::CaseInsensitive ) ||
hgs
parents:
diff changeset
   350
        trimmedName.contains( QChar('\"'), Qt::CaseInsensitive ) ||
hgs
parents:
diff changeset
   351
        trimmedName.contains( QChar('<'),  Qt::CaseInsensitive ) ||
hgs
parents:
diff changeset
   352
        trimmedName.contains( QChar('>'),  Qt::CaseInsensitive ) ||
hgs
parents:
diff changeset
   353
        trimmedName.contains( QChar('|'),  Qt::CaseInsensitive ) ){
hgs
parents:
diff changeset
   354
        return false;
hgs
parents:
diff changeset
   355
    }
hgs
parents:
diff changeset
   356
    // use original name to exam max size of file name
hgs
parents:
diff changeset
   357
    if( name.length() > getMaxFileNameLength() ) {
hgs
parents:
diff changeset
   358
        return false;
hgs
parents:
diff changeset
   359
    }
hgs
parents:
diff changeset
   360
    return true;
hgs
parents:
diff changeset
   361
}
hgs
parents:
diff changeset
   362
hgs
parents:
diff changeset
   363
/*!
hgs
parents:
diff changeset
   364
    check file or folder path is illegal or not.
hgs
parents:
diff changeset
   365
    \a fileName file/folder name, used to check illegal characters
hgs
parents:
diff changeset
   366
    \a path file/folder path, used to check if path is available to use.
hgs
parents:
diff changeset
   367
    \a errString if return false, errString will be set for error note.
hgs
parents:
diff changeset
   368
    return true for not illegal and false for illegal path.
hgs
parents:
diff changeset
   369
*/
hgs
parents:
diff changeset
   370
bool FmUtils::checkNewFolderOrFile( const QString &fileName, const QString &path, QString &errString )
hgs
parents:
diff changeset
   371
{
hgs
parents:
diff changeset
   372
    // first check if fileName is valid, then check if path length is valid, and check if file/foler is existed at last
hgs
parents:
diff changeset
   373
    QFileInfo fileInfo( path );
hgs
parents:
diff changeset
   374
    bool ret( true );   
hgs
parents:
diff changeset
   375
    if (!FmUtils::checkFolderFileName( fileName ) ) {
hgs
parents:
diff changeset
   376
        errString = hbTrId( "Invalid file or folder name!" );
hgs
parents:
diff changeset
   377
        ret = false;
hgs
parents:
diff changeset
   378
    } else if( !FmUtils::checkMaxPathLength( path ) ) {
hgs
parents:
diff changeset
   379
        errString = hbTrId( "the path you specified is too long!" );
hgs
parents:
diff changeset
   380
        ret = false;
hgs
parents:
diff changeset
   381
    } else if (fileInfo.exists()) {
hgs
parents:
diff changeset
   382
        errString = hbTrId( "%1 already exist!" ).arg( fileInfo.fileName() );
hgs
parents:
diff changeset
   383
        ret = false;
hgs
parents:
diff changeset
   384
    }
hgs
parents:
diff changeset
   385
    return ret;
hgs
parents:
diff changeset
   386
}
hgs
parents:
diff changeset
   387
hgs
parents:
diff changeset
   388
/*!
hgs
parents:
diff changeset
   389
    Check if \a dest is sub level path of \a src
hgs
parents:
diff changeset
   390
    Used to check True/False when copy a folder to itself or its subfolder
hgs
parents:
diff changeset
   391
    For example, c:\data\test is sub path of c:\data.
hgs
parents:
diff changeset
   392
    But c:\data123\test is not sub path of c:\data.
hgs
parents:
diff changeset
   393
    So after got right part of path, the first char must be \ or /
hgs
parents:
diff changeset
   394
*/
hgs
parents:
diff changeset
   395
bool FmUtils::isSubLevelPath( const QString &src, const QString &dest )
hgs
parents:
diff changeset
   396
{
hgs
parents:
diff changeset
   397
    FM_LOG("FmUtils::isSubFolder: src=" + src + " dest=" + dest);
hgs
parents:
diff changeset
   398
    QString checkedSrc( FmUtils::fillPathWithSplash( src ) );
hgs
parents:
diff changeset
   399
    QString checkedDest( FmUtils::fillPathWithSplash( dest ) );
hgs
parents:
diff changeset
   400
    
hgs
parents:
diff changeset
   401
    if( checkedDest.contains( checkedSrc, Qt::CaseInsensitive) &&
hgs
parents:
diff changeset
   402
            checkedDest.length() > checkedSrc.length() ) {
hgs
parents:
diff changeset
   403
        // for example c:\data\ vs c:\data\123\ 
hgs
parents:
diff changeset
   404
        FM_LOG("FmUtils::isSubFolder: true");
hgs
parents:
diff changeset
   405
        return true;
hgs
parents:
diff changeset
   406
    }
hgs
parents:
diff changeset
   407
    // for example c:\data\ vs c:\data\ 
hgs
parents:
diff changeset
   408
    // for example c:\data\ vs c:\data123\ 
hgs
parents:
diff changeset
   409
hgs
parents:
diff changeset
   410
    FM_LOG("FmUtils::isSubFolder: false");
hgs
parents:
diff changeset
   411
    return false;
hgs
parents:
diff changeset
   412
}