filemanager/src/inc/fmserviceutils/private/symbian/fmserviceutilsprivate.cpp
changeset 47 12b82dc0e8db
child 49 81668a704644
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/filemanager/src/inc/fmserviceutils/private/symbian/fmserviceutilsprivate.cpp	Thu Sep 30 16:33:59 2010 +0800
@@ -0,0 +1,134 @@
+/*
+* Copyright (c) 2009 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:
+*     The source file of service utils private
+*/
+
+#include "fmserviceutilsprivate.h"
+#include "fmserviceutilshandler.h"
+#include "fmcommon.h"
+#include <shareui.h>
+#include <afactivitystorage.h>
+
+FmServiceUtilsPrivate::FmServiceUtilsPrivate()
+    :mShareUi( 0 ), mServiceUtilsHandler( 0 ), mActivityStorage( 0 )
+{
+    
+}
+
+FmServiceUtilsPrivate::~FmServiceUtilsPrivate()
+{
+    if( mShareUi ) {
+        delete mShareUi;
+        mShareUi = 0;
+    }
+    
+    if( mServiceUtilsHandler ) {
+        delete mServiceUtilsHandler;
+        mServiceUtilsHandler = 0;
+    }
+    
+    if( mActivityStorage ) {
+        delete mActivityStorage;
+        mActivityStorage = 0;
+    }
+}
+
+/*
+   return \a shareUi which is used to send files. 
+*/
+ShareUi *FmServiceUtilsPrivate::shareUi()
+{
+    if( !mShareUi ) {
+        mShareUi = new ShareUi;
+    }
+    return mShareUi;
+}
+
+/*
+   return \a AfActivityStorage which is used to save activity. 
+*/
+AfActivityStorage *FmServiceUtilsPrivate::activityStorage()
+{
+    if( !mActivityStorage ) {
+        mActivityStorage = new AfActivityStorage;
+    }
+    return mActivityStorage;
+}
+
+/*
+   return \a CFmServiceUtilsHandler which is used to closeApps and restartApps
+*/
+CFmServiceUtilsHandler *FmServiceUtilsPrivate::serviceUtilsHandler()
+{
+    if( !mServiceUtilsHandler ) {
+        TRAPD(err, mServiceUtilsHandler = CFmServiceUtilsHandler::NewL());
+        if( err != KErrNone ) {
+            mServiceUtilsHandler = 0;
+        }
+    }
+    return mServiceUtilsHandler;
+}
+
+/*!
+    send files that included in \a filePathList via ShareUi
+*/
+void FmServiceUtilsPrivate::sendFile( const QStringList &filePathList )
+{
+    // send do not accept const QStringList, so use QStringList()<<filePathList
+    shareUi()->send( QStringList()<<filePathList, true );
+}
+
+/*!
+    call CBaBackupSessionWrapper to close apps, for example, before formant, apps need be closed
+    this is synchronous which will take a while, please call this function in thread
+*/
+void FmServiceUtilsPrivate::closeApps()
+{
+    CFmServiceUtilsHandler *utilsHandler = serviceUtilsHandler();
+    if( utilsHandler ) {
+        TRAP_IGNORE( utilsHandler->CloseAppsL() );
+    }
+}
+
+/*!
+    call CBaBackupSessionWrapper to restart apps
+    for example, after formant, closed apps need be restarted
+    this is synchronous which will return quickly.
+*/
+void FmServiceUtilsPrivate::restartApps()
+{
+    CFmServiceUtilsHandler *utilsHandler = serviceUtilsHandler();
+    if( utilsHandler ) {
+        TRAP_IGNORE( serviceUtilsHandler()->RestartAppsL() );
+    }
+}
+
+/*!
+    call AfActivityStorage to save activity
+*/
+bool FmServiceUtilsPrivate::saveActivity(const QString &activityId, const QVariant &activityData, const QVariantHash &metadata)
+{
+    return activityStorage()->saveActivity( activityId, activityData, metadata);
+}
+
+/*!
+    call AfActivityStorage to remove activity
+*/
+bool FmServiceUtilsPrivate::removeActivity(const QString &activityId)
+{
+    return activityStorage()->removeActivity( activityId );
+}
+