diff -r ada7962b4308 -r b7bfdea70ca2 filemanager/src/inc/fmdrivemodel.cpp --- a/filemanager/src/inc/fmdrivemodel.cpp Mon May 03 12:24:39 2010 +0300 +++ b/filemanager/src/inc/fmdrivemodel.cpp Fri Jun 25 17:08:34 2010 +0800 @@ -22,8 +22,11 @@ #include #include -FmDriveModel::FmDriveModel( QObject *parent, Options options ) : - QAbstractListModel( parent ), mOptions( options ) +#include + +FmDriveModel::FmDriveModel( QObject *parent, Options options, + FmDriveListProvider *driveListProvider ) : + QAbstractListModel( parent ), mOptions( options ), mDriveListProvider( driveListProvider ) { mIconProvider = new FmFileIconProvider(); refresh(); @@ -36,17 +39,27 @@ void FmDriveModel::refresh() { - QFileInfoList infoList = QDir::drives(); - + emit layoutAboutToBeChanged(); mDriveList.clear(); - if( mOptions & HideUnAvailableDrive ) { - FmLogger::log( QString( "FmDriveModel::refresh HideUnAvailableDrive_true" ) ); - FmUtils::getDriveList( mDriveList, true ); + + // if mDriveListProvider existed, use it to fetch drive list + // otherwise use FmUtils::getDriveList to fetch drive list. + if( mDriveListProvider ) { + mDriveListProvider->getDriveList( mDriveList ); } else { - FmLogger::log( QString( "FmDriveModel::refresh HideUnAvailableDrive_false" ) ); - FmUtils::getDriveList( mDriveList, false ); + if( mOptions & HideUnAvailableDrive ) { + FmLogger::log( QString( "FmDriveModel::refresh HideUnAvailableDrive_true" ) ); + FmUtils::getDriveList( mDriveList, true ); + } else { + FmLogger::log( QString( "FmDriveModel::refresh HideUnAvailableDrive_false" ) ); + FmUtils::getDriveList( mDriveList, false ); + } } - emit layoutChanged(); + + emit layoutChanged(); + for( int i=0; i