filebrowser/ui/src/enginewrapper.cpp
changeset 17 4f2773374eff
child 19 4b22a598b890
child 24 6053b7ae82ab
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/filebrowser/ui/src/enginewrapper.cpp	Fri May 14 15:53:02 2010 +0300
@@ -0,0 +1,729 @@
+/*
+* Copyright (c) 2010 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:
+*
+*/
+
+#include "enginewrapper.h"
+#include "engine.h"
+#include "FBFileUtils.h"
+#include "notifications.h"
+#include "filebrowserview.h"
+#include "searchview.h"
+#include "filebrowsersettings.h"
+#include "settingsview.h"
+
+#include <QString>
+#include <QFileInfo>
+#include <QModelIndex>
+
+// ---------------------------------------------------------------------------
+
+EngineWrapper::EngineWrapper()
+    : mEngine(0),
+    mFilesFound(),
+    mSettings(0)
+{
+}
+
+// ---------------------------------------------------------------------------
+
+EngineWrapper::~EngineWrapper()
+{
+    if(mEngine != NULL) {
+        TRAP_IGNORE(mEngine->DeActivateEngineL());
+        delete mEngine;
+    } 
+}
+
+// ---------------------------------------------------------------------------
+
+bool EngineWrapper::init()
+{
+    TRAPD(err, mEngine = CEngine::NewL(this));
+    if (err != KErrNone) {
+        return false;
+    } else {
+        TRAP_IGNORE(mEngine->ActivateEngineL());
+        mSettings = FileBrowserSettings(&mEngine->Settings());
+        return true;
+    }
+}
+
+// ---------------------------------------------------------------------------
+// Functions that are called from UI
+// ---------------------------------------------------------------------------
+bool EngineWrapper::searchFiles()
+{
+    TRAPD(err, mEngine->SearchL() );
+    if(err != KErrNone) {
+        return false;
+    }
+    else {
+        return true;
+    }
+}
+
+// ---------------------------------------------------------------------------
+SearchAttributes EngineWrapper::getFileSearchAttributes()
+{
+    TSearchAttributes tAttributes = mEngine->GetSearchAttributes();
+    SearchAttributes attributes;
+
+    // Convert TSearchAttributes to SearchAttributes 
+    attributes.mSearchDir  = QString((QChar*)tAttributes.iSearchDir.Ptr(),tAttributes.iSearchDir.Length());
+    attributes.mWildCards  = QString((QChar*)tAttributes.iWildCards.Ptr(),tAttributes.iWildCards.Length()); 
+    attributes.mTextInFile = QString((QChar*)tAttributes.iTextInFile.Ptr(),tAttributes.iTextInFile.Length()); 
+    attributes.mMinSize    = tAttributes.iMinSize;
+    attributes.mMaxSize    = tAttributes.iMaxSize;
+    attributes.mRecurse    = tAttributes.iRecurse;
+    
+    // TTime to QDate
+    TBuf<20> timeString;
+    _LIT(KDateString,"%D%M%Y%/0%1%/1%2%/2%3%/3");
+    TRAP_IGNORE( tAttributes.iMinDate.FormatL(timeString, KDateString) );
+    QString temp = QString::fromUtf16(timeString.Ptr(), timeString.Length());
+    temp.replace(QChar('/'), QChar('-'));
+    attributes.mMinDate = QDate::fromString(temp, "dd-MM-yyyy");
+    
+    
+    TRAP_IGNORE( tAttributes.iMaxDate.FormatL(timeString, KDateString) );
+    temp = QString::fromUtf16(timeString.Ptr(), timeString.Length());
+    temp.replace(QChar('/'), QChar('-'));
+    attributes.mMaxDate = QDate::fromString(temp, "dd-MM-yyyy");
+    
+    return attributes;
+
+}
+
+// ---------------------------------------------------------------------------
+int EngineWrapper::setFileSearchAttributes(SearchAttributes attributes)
+{
+    TSearchAttributes tAttributes;
+    // Convert SearchAttributes to TSearchAttributes 
+    
+    //convert QString to TFilename:
+    tAttributes.iSearchDir = TFileName(attributes.mSearchDir.utf16());
+    tAttributes.iWildCards = TFileName(attributes.mWildCards.utf16());
+    tAttributes.iTextInFile = TFileName(attributes.mTextInFile.utf16());
+    
+    tAttributes.iMinSize    = attributes.mMinSize;
+    tAttributes.iMaxSize    = attributes.mMaxSize;    
+    tAttributes.iRecurse    = attributes.mRecurse;
+    
+    // QDate to TTime for both min- and max Date
+    QString temp = attributes.mMinDate.toString("yyyy-MM-dd");
+    QStringList dateList = temp.split("-");
+    int month = dateList[1].toInt() - 1;
+    int day = dateList[2].toInt() - 1;
+    temp = dateList[0];
+    if (month == 0) {
+        temp.append("00");
+    }
+    else {
+        temp.append(QString::number(month));
+    }
+    if (day == 0) {
+        temp.append("00");
+    }
+    else { 
+        temp.append(QString::number(day));
+    }
+    temp.append(":");
+        
+    TBuf<24> dateString(temp.utf16());
+    tAttributes.iMinDate.Set(dateString);
+    
+    temp = attributes.mMaxDate.toString("yyyy-MM-dd");
+    dateList = temp.split("-");
+    month = dateList[1].toInt() - 1;
+    day = dateList[2].toInt() - 1;
+    temp = dateList[0];
+    if (month == 0) {
+        temp.append("00");
+    }
+    else {
+        temp.append(QString::number(month));
+    }
+    if (day == 0) {
+        temp.append("00");
+    }
+    else { 
+        temp.append(QString::number(day));
+    }
+    temp.append(":");
+    dateString.Copy(temp.utf16());
+    tAttributes.iMaxDate.Set(dateString);
+    
+    mEngine->ChangeAttributes(tAttributes);
+    return KErrNone;
+}
+
+
+// ---------------------------------------------------------------------------
+SearchResults EngineWrapper::getSearchResults()
+{
+    TSearchResults tResults = mEngine->SearchResults();
+    SearchResults results;
+    results.mNumberOfFoundFiles = tResults.iNumberOfFoundFiles;
+    CFileEntryList* foundFilesResult = mEngine->FoundFiles();
+    if (!mFilesFound.isEmpty()) {
+        mFilesFound.clear();
+        }
+    // copy file names and convert them from TFileName format to QStringList items type
+    for (int i = 0; i < foundFilesResult->Count(); i++) {
+            mFilesFound.append(
+                    QString((QChar*)foundFilesResult->At(i).iFullName.Ptr(), 
+                    foundFilesResult->At(i).iFullName.Length()) 
+                    );
+        }
+    results.mFoundFilesList = &mFilesFound;
+    return results;
+}
+
+// ---------------------------------------------------------------------------
+
+void EngineWrapper::saveSettings(bool aNotifyModules)
+{
+    return mEngine->SaveSettingsL(aNotifyModules);;
+}
+
+// ---------------------------------------------------------------------------
+
+bool EngineWrapper::isDriveListViewActive()
+{
+    // TODO check return value
+    if (mEngine->FileUtils() && mEngine->FileUtils()->IsDriveListViewActive()) {
+        return true;
+    } else {
+        return false;
+    }
+}
+
+bool EngineWrapper::isCurrentDriveReadOnly()
+{
+    // TODO check return value
+    if (mEngine->FileUtils() && mEngine->FileUtils()->IsCurrentDriveReadOnly()) {
+        return true;
+    } else {
+        return false;
+    }
+}
+
+bool EngineWrapper::isClipBoardListInUse()
+{
+    if (mEngine->FileUtils() && mEngine->FileUtils()->ClipBoardList() && mEngine->FileUtils()->ClipBoardList()->Count() != 0)
+        return true;
+    else
+        return false;
+}
+
+// ---------------------------------------------------------------------------
+void EngineWrapper::startExecutingCommands(const QString &aCommandsExecutionMessage)
+{
+    TPtrC commandsExecutionMessage(reinterpret_cast<const TText*>(aCommandsExecutionMessage.constData()));
+    TRAPD(err, mEngine->FileUtils()->StartExecutingCommandsL(commandsExecutionMessage) );
+    Q_UNUSED(err); //TODO
+}
+
+// ---------------------------------------------------------------------------
+
+void EngineWrapper::refreshView()
+{
+    if (mEngine->FileUtils()) {
+        TRAPD(err, mEngine->FileUtils()->RefreshViewL() );
+        Q_UNUSED(err); //TODO
+    }
+}
+
+void EngineWrapper::moveUpOneLevel()
+{
+    if (mEngine->FileUtils()) {
+        TRAPD(err, mEngine->FileUtils()->MoveUpOneLevelL() );
+        Q_UNUSED(err); //TODO
+    }
+}
+
+// ---------------------------------------------------------------------------
+
+void EngineWrapper::moveDownToDirectory(const QModelIndex& aIndex)
+{
+    if (mEngine->FileUtils()) {
+        TRAPD(err, mEngine->FileUtils()->MoveDownToDirectoryL(aIndex.row()) );
+        Q_UNUSED(err); //TODO
+    }
+}
+
+// ---------------------------------------------------------------------------
+
+int EngineWrapper::clipboardCut(const QModelIndexList& aSelectionIndices)
+{
+    TInt operations = 0;
+    const CArrayFix<TInt> *selectionIndexes = convertSelectionList(aSelectionIndices);
+    if (mEngine->FileUtils()) {
+        TRAPD(err, operations = mEngine->FileUtils()->ClipboardCutL(selectionIndexes) );
+        Q_UNUSED(err); //TODO
+    }
+    delete selectionIndexes;
+    return operations;
+}
+
+// ---------------------------------------------------------------------------
+int EngineWrapper::clipboardCopy(const QModelIndexList& aSelectionIndices)
+{
+    TInt operations = 0;
+    const CArrayFix<TInt> *selectionIndexes = convertSelectionList(aSelectionIndices);
+
+    if (mEngine->FileUtils()) {
+        TRAPD(err, operations = mEngine->FileUtils()->ClipboardCopyL(selectionIndexes));
+        Q_UNUSED(err); //TODO
+    }
+    delete selectionIndexes;
+    return operations;
+}
+
+// ---------------------------------------------------------------------------
+
+void EngineWrapper::clipboardPaste(const OverwriteOptions &aOverwriteOptions)
+{
+    TOverwriteOptions tOverwriteOptions = convertOverwriteOptions(aOverwriteOptions);
+    if (mEngine->FileUtils()) {
+        TRAPD(err, mEngine->FileUtils()->ClipboardPasteL(tOverwriteOptions));
+        Q_UNUSED(err); //TODO
+    }
+}
+
+// ---------------------------------------------------------------------------
+
+void EngineWrapper::copyToFolder(const QString &aTargetDir, const OverwriteOptions &aOverwriteOptions, bool aMove)
+{
+    TFileName targetDir = TFileName(aTargetDir.utf16());
+    TOverwriteOptions tOverwriteOptions = convertOverwriteOptions(aOverwriteOptions);
+
+
+    TRAPD(err, mEngine->FileUtils()->CopyToFolderL(targetDir, tOverwriteOptions, aMove ? ETrue : EFalse) );
+    Q_UNUSED(err); //TODO
+}
+
+// ---------------------------------------------------------------------------
+
+void EngineWrapper::createNewFile(const QString &aNewFileName)
+{
+    TFileName fileName = TFileName(aNewFileName.utf16());
+    TRAPD(err, mEngine->FileUtils()->NewFileL(fileName) );
+    Q_UNUSED(err); //TODO
+}
+
+// ---------------------------------------------------------------------------
+
+void EngineWrapper::createNewDirectory(const QString &aNewDirectoryName)
+{
+    TFileName newDirectoryName = TFileName(aNewDirectoryName.utf16());
+    TRAPD(err, mEngine->FileUtils()->NewDirectoryL(newDirectoryName) );
+    Q_UNUSED(err); //TODO
+}
+
+// ---------------------------------------------------------------------------
+
+void EngineWrapper::deleteItems(const QModelIndexList& aSelectionIndices)
+{
+    setCurrentSelection(aSelectionIndices);
+    TRAPD(err, mEngine->FileUtils()->DeleteL() );
+    Q_UNUSED(err); //TODO
+}
+
+// ---------------------------------------------------------------------------
+bool EngineWrapper::selectionHasDirs()
+{
+    return mEngine->FileUtils()->SelectionHasDirs();
+}
+
+// ---------------------------------------------------------------------------
+
+void EngineWrapper::rename(const QModelIndex& aIndex, const QString aNewName)
+{
+    if (mEngine->FileUtils()) {
+        const TFileName newName = TFileName(aNewName.utf16());
+        TRAPD(err, mEngine->FileUtils()->RenameL(aIndex.row(), newName) );
+        Q_UNUSED(err); //TODO
+    }
+}
+
+// ---------------------------------------------------------------------------
+
+void EngineWrapper::touch(bool aRecurse)
+{
+    if (mEngine->FileUtils()) {
+        TRAPD(err, mEngine->FileUtils()->TouchL(aRecurse) );
+        Q_UNUSED(err); //TODO
+    }
+}
+
+// ---------------------------------------------------------------------------
+
+void EngineWrapper::properties(const QModelIndex &aCurrentItemIndex, QStringList &aPropertyList, QString &aTitleText)
+{
+    if (mEngine->FileUtils()) {
+
+        // create an array for the items
+        CDesCArray* entryLines = new(ELeave) CDesCArrayFlat(16);
+//        CleanupStack::PushL(entryLines);
+        TFileName titleText;
+
+        TRAPD(err, mEngine->FileUtils()->PropertiesL(aCurrentItemIndex.row(), entryLines, titleText));
+        Q_UNUSED(err); //TODO
+
+        aTitleText = QString::fromUtf16(titleText.Ptr(), titleText.Length());
+        QString textItem;
+        for (TInt i = 0; i < entryLines->Count(); ++i) {
+            textItem = QString::fromUtf16((*entryLines)[i].Ptr(), (*entryLines)[i].Length());
+            aPropertyList.append(textItem);
+        }
+//        CleanupStack::PopAndDestroy(); //entryLines
+        delete entryLines;
+    }
+}
+// ---------------------------------------------------------------------------
+
+bool EngineWrapper::openAppArc(QString fileName)
+{
+
+    //convert QString to TFilename:
+    fileName.replace("/", "\\");
+    TFileName fileToOpen = TFileName(fileName.utf16());
+
+    TRAPD(err, mEngine->OpenWithApparcL(fileToOpen) );
+    if(err != KErrNone) {
+        return false;
+    } else {
+        return true;
+    }
+}
+
+// ---------------------------------------------------------------------------
+
+bool EngineWrapper::openDocHandler(QString fileName, bool embeddedVal)
+{
+    //convert QString to TFilename:
+    fileName.replace("/", "\\");
+    TFileName fileToOpen = TFileName(fileName.utf16());
+
+    TRAPD(err, mEngine->OpenWithDocHandlerL(fileToOpen, embeddedVal) );
+    if(err != KErrNone) {
+        return false;
+    } else {
+        return true;
+    }
+}
+
+// ---------------------------------------------------------------------------
+
+int EngineWrapper::itemCount() const
+{
+    if (mEngine->FileUtils()->IsDriveListViewActive()) {
+        return mEngine->FileUtils()->DriveEntries()->Count();
+    } else {
+        return mEngine->FileUtils()->FileEntries()->Count();
+    }
+}
+
+// ---------------------------------------------------------------------------
+
+DriveEntry EngineWrapper::getDriveEntry(const QModelIndex& aIndex) const
+{
+    TDriveEntry driveEntry;
+    if (mEngine->FileUtils()->DriveEntries()->Count() > aIndex.row() && aIndex.row() >= 0) {
+        driveEntry = mEngine->FileUtils()->DriveEntries()->At(aIndex.row());
+    }
+    return DriveEntry(driveEntry);
+}
+
+// ---------------------------------------------------------------------------
+
+FileEntry EngineWrapper::getFileEntry(const QModelIndex& aIndex) const
+{
+    TFileEntry fileEntry;
+    if (mEngine->FileUtils()->FileEntries()->Count() > aIndex.row() && aIndex.row() >= 0) {
+        fileEntry = mEngine->FileUtils()->FileEntries()->At(aIndex.row());
+    }
+    return FileEntry(fileEntry);
+}
+
+// ---------------------------------------------------------------------------
+
+const CArrayFix<TInt> *EngineWrapper::convertSelectionList(const QModelIndexList &aSelectionIndices)
+{
+    CArrayFixFlat<TInt>* selectionIndexes = 0;
+    TRAPD(err, selectionIndexes = new(ELeave)CArrayFixFlat<TInt>(4));
+    if (err != KErrNone) {
+        return 0;
+    }
+
+    for (int i=0; i< aSelectionIndices.count(); ++i) {
+        TRAPD(err, selectionIndexes->AppendL(aSelectionIndices.at(i).row()) );
+        Q_UNUSED(err); //TODO
+    }
+    return selectionIndexes;
+}
+
+
+// ---------------------------------------------------------------------------
+
+void EngineWrapper::setCurrentSelection(const QModelIndexList &aSelectionIndices)
+{
+    const CArrayFix<TInt> *selectionIndexes = convertSelectionList(aSelectionIndices);
+    mEngine->FileUtils()->SetCurrentSelection(selectionIndexes);
+    delete selectionIndexes;
+}
+
+// ---------------------------------------------------------------------------
+
+bool EngineWrapper::isDestinationEntriesExists(const QModelIndexList &aSelectionIndices, QString aTargetDir)
+{
+    TFileName targetDir = TFileName(aTargetDir.utf16());
+    setCurrentSelection(aSelectionIndices);
+
+    TBool someEntryExists = mEngine->FileUtils()->IsDestinationEntriesExists(targetDir);
+    return someEntryExists;
+}
+
+// ---------------------------------------------------------------------------
+bool EngineWrapper::targetExists(const QModelIndex& aIndex, const QString aNewName)
+{
+    const TFileName newName = TFileName(aNewName.utf16());
+    return mEngine->FileUtils()->TargetExists(aIndex.row(), newName);
+}
+
+// ---------------------------------------------------------------------------
+
+QString EngineWrapper::currentPath() const
+{
+    return QString::fromUtf16(mEngine->FileUtils()->CurrentPath().Ptr(),
+                              mEngine->FileUtils()->CurrentPath().Length());
+}
+
+TOverwriteOptions EngineWrapper::convertOverwriteOptions(const OverwriteOptions &aOverwriteOptions)
+{
+    TOverwriteOptions tOverwriteOptions;
+    tOverwriteOptions.iDoFileOperations = aOverwriteOptions.doFileOperations;
+    tOverwriteOptions.iQueryIndex = aOverwriteOptions.queryIndex;
+    tOverwriteOptions.iPostFix = TFileName(aOverwriteOptions.postFix.utf16());
+    tOverwriteOptions.iOverWriteFlags = aOverwriteOptions.overWriteFlags;
+    return tOverwriteOptions;
+}
+
+bool EngineWrapper::hasDrivePassword(const QModelIndex &aIndex)
+{
+    bool hasPassword = false;
+    if (mEngine->FileUtils()->DriveEntries()->Count() > aIndex.row() && aIndex.row() >= 0)
+    {
+        TDriveEntry driveEntry = mEngine->FileUtils()->DriveEntries()->At(aIndex.row());
+        hasPassword = driveEntry.iVolumeInfo.iDrive.iMediaAtt & KMediaAttHasPassword;
+    }
+    return hasPassword;
+}
+
+bool EngineWrapper::isDriveRemovable(const QModelIndex &aIndex)
+{
+    bool isRemovable = false;
+    if (mEngine->FileUtils()->DriveEntries()->Count() > aIndex.row() && aIndex.row() >= 0)
+    {
+        TDriveEntry driveEntry = mEngine->FileUtils()->DriveEntries()->At(aIndex.row());
+        isRemovable = driveEntry.iVolumeInfo.iDrive.iDriveAtt & KDriveAttRemovable;
+    }
+    return isRemovable;
+}
+
+bool EngineWrapper::isDriveLocked(const QModelIndex &aIndex)
+{
+    bool isRemovable = false;
+    if (mEngine->FileUtils()->DriveEntries()->Count() > aIndex.row() && aIndex.row() >= 0)
+    {
+        TDriveEntry driveEntry = mEngine->FileUtils()->DriveEntries()->At(aIndex.row());
+        isRemovable = driveEntry.iVolumeInfo.iDrive.iMediaAtt & KMediaAttLocked;
+    }
+    return isRemovable;
+}
+
+void EngineWrapper::GetDriveName(const QModelIndex &aIndex, QString &aDriveName)
+{
+    TFileName driveName;
+    mEngine->FileUtils()->GetDriveName(aIndex.row(), driveName);
+    aDriveName = QString::fromUtf16(driveName.Ptr(), driveName.Length());
+}
+
+
+void EngineWrapper::GetDriveVolumeLabel(const QModelIndex &aIndex, QString &aVolumeLabel)
+{
+    TFileName volumeLabel;
+    mEngine->FileUtils()->GetDriveName(aIndex.row(), volumeLabel);
+    aVolumeLabel = QString::fromUtf16(volumeLabel.Ptr(), volumeLabel.Length());
+}
+
+void EngineWrapper::DiskAdminSetDrivePassword(const QModelIndex &aIndex,
+                                              const QString &aOldPassword,
+                                              const QString &aNewPassword)
+{
+    TFileName oldPassword = TFileName(aOldPassword.utf16());
+    TFileName newPassword = TFileName(aNewPassword.utf16());
+    TRAP_IGNORE(mEngine->FileUtils()->SetDrivePasswordL(aIndex.row(), oldPassword, newPassword));
+}
+
+void EngineWrapper::DiskAdminUnlockDrive(const QModelIndex &aIndex, const QString &aOldPassword)
+{
+    TFileName oldPassword = TFileName(aOldPassword.utf16());
+    TRAP_IGNORE(mEngine->FileUtils()->UnlockDriveL(aIndex.row(), oldPassword));
+}
+
+void EngineWrapper::DiskAdminClearDrivePassword(const QModelIndex &aIndex, const QString &aOldPassword)
+{
+    TFileName oldPassword = TFileName(aOldPassword.utf16());
+    TRAP_IGNORE(mEngine->FileUtils()->ClearDrivePasswordL(aIndex.row(), oldPassword));
+}
+
+void EngineWrapper::DiskAdminEraseDrivePassword(const QModelIndex &aIndex)
+{
+    TRAP_IGNORE(mEngine->FileUtils()->EraseDrivePasswordL(aIndex.row()));
+}
+
+void EngineWrapper::DiskAdminFormatDrive(const QModelIndex &aIndex, bool aQuickFormat)
+{
+    TRAP_IGNORE(mEngine->FileUtils()->FormatDriveL(aIndex.row(), aQuickFormat));
+}
+
+void EngineWrapper::DiskAdminQuickFormatDrive(const QModelIndex &aIndex, bool aQuickFormat)
+{
+    TRAP_IGNORE(mEngine->FileUtils()->FormatDriveL(aIndex.row(), aQuickFormat));
+}
+
+void EngineWrapper::DiskAdminCheckDisk(const QModelIndex &aIndex)
+{
+    TRAP_IGNORE(mEngine->FileUtils()->CheckDiskL(aIndex.row()));
+}
+
+void EngineWrapper::DiskAdminScanDrive(const QModelIndex &aIndex)
+{
+    TRAP_IGNORE(mEngine->FileUtils()->ScanDriveL(aIndex.row()));
+}
+
+void EngineWrapper::DiskAdminSetDriveName(const QModelIndex &aIndex, const QString &aDriveName)
+{
+    TFileName driveName = TFileName(aDriveName.utf16());
+    TRAP_IGNORE(mEngine->FileUtils()->SetDriveNameL(aIndex.row(), driveName));
+}
+
+void EngineWrapper::DiskAdminSetDriveVolumeLabel(const QModelIndex &aIndex, const QString &aVolumeLabel)
+{
+    TFileName volumeLabel = TFileName(aVolumeLabel.utf16());
+    TRAP_IGNORE(mEngine->FileUtils()->SetDriveNameL(aIndex.row(), volumeLabel));
+}
+
+void EngineWrapper::DiskAdminEjectDrive(const QModelIndex &aIndex)
+{
+    TRAP_IGNORE(mEngine->FileUtils()->EjectDriveL(aIndex.row()));
+}
+
+void EngineWrapper::DiskAdminDismountDrive(const QModelIndex &aIndex)
+{
+    TRAP_IGNORE(mEngine->FileUtils()->DismountFileSystemL(aIndex.row()));
+}
+
+void EngineWrapper::DiskAdminEraseMBR(const QModelIndex &aIndex)
+{
+    TRAP_IGNORE(mEngine->FileUtils()->EraseMBRL(aIndex.row()));
+}
+
+void EngineWrapper::DiskAdminPartitionDrive(const QModelIndex &aIndex, bool aEraseMBR, int aAmountOfPartitions)
+{
+    TRAP_IGNORE(mEngine->FileUtils()->PartitionDriveL(aIndex.row(), aEraseMBR, aAmountOfPartitions));
+}
+
+void EngineWrapper::ToolsSetErrRd(bool aEnable)
+{
+    TRAP_IGNORE(mEngine->FileUtils()->SetErrRdL(aEnable));
+}
+
+bool EngineWrapper::ErrRdFileExists()
+{
+    return mEngine->FileUtils()->FileExists(KErrRdPath);
+}
+
+void EngineWrapper::ToolsErrorSimulateLeave(int aLeaveCode)
+{
+    mEngine->FileUtils()->SimulateLeaveL(aLeaveCode);
+}
+
+void EngineWrapper::ToolsErrorSimulatePanic(QString aPanicCategory, int aPanicCode)
+{
+    TBuf<128> panicCategory;
+    panicCategory.Copy(aPanicCategory.utf16());
+    mEngine->FileUtils()->SimulatePanicL(panicCategory, aPanicCode);
+}
+
+void EngineWrapper::ToolsErrorSimulateException(int aExceptionCode)
+{
+    mEngine->FileUtils()->SimulateExceptionL(aExceptionCode);
+}
+
+quint32 EngineWrapper::getDebugMask()
+{
+    return mEngine->FileUtils()->GetDebugMask();
+}
+
+void EngineWrapper::toolsSetDebugMask(quint32 aDbgMask)
+{
+    mEngine->FileUtils()->SetDebugMaskL(aDbgMask);
+}
+
+void EngineWrapper::showFileCheckSums(const QModelIndex &aIndex, TFileBrowserCmdFileChecksums checksumType)
+{
+    mEngine->FileUtils()->ShowFileCheckSumsL(aIndex.row(), checksumType);
+}
+
+// ---------------------------------------------------------------------------
+// Functions that are called from engine
+// ---------------------------------------------------------------------------
+
+// ---------------------------------------------------------------------------
+
+void EngineWrapper::ShowErrorNote(const TDesC& aDescText, TBool aNoTimeout /*= EFalse*/)
+{
+    QString qStringText = QString::fromUtf16(aDescText.Ptr(), aDescText.Length());
+    Notifications::showErrorNote(qStringText, aNoTimeout);
+}
+
+// ---------------------------------------------------------------------------
+
+void EngineWrapper::ShowInformationNote(const TDesC &aDescText, const TDesC &aDescTitle)
+{
+    QString qText = QString::fromUtf16(aDescText.Ptr(), aDescText.Length());
+    QString qTitle = QString::fromUtf16(aDescTitle.Ptr(), aDescTitle.Length());
+    Notifications::showInformationNote(qText, qTitle);
+}
+
+// ---------------------------------------------------------------------------
+
+void EngineWrapper::ShowConfirmationNote(const TDesC& aDescText, TBool aNoTimeout /*= EFalse*/)
+{
+    QString qStringText = QString::fromUtf16(aDescText.Ptr(), aDescText.Length());
+    Notifications::showConfirmationNote(qStringText, aNoTimeout);
+}
+
+TBool EngineWrapper::ShowConfirmationQuery(const TDesC& aDescText)
+{
+    QString qStringText = QString::fromUtf16(aDescText.Ptr(), aDescText.Length());
+    return Notifications::showConfirmationQuery(qStringText);
+}
+
+// ---------------------------------------------------------------------------