# HG changeset patch # User hgs # Date 1271418349 -10800 # Node ID 782e3408c2abf835903f28ed750ec27e69f84daf # Parent a6d55a2e75bee3a6571c3a617b46e6ae977f7a08 201015 diff -r a6d55a2e75be -r 782e3408c2ab activityfw/activitydatabase/eabi/hsactivitydbclientu.def --- a/activityfw/activitydatabase/eabi/hsactivitydbclientu.def Fri Mar 26 13:00:55 2010 +0200 +++ b/activityfw/activitydatabase/eabi/hsactivitydbclientu.def Fri Apr 16 14:45:49 2010 +0300 @@ -31,4 +31,5 @@ _ZThn8_N18HsActivityDbClient14updateActivityERK5QHashI7QString8QVariantE @ 30 NONAME _ZThn8_N18HsActivityDbClient21applicationActivitiesER5QListI5QHashI7QString8QVariantEERKS4_ @ 31 NONAME _ZThn8_N18HsActivityDbClient27removeApplicationActivitiesERK5QHashI7QString8QVariantE @ 32 NONAME + _ZN18HsActivityDbClient12getThumbnailER7QPixmapRK7QString @ 33 NONAME diff -r a6d55a2e75be -r 782e3408c2ab activityfw/activitydatabase/hsactivitydbclient/hsactivitydbclient.pro --- a/activityfw/activitydatabase/hsactivitydbclient/hsactivitydbclient.pro Fri Mar 26 13:00:55 2010 +0200 +++ b/activityfw/activitydatabase/hsactivitydbclient/hsactivitydbclient.pro Fri Apr 16 14:45:49 2010 +0300 @@ -20,8 +20,6 @@ QT += core \ sql -QT -= gui - HEADERS += inc/hsactivitydbclient.h SOURCES += src/hsactivitydbclient.cpp @@ -50,5 +48,6 @@ DEPLOYMENT += api TARGET.CAPABILITY = ALL -TCB TARGET.EPOCALLOWDLLDATA = 1 +TARGET.UID3 = 0x200267B3 MMP_RULES += EXPORTUNFROZEN } diff -r a6d55a2e75be -r 782e3408c2ab activityfw/activitydatabase/hsactivitydbclient/inc/hsactivitydbasyncrequestobserver.h --- a/activityfw/activitydatabase/hsactivitydbclient/inc/hsactivitydbasyncrequestobserver.h Fri Mar 26 13:00:55 2010 +0200 +++ b/activityfw/activitydatabase/hsactivitydbclient/inc/hsactivitydbasyncrequestobserver.h Fri Apr 16 14:45:49 2010 +0300 @@ -25,10 +25,10 @@ * Function inform observer about asynchronous request results * @param result - request result * @param requestType - request type - * @param data - respons data + * @param data - respons data */ - virtual void asyncRequestCompleated(int result, - int requestType, - const QString& data)=0; + virtual void asyncRequestCompleated(int result, + int requestType, + const QString &data)=0; }; #endif // HSACTIVITYDBASYNCREQUESTOBSERVER_H diff -r a6d55a2e75be -r 782e3408c2ab activityfw/activitydatabase/hsactivitydbclient/inc/hsactivitydbclient.h --- a/activityfw/activitydatabase/hsactivitydbclient/inc/hsactivitydbclient.h Fri Mar 26 13:00:55 2010 +0200 +++ b/activityfw/activitydatabase/hsactivitydbclient/inc/hsactivitydbclient.h Fri Apr 16 14:45:49 2010 +0300 @@ -36,90 +36,99 @@ public HsActivityDbClientInterface, public HsActivityDbAsyncRequestObserver { -Q_OBJECT + Q_OBJECT public: /** * Constructor */ HsActivityDbClient(QObject* =0); - + /** * Destructor */ ~HsActivityDbClient(); - + /** * Establish connection with activity server * @return 0 on succees, error code otherwise */ int connect(); - + /** * Interface implementation. * @see int HsActivityDbAsyncRequestObserver::asyncRequestCompleated(int, int, const QString&) */ - void asyncRequestCompleated(int, int, const QString&); - + void asyncRequestCompleated(int, int, const QString &); + /** * Interface implementation. * @see int HsActivityDbClientInterface::saveActivity(const QVariantHash&) */ int addActivity(const QVariantHash &); - + /** * Interface implementation. * @see int HsActivityDbClientInterface::updateActivity(const QVariantHash&) */ int updateActivity(const QVariantHash &); - + /** * Interface implementation. * @see int HsActivityDbClientInterface::deleteActivity(const QVariantHash &) */ int removeActivity(const QVariantHash &activity); - + /** * Interface implementation. * @see int HsActivityDbClientInterface::deleteApplicationActivities(const QVariantHash &) */ int removeApplicationActivities(const QVariantHash &activity); - + /** * Interface implementation. * @see int HsActivityDbClientInterface::activities(QList&) */ int activities(QList &); - + /** * Interface implementation. * @see int HsActivityDbClientInterface::applicationActivities(QList &, const QVariantHash &) */ - int applicationActivities(QList &, + int applicationActivities(QList &, const QVariantHash &); - + /** * Interface implementation. * @see int HsActivityDbClientInterface::waitActivity(const QVariantHash &) */ int waitActivity(const QVariantHash &); - + /** * Interface implementation. * @see int HsActivityDbClientInterface::launchActivity(const QVariantHash &) */ int launchActivity(const QVariantHash &); + + /** + * Read thumbnail from file + * @param dst - destination QPixmap instance + * @param src - thumbnail file path + * @return 0 on success, error code otherwise + */ + int getThumbnail(QPixmap &dst, const QString & src); + signals: /** * Function notify about runtime activity change * @param activityId - requested activity name */ - void activityRequested(const QString& activityId); + void activityRequested(const QString &activityId); private: /** * Private client implementation. * Own. */ - HsActivityDbClientPrivate* d_ptr; + HsActivityDbClientPrivate *d_ptr; }; #endif //HSACTIVITYDBCLIENT_H diff -r a6d55a2e75be -r 782e3408c2ab activityfw/activitydatabase/hsactivitydbclient/s60/inc/hsactivitydbasyncrequest_p.h --- a/activityfw/activitydatabase/hsactivitydbclient/s60/inc/hsactivitydbasyncrequest_p.h Fri Mar 26 13:00:55 2010 +0200 +++ b/activityfw/activitydatabase/hsactivitydbclient/s60/inc/hsactivitydbasyncrequest_p.h Fri Apr 16 14:45:49 2010 +0300 @@ -32,32 +32,32 @@ /** * First step constructor */ - static HsActivityDbAsyncRequestPrivate* - NewL(HsActivityDbAsyncRequestObserver &, HsActivityDbClientPrivate &); - + static HsActivityDbAsyncRequestPrivate* + NewL(HsActivityDbAsyncRequestObserver &, HsActivityDbClientPrivate &); + /** * First step constructor */ - static HsActivityDbAsyncRequestPrivate* - NewLC(HsActivityDbAsyncRequestObserver &, HsActivityDbClientPrivate &); - + static HsActivityDbAsyncRequestPrivate* + NewLC(HsActivityDbAsyncRequestObserver &, HsActivityDbClientPrivate &); + /** * Destructor */ ~HsActivityDbAsyncRequestPrivate(); - + /** * Function create subscription to current ativity changes * @param condition - activity filetering rules */ - void waitActivity(const QVariantHash& condition); + void waitActivity(const QVariantHash &condition); protected: /** * Interface implementation. * @see void CActive::DoCancel() */ void DoCancel(); - + /** * Interface implementation. * @see void CActive::DoCancel() @@ -70,8 +70,8 @@ HsActivityDbAsyncRequestPrivate(HsActivityDbAsyncRequestObserver &, HsActivityDbClientPrivate &); private: - HsActivityDbAsyncRequestObserver& mObserver; - HsActivityDbClientPrivate& mSession; + HsActivityDbAsyncRequestObserver &mObserver; + HsActivityDbClientPrivate &mSession; int mRequestType; RBuf8 mDataBuf; TPckgBuf mDataSize; diff -r a6d55a2e75be -r 782e3408c2ab activityfw/activitydatabase/hsactivitydbclient/s60/inc/hsactivitydbclient_p.h --- a/activityfw/activitydatabase/hsactivitydbclient/s60/inc/hsactivitydbclient_p.h Fri Mar 26 13:00:55 2010 +0200 +++ b/activityfw/activitydatabase/hsactivitydbclient/s60/inc/hsactivitydbclient_p.h Fri Apr 16 14:45:49 2010 +0300 @@ -23,7 +23,7 @@ class HsActivityDbAsyncRequestPrivate; /** - * Class implemets HsActivityDbClientInterface and is responsible for + * Class implemets HsActivityDbClientInterface and is responsible for * activity data management on S60 enviroment. */ class HsActivityDbClientPrivate : protected RSessionBase, @@ -33,67 +33,67 @@ /** * Constructor */ - HsActivityDbClientPrivate(HsActivityDbAsyncRequestObserver&); - + HsActivityDbClientPrivate(HsActivityDbAsyncRequestObserver &); + /** * Destructor */ ~HsActivityDbClientPrivate(); - + /** * Function establish connection to activity server * @return 0 on succees, error code otherwise */ int connect(); - + /** * Interface implementation. * @see int HsActivityDbClientInterface::addActivity(const QVariantHash &) */ int addActivity(const QVariantHash &); - + /** * Interface implementation. * @see int HsActivityDbClientInterface::updateActivity(const QVariantHash &) */ int updateActivity(const QVariantHash &); - + /** * Interface implementation. * @see int HsActivityDbClientInterface::removeActivity(const QVariantHash &) */ int removeActivity(const QVariantHash &activity); - + /** * Interface implementation. * @see int HsActivityDbClientInterface::removeApplicationActivities(const QVariantHash &) */ int removeApplicationActivities(const QVariantHash &activity); - + /** * Interface implementation. * @see int HsActivityDbClientInterface::requestedActivityName(QString &, const QVariantHash &); */ int requestedActivityName(QString &, const QVariantHash &); - + /** * Interface implementation. * @see int HsActivityDbClientInterface::activities(QList &); */ int activities(QList &); - + /** * Interface implementation. * @see int HsActivityDbClientInterface::applicationActivities(QList &, const QVariantHash &) */ int applicationActivities(QList&, const QVariantHash &); - + /** * Interface implementation. * @see int HsActivityDbClientInterface::waitActivity(const QVariantHash &) */ int waitActivity(const QVariantHash &activity); - + /** * Interface implementation. * @see int HsActivityDbClientInterface::launchActivity(const QVariantHash &) @@ -106,73 +106,81 @@ */ int cancelWaitActivity(); + /** + * Read thumbnail from file + * @param dst - destination QPixmap instance + * @param src - thumbnail file path + * @return 0 on success, error code otherwise + */ + int getThumbnail(QPixmap &dst, const QString & src); + public: /** * Function get cached data from server * @param dst - destination, preallocated buffer */ - void getData(RBuf8 & dst); - + void getData(RBuf8 &dst); + /** * Function initialize aync request * @param func - requested function * @param data - request data * @param status - request status */ - void sendDataAsync(int func,const TIpcArgs & data, TRequestStatus& status); - + void sendDataAsync(int func,const TIpcArgs &data, TRequestStatus &status); + private: /** * Function start activity server process. * Function can leave on failure. */ void startServerL(); - + /** * Function establish connection to activity server. * Function can leave on failure */ void connectL(); - + /** * Function execute remote call request. * @param function - remote function identyfier - * @param activity - remote function parameters + * @param activity - remote function parameters */ - void execSimpleRequestL( int function, const QVariantHash &activity); - + void execSimpleRequestL(int function, const QVariantHash &activity); + /** * Function retrieve current activity name for application. * Function can leave on failure * @param result - activity name - * @param activity - request filtering rules + * @param activity - request filtering rules */ - void requestedActivityNameL(QString& result, + void requestedActivityNameL(QString &result, const QVariantHash &activity); - - /** - * Function retrieve all stored activity - * Function can leave on failure - * @param result - list of activity - */ - void activitiesL(QList& result); - + /** * Function retrieve all stored activity * Function can leave on failure * @param result - list of activity - * @param cond - request conditions */ - void applicationActivitiesL(QList& result, - const QVariantHash & cond); - + void activitiesL(QList& result); + + /** + * Function retrieve all stored activity + * Function can leave on failure + * @param result - list of activity + * @param cond - request conditions + */ + void applicationActivitiesL(QList& result, + const QVariantHash &cond); + void waitActivityL(const QVariantHash &activity); private: /** * Async request handler * Own */ - HsActivityDbAsyncRequestPrivate* mAsyncDataHandler; + HsActivityDbAsyncRequestPrivate *mAsyncDataHandler; }; #endif // HSACTIVITYDBCLIENTPRIVATE_H diff -r a6d55a2e75be -r 782e3408c2ab activityfw/activitydatabase/hsactivitydbclient/s60/src/hsactivitydbasyncrequest_p.cpp --- a/activityfw/activitydatabase/hsactivitydbclient/s60/src/hsactivitydbasyncrequest_p.cpp Fri Mar 26 13:00:55 2010 +0200 +++ b/activityfw/activitydatabase/hsactivitydbclient/s60/src/hsactivitydbasyncrequest_p.cpp Fri Apr 16 14:45:49 2010 +0300 @@ -22,11 +22,11 @@ // // ----------------------------------------------------------------------------- // -HsActivityDbAsyncRequestPrivate* - HsActivityDbAsyncRequestPrivate::NewL(HsActivityDbAsyncRequestObserver& observer, - HsActivityDbClientPrivate& session) +HsActivityDbAsyncRequestPrivate* +HsActivityDbAsyncRequestPrivate::NewL(HsActivityDbAsyncRequestObserver &observer, + HsActivityDbClientPrivate &session) { - HsActivityDbAsyncRequestPrivate* self = + HsActivityDbAsyncRequestPrivate *self = HsActivityDbAsyncRequestPrivate::NewLC(observer, session); CleanupStack::Pop(self); return self; @@ -35,12 +35,12 @@ // // ----------------------------------------------------------------------------- // -HsActivityDbAsyncRequestPrivate* - HsActivityDbAsyncRequestPrivate::NewLC(HsActivityDbAsyncRequestObserver& observer, - HsActivityDbClientPrivate& session) +HsActivityDbAsyncRequestPrivate* +HsActivityDbAsyncRequestPrivate::NewLC(HsActivityDbAsyncRequestObserver &observer, + HsActivityDbClientPrivate &session) { - HsActivityDbAsyncRequestPrivate* self = - new (ELeave)HsActivityDbAsyncRequestPrivate(observer, session); + HsActivityDbAsyncRequestPrivate *self = + new(ELeave)HsActivityDbAsyncRequestPrivate(observer, session); CleanupStack::PushL(self); self->mDataBuf.CreateL(64); return self; @@ -51,7 +51,7 @@ // HsActivityDbAsyncRequestPrivate::HsActivityDbAsyncRequestPrivate(HsActivityDbAsyncRequestObserver &observer, HsActivityDbClientPrivate &session) -: + : CActive(EPriorityStandard), mObserver(observer), mSession(session), @@ -77,8 +77,8 @@ // void HsActivityDbAsyncRequestPrivate::DoCancel() { - if(IsActive()) { - mSession.cancelWaitActivity(); + if (IsActive()) { + mSession.cancelWaitActivity(); } } @@ -92,12 +92,12 @@ CleanupClosePushL(buff); QString data; int requestResult(iStatus.Int()); - if(KErrNone == requestResult) { - if(0 < mDataSize()) { + if (KErrNone == requestResult) { + if (0 < mDataSize()) { buff.CreateL(mDataSize()); } mSession.getData(buff); - data = QString::fromAscii(reinterpret_cast(buff.Ptr()), + data = QString::fromAscii(reinterpret_cast(buff.Ptr()), buff.Length()); buff.Close(); } @@ -109,7 +109,7 @@ // // ----------------------------------------------------------------------------- // -void HsActivityDbAsyncRequestPrivate::waitActivity(const QVariantHash& condition) +void HsActivityDbAsyncRequestPrivate::waitActivity(const QVariantHash &condition) { mRequestType = WaitActivity; iStatus = KRequestPending; diff -r a6d55a2e75be -r 782e3408c2ab activityfw/activitydatabase/hsactivitydbclient/s60/src/hsactivitydbclient_p.cpp --- a/activityfw/activitydatabase/hsactivitydbclient/s60/src/hsactivitydbclient_p.cpp Fri Mar 26 13:00:55 2010 +0200 +++ b/activityfw/activitydatabase/hsactivitydbclient/s60/src/hsactivitydbclient_p.cpp Fri Apr 16 14:45:49 2010 +0300 @@ -19,12 +19,14 @@ #include "hsactivitydbasyncrequest_p.h" #include "hsactivityglobals.h" #include "hsserializer.h" +#include + // ----------------------------------------------------------------------------- // // ----------------------------------------------------------------------------- // -HsActivityDbClientPrivate::HsActivityDbClientPrivate(HsActivityDbAsyncRequestObserver& observer) +HsActivityDbClientPrivate::HsActivityDbClientPrivate(HsActivityDbAsyncRequestObserver &observer) { mAsyncDataHandler = HsActivityDbAsyncRequestPrivate::NewL(observer, *this); } @@ -55,8 +57,8 @@ // int HsActivityDbClientPrivate::addActivity(const QVariantHash &activity) { - TRAPD( errNo, execSimpleRequestL(AddActivity, activity);) - return errNo; + TRAPD(errNo, execSimpleRequestL(AddActivity, activity);) + return errNo; } // ----------------------------------------------------------------------------- @@ -65,8 +67,8 @@ // int HsActivityDbClientPrivate::updateActivity(const QVariantHash &activity) { - TRAPD( errNo, execSimpleRequestL(UpdateActivity, activity);) - return errNo; + TRAPD(errNo, execSimpleRequestL(UpdateActivity, activity);) + return errNo; } // ----------------------------------------------------------------------------- @@ -75,8 +77,8 @@ // int HsActivityDbClientPrivate::removeActivity(const QVariantHash &activity) { - TRAPD( errNo, execSimpleRequestL(RemoveActivity, activity);) - return errNo; + TRAPD(errNo, execSimpleRequestL(RemoveActivity, activity);) + return errNo; } // ----------------------------------------------------------------------------- @@ -85,8 +87,8 @@ // int HsActivityDbClientPrivate::removeApplicationActivities(const QVariantHash &activity) { - TRAPD( errNo, execSimpleRequestL(RemoveApplicationActivities, activity);) - return errNo; + TRAPD(errNo, execSimpleRequestL(RemoveApplicationActivities, activity);) + return errNo; } // ----------------------------------------------------------------------------- @@ -103,8 +105,8 @@ // // ----------------------------------------------------------------------------- // -int HsActivityDbClientPrivate::applicationActivities(QList& result, - const QVariantHash & condition) +int HsActivityDbClientPrivate::applicationActivities(QList& result, + const QVariantHash &condition) { TRAPD(errNo, applicationActivitiesL(result, condition)); return errNo; @@ -117,7 +119,7 @@ // int HsActivityDbClientPrivate::waitActivity(const QVariantHash &activity) { - TRAPD( errNo, waitActivityL(activity);) + TRAPD(errNo, waitActivityL(activity);) return errNo; } @@ -127,7 +129,7 @@ // int HsActivityDbClientPrivate::launchActivity(const QVariantHash &activity) { - TRAPD( errNo, execSimpleRequestL(LaunchActivity, activity);) + TRAPD(errNo, execSimpleRequestL(LaunchActivity, activity);) return errNo; } @@ -148,18 +150,18 @@ { RProcess server; const TUidType uid(KNullUid, KNullUid, KActivityServerUid); - User::LeaveIfError(server.Create( KActivityServerName, KNullDesC, uid)); + User::LeaveIfError(server.Create(KActivityServerName, KNullDesC, uid)); TRequestStatus stat; - server.Rendezvous( stat ); - if ( stat != KRequestPending ) { + server.Rendezvous(stat); + if (stat != KRequestPending) { server.Kill(0); } else { server.Resume(); } User::WaitForRequest(stat); - int errNo = (EExitPanic == server.ExitType()) ? + int errNo = (EExitPanic == server.ExitType()) ? KErrGeneral : stat.Int(); - if(KErrCancel == errNo) { + if (KErrCancel == errNo) { errNo = KErrNone; } server.Close(); @@ -174,20 +176,21 @@ { const int asyncMessageSlots(4); const int maxRetry(4); - + TInt retry = maxRetry; TInt errNo(KErrNone); do { - errNo = CreateSession( KActivityServerName, TVersion( 0, 0, 0 ), asyncMessageSlots ); - if( KErrNotFound != errNo && KErrServerTerminated != errNo) { + errNo = CreateSession(KActivityServerName, TVersion(0, 0, 0), asyncMessageSlots); + if (KErrNotFound != errNo && KErrServerTerminated != errNo) { retry =0; } else { TRAP(errNo, startServerL()); if (KErrNone != errNo && KErrAlreadyExists != errNo) { retry =0; + errNo = CreateSession(KActivityServerName, TVersion(0, 0, 0), asyncMessageSlots); } } - } while(--retry > 0); + } while (--retry > 0); User::LeaveIfError(errNo); } @@ -209,7 +212,7 @@ // // ----------------------------------------------------------------------------- // -void HsActivityDbClientPrivate::requestedActivityNameL(QString& result, +void HsActivityDbClientPrivate::requestedActivityNameL(QString &result, const QVariantHash &activity) { RBuf8 data; @@ -218,11 +221,11 @@ data.CreateL(256); data << activity; User::LeaveIfError(SendReceive(RequestedActivityName, TIpcArgs(&data,&sizeBuf))); - if(sizeBuf() > data.MaxSize()) { - data.ReAlloc(sizeBuf()); + if (sizeBuf() > data.MaxSize()) { + data.ReAlloc(sizeBuf()); } User::LeaveIfError(SendReceive(GetData, TIpcArgs(&data))); - result = QString::fromAscii(reinterpret_cast(data.Ptr()), + result = QString::fromAscii(reinterpret_cast(data.Ptr()), data.Length()); CleanupStack::PopAndDestroy(&data); } @@ -238,8 +241,8 @@ CleanupClosePushL(data); data.CreateL(256); User::LeaveIfError(SendReceive(Activities, TIpcArgs(&data, &sizeBuf))); - if(sizeBuf() > data.MaxSize()) { - data.ReAlloc(sizeBuf()); + if (sizeBuf() > data.MaxSize()) { + data.ReAlloc(sizeBuf()); } User::LeaveIfError(SendReceive(GetData, TIpcArgs(&data))); result << data; @@ -250,7 +253,7 @@ // // ----------------------------------------------------------------------------- // -void HsActivityDbClientPrivate::applicationActivitiesL(QList& result, +void HsActivityDbClientPrivate::applicationActivitiesL(QList& result, const QVariantHash & condition) { RBuf8 data; @@ -259,8 +262,8 @@ data.CreateL(256); data << condition; User::LeaveIfError(SendReceive(ApplicationActivities, TIpcArgs(&data, &sizeBuf))); - if(sizeBuf() > data.MaxSize()) { - data.ReAlloc(sizeBuf()); + if (sizeBuf() > data.MaxSize()) { + data.ReAlloc(sizeBuf()); } User::LeaveIfError(SendReceive(GetData, TIpcArgs(&data))); result << data; @@ -273,7 +276,7 @@ // void HsActivityDbClientPrivate::waitActivityL(const QVariantHash &activity) { - if(mAsyncDataHandler->IsActive()) { + if (mAsyncDataHandler->IsActive()) { User::Leave(KErrServerBusy); } else { mAsyncDataHandler->waitActivity(activity); @@ -284,7 +287,7 @@ // // ----------------------------------------------------------------------------- // -void HsActivityDbClientPrivate::getData(RBuf8& data) +void HsActivityDbClientPrivate::getData(RBuf8 &data) { SendReceive(GetData, TIpcArgs(&data)); } @@ -299,3 +302,26 @@ { SendReceive(func, data, status); } + +// ----------------------------------------------------------------------------- +// +// ----------------------------------------------------------------------------- +// +int HsActivityDbClientPrivate::getThumbnail(QPixmap &dst, const QString & src) +{ + RBuf8 data; + QVariantHash thumbnailRequest; + thumbnailRequest.insert(ActivityScreenshotKeyword, src); + TPckgBuf sizeBuf(0); + CleanupClosePushL(data); + data.CreateL(256); + data << thumbnailRequest; + User::LeaveIfError(SendReceive(GetThumbnail, TIpcArgs(&data, &sizeBuf))); + if (sizeBuf() > data.MaxSize()) { + data.ReAlloc(sizeBuf()); + } + User::LeaveIfError(SendReceive(GetData, TIpcArgs(&data))); + dst << data; + CleanupStack::PopAndDestroy(&data); + return 0; +} diff -r a6d55a2e75be -r 782e3408c2ab activityfw/activitydatabase/hsactivitydbclient/src/hsactivitydbclient.cpp --- a/activityfw/activitydatabase/hsactivitydbclient/src/hsactivitydbclient.cpp Fri Mar 26 13:00:55 2010 +0200 +++ b/activityfw/activitydatabase/hsactivitydbclient/src/hsactivitydbclient.cpp Fri Apr 16 14:45:49 2010 +0300 @@ -21,8 +21,8 @@ // // ----------------------------------------------------------------------------- // -HsActivityDbClient::HsActivityDbClient(QObject* obj) -: +HsActivityDbClient::HsActivityDbClient(QObject *obj) + : QObject(obj), d_ptr(0) { @@ -51,16 +51,16 @@ // // ----------------------------------------------------------------------------- // -void HsActivityDbClient::asyncRequestCompleated(int result, +void HsActivityDbClient::asyncRequestCompleated(int result, int requestType, const QString& data) { - switch(requestType){ - case WaitActivity: - if( KErrNone == result ) { - emit activityRequested(data); - } - break; + switch (requestType) { + case WaitActivity: + if (KErrNone == result) { + emit activityRequested(data); + } + break; } } @@ -90,7 +90,7 @@ { return d_ptr->removeActivity(activity); } - + // ----------------------------------------------------------------------------- // // ----------------------------------------------------------------------------- @@ -113,8 +113,8 @@ // // ----------------------------------------------------------------------------- // -int HsActivityDbClient::applicationActivities(QList & result, - const QVariantHash & conditions) +int HsActivityDbClient::applicationActivities(QList & result, + const QVariantHash &conditions) { return d_ptr->applicationActivities(result, conditions); } @@ -136,3 +136,12 @@ { return d_ptr->launchActivity(activity); } + +// ----------------------------------------------------------------------------- +// +// ----------------------------------------------------------------------------- +// +int HsActivityDbClient::getThumbnail(QPixmap &dst, const QString & src) +{ + return d_ptr->getThumbnail(dst, src); +} diff -r a6d55a2e75be -r 782e3408c2ab activityfw/activitydatabase/hsactivitydbserver/hsactivitydbserver.pro --- a/activityfw/activitydatabase/hsactivitydbserver/hsactivitydbserver.pro Fri Mar 26 13:00:55 2010 +0200 +++ b/activityfw/activitydatabase/hsactivitydbserver/hsactivitydbserver.pro Fri Apr 16 14:45:49 2010 +0300 @@ -44,6 +44,13 @@ s60/src/hsactivityserver_p.cpp \ s60/src/hsactivitysession_p.cpp +LIBS += -lcone -lavkon -leikcore -leiksrv -lapparc -lws32 -lapgrfx + TARGET.CAPABILITY = ALL -TCB + +myrssrules = \ +"hidden = KAppIsHidden;" +RSS_RULES += myrssrules + } diff -r a6d55a2e75be -r 782e3408c2ab activityfw/activitydatabase/hsactivitydbserver/inc/hsactivityserver.h --- a/activityfw/activitydatabase/hsactivitydbserver/inc/hsactivityserver.h Fri Mar 26 13:00:55 2010 +0200 +++ b/activityfw/activitydatabase/hsactivitydbserver/inc/hsactivityserver.h Fri Apr 16 14:45:49 2010 +0300 @@ -11,7 +11,7 @@ * * Contributors: * -* Description: +* Description: * */ @@ -32,23 +32,23 @@ * Constructor * @param storage - reference to initialized activity storage */ - HsActivityServer(HsActivityDbClientInterface& storage); - + HsActivityServer(HsActivityDbClientInterface &storage); + /** * Destructor */ ~HsActivityServer(); - + /** * Function establish server and initialize listening proces - * @return true on succees, false otherwise + * @return true on succees, false otherwise */ bool start(); private: /** * Private server implementation */ - HsActivityServerPrivate* d_ptr; + HsActivityServerPrivate *d_ptr; }; #endif //HSACTIVITYSERVER_H diff -r a6d55a2e75be -r 782e3408c2ab activityfw/activitydatabase/hsactivitydbserver/inc/hsactivitystorage.h --- a/activityfw/activitydatabase/hsactivitydbserver/inc/hsactivitystorage.h Fri Mar 26 13:00:55 2010 +0200 +++ b/activityfw/activitydatabase/hsactivitydbserver/inc/hsactivitystorage.h Fri Apr 16 14:45:49 2010 +0300 @@ -29,24 +29,24 @@ * Constructor */ HsActivityStorage(); - + /** * Destructor */ ~HsActivityStorage(); - + /** * Interface implementation. * @see int HsActivityDbClientInterface::addActivity(const QVariantHash&) */ int addActivity(const QVariantHash &activity); - + /** * Interface implementation. * @see int HsActivityDbClientInterface::updateActivity(const QVariantHash&) */ int updateActivity(const QVariantHash &activity); - + /** * Interface implementation. * @see int HsActivityDbClientInterface::removeActivity(const QVariantHash &) @@ -58,26 +58,26 @@ * @see int HsActivityDbClientInterface::removeApplicationActivities(const QVariantHash &) */ int removeApplicationActivities(const QVariantHash &activity); - + /** * Interface implementation. * @see int HsActivityDbClientInterface::activities(QList &) */ int activities(QList& result); - + /** * Interface implementation. * @see int HsActivityDbClientInterface::applicationActivities(QList &, const QVariantHash &) */ - int applicationActivities(QList& result, + int applicationActivities(QList& result, const QVariantHash &activity); - + /** * Interface implementation. * @see int HsActivityDbClientInterface::waitActivity(const QVariantHash &) */ int waitActivity(const QVariantHash &activity); - + /** * Interface implementation. * @see int HsActivityDbClientInterface::launchActivity(const QVariantHash &) @@ -88,6 +88,6 @@ * Private storage implementation * Own. */ - HsActivityStoragePrivate* d_ptr; + HsActivityStoragePrivate *d_ptr; }; #endif //HSACTIVITYSTORAGE_H diff -r a6d55a2e75be -r 782e3408c2ab activityfw/activitydatabase/hsactivitydbserver/inc/hsactivitystorage_p.h --- a/activityfw/activitydatabase/hsactivitydbserver/inc/hsactivitystorage_p.h Fri Mar 26 13:00:55 2010 +0200 +++ b/activityfw/activitydatabase/hsactivitydbserver/inc/hsactivitystorage_p.h Fri Apr 16 14:45:49 2010 +0300 @@ -21,7 +21,7 @@ /** * Class implements HsActivityDbClientInterface and storage functionality using - * database subsystem + * database subsystem */ class HsActivityStoragePrivate: public HsActivityDbClientInterface { @@ -30,61 +30,61 @@ * Constructor */ HsActivityStoragePrivate(); - + /** * Destructor */ ~HsActivityStoragePrivate(); - + /** * Interface implementation. * @see int HsActivityDbClientInterface::addActivity(const QVariantHash&) */ int addActivity(const QVariantHash &); - + /** * Interface implementation. * @see int HsActivityDbClientInterface::updateActivity(const QVariantHash&) */ int updateActivity(const QVariantHash &); - + /** * Interface implementation. * @see int HsActivityDbClientInterface::removeActivity(const QVariantHash &) */ int removeActivity(const QVariantHash &activity); - /** - * Interface implementation. - * @see int HsActivityDbClientInterface::removeApplicationActivities(const QVariantHash &) - */ + /** + * Interface implementation. + * @see int HsActivityDbClientInterface::removeApplicationActivities(const QVariantHash &) + */ int removeApplicationActivities(const QVariantHash &activity); /** * Interface implementation. * @see int HsActivityDbClientInterface::requestedActivityName( QString &, const QVariantHash &) */ - int requestedActivityName(QString& result, + int requestedActivityName(QString &result, const QVariantHash &activity); - + /** * Interface implementation. * @see int HsActivityDbClientInterface::activities(QList &) */ int activities(QList &); - + /** * Interface implementation. * @see int HsActivityDbClientInterface::applicationActivities(QList &, const QVariantHash &) */ int applicationActivities(QList &, const QVariantHash &); - + /** * Interface implementation. * @see int HsActivityDbClientInterface::waitActivity(const QVariantHash &) */ int waitActivity(const QVariantHash &activity); - + /** * Interface implementation. * @see int HsActivityDbClientInterface::launchActivity(const QVariantHash &) @@ -96,50 +96,50 @@ * @return true if structure is valid, false otherwise */ bool checkTables(); - + /** * Function create database structure */ void recreateTables(); - + /** * Function return last SQL query error code * @param querty - executed sql query - * @return SQL query error code + * @return SQL query error code */ - int getSqlErrorCode(const QSqlQuery& query); - + int getSqlErrorCode(const QSqlQuery &query); + /** * Function exeute SQL query - * @param query - SQL + * @param query - SQL * @return true on succees, false otherwise */ - bool exec(QSqlQuery& query); - + bool exec(QSqlQuery &query); + /** * Function exeute SQL query * @param query - SQL query that has to be executed * @return true on succees, false otherwise */ - bool exec(const QString &query, const QVariantHash& params); - + bool exec(const QString &query, const QVariantHash ¶ms); + /** * Funciton bind provided filtering rules with prepared SQL query - * @param query - SQL query + * @param query - SQL query * @param activity - filtering rules * @param additionalData - additional filetering rules */ - void bind( QSqlQuery& query, - const QVariantHash &activity, - const QVariantHash &additionalData = QVariantHash()); - + void bind(QSqlQuery &query, + const QVariantHash &activity, + const QVariantHash &additionalData = QVariantHash()); + /** * Funciton get records that match conditions - * @param result - output destination + * @param result - output destination * @param query - SQL query sting * @param conditions - query conditions */ - int activities(QList &results, + int activities(QList &results, const QString &query, const QVariantHash &conditions); diff -r a6d55a2e75be -r 782e3408c2ab activityfw/activitydatabase/hsactivitydbserver/s60/inc/hsactivityserver_p.h --- a/activityfw/activitydatabase/hsactivitydbserver/s60/inc/hsactivityserver_p.h Fri Mar 26 13:00:55 2010 +0200 +++ b/activityfw/activitydatabase/hsactivitydbserver/s60/inc/hsactivityserver_p.h Fri Apr 16 14:45:49 2010 +0300 @@ -24,53 +24,53 @@ /** * Class implemets server functionality for S60 enviroment */ -class HsActivityServerPrivate : public CServer2 +class HsActivityServerPrivate : public CServer2 { public: /** * Constructor */ - HsActivityServerPrivate(HsActivityDbClientInterface& storage); - + HsActivityServerPrivate(HsActivityDbClientInterface &storage); + /** * Destructor */ ~HsActivityServerPrivate(); - + /** * Function establish server and initialize listening proces - * @return true on succees, false otherwise + * @return true on succees, false otherwise */ bool start(); - + /** - * Function look for active application session and complete pending message + * Function look for active application session and complete pending message */ - void notifyL(int applicationId, const QString& activityName); - + void notifyL(int applicationId, const QString &activityName); + /** - * Cancel notification + * Cancel notification */ void cancelNotify(int applicationId); - + /** * Function add item to pending messages */ - void waitNotification(int applicationId, const RMessage2& msg); + void waitNotification(int applicationId, const RMessage2 &msg); private: /** * Function create new client session to handle its request * @param version - client implementation version * @param message - request message */ - CSession2* NewSessionL(const TVersion& version,const RMessage2& message)const; + CSession2 *NewSessionL(const TVersion &version,const RMessage2 &message)const; private: /** * Reference to initialized storage client */ - HsActivityDbClientInterface& mStorage; - + HsActivityDbClientInterface &mStorage; + QHash mPendingMessage; }; diff -r a6d55a2e75be -r 782e3408c2ab activityfw/activitydatabase/hsactivitydbserver/s60/inc/hsactivitysession_p.h --- a/activityfw/activitydatabase/hsactivitydbserver/s60/inc/hsactivitysession_p.h Fri Mar 26 13:00:55 2010 +0200 +++ b/activityfw/activitydatabase/hsactivitydbserver/s60/inc/hsactivitysession_p.h Fri Apr 16 14:45:49 2010 +0300 @@ -19,8 +19,9 @@ #define ACTIVITYSESSIONPRIVATE_H #include #include "hsactivitydbclientinterface.h" + /** - * Class impolements client session for S60 enviroment. + * Class impolements client session for S60 enviroment. * Class is responsible for request handling and data translations */ class HsActivitySessionPrivate: public CSession2 @@ -30,122 +31,130 @@ * Constructor * @param storage - reference to initialized activity storage */ - HsActivitySessionPrivate(HsActivityDbClientInterface& storage); - + HsActivitySessionPrivate(HsActivityDbClientInterface &storage); + /** * Destructor */ ~HsActivitySessionPrivate(); - + /** * Implements interface * @see void CSession2::ServiceL(const RMessage2&) */ - void ServiceL(const RMessage2& message); - + void ServiceL(const RMessage2 &message); + /** * Implements interface * @see void CSession2::ServiceError(const RMessage2 &, TInt) */ void ServiceError(const RMessage2 &message, TInt error); - - void LaunchActivityL(const RMessage2 &message, const QString &name ); - - void CancelNotify(RMessage2& message); + + void LaunchActivityL(const RMessage2 &message, const QString &name); + + void CancelNotify(RMessage2 &message); private: /** * Function handle data translation and forward request to storage client * Function can leave on failure. - * @param message - request message + * @param message - request message */ - void HandleAddActivityL(const RMessage2& message); - + void HandleAddActivityL(const RMessage2 &message); + /** * Function handle data translation and forward request to storage client * Function can leave on failure. - * @param message - request message + * @param message - request message */ - void HandleUpdateActivityL(const RMessage2& message); - + void HandleUpdateActivityL(const RMessage2 &message); + /** * Function handle data translation and forward request to storage client * Function can leave on failure. - * @param message - request message + * @param message - request message */ - void HandleRemoveActivityL(const RMessage2& message); - + void HandleRemoveActivityL(const RMessage2 &message); + /** * Function handle data translation and forward request to storage client * Function can leave on failure. - * @param message - request message + * @param message - request message */ - void HandleRemoveApplicationActivitiesL(const RMessage2& message); - + void HandleRemoveApplicationActivitiesL(const RMessage2 &message); + /** * Function handle data translation and forward request to storage client * Function can leave on failure. - * @param message - request message + * @param message - request message */ - void HandleActivitiesL(const RMessage2& message); - + void HandleActivitiesL(const RMessage2 &message); + /** * Function handle data translation and forward request to storage client * Function can leave on failure. - * @param message - request message + * @param message - request message */ - void HandleApplicationActivitiesL(const RMessage2& message); - + void HandleApplicationActivitiesL(const RMessage2 &message); + /** * Function handle data translation and forward request to server * Function can leave on failure. - * @param message - request message + * @param message - request message */ - void HandleLaunchActivityL(const RMessage2& message); - + void HandleLaunchActivityL(const RMessage2 &message); + /** * Function handle data translation and forward request to server * Function can leave on failure. - * @param message - request message + * @param message - request message */ - void HandleWaitActivityL(const RMessage2& message); + void HandleWaitActivityL(const RMessage2 &message); + + /** + * Function cancels subscribtion + * @param message - request message + */ + void HandleCancelWaitActivity(const RMessage2 &message); /** - * Function cancels subscribtion - * @param message - request message - */ - void HandleCancelWaitActivity(const RMessage2& message); - + * Function read thumbail + * @param message - request message + */ + void HandleGetThumbnailL(const RMessage2 &message); + /** * Function handle data translation and forward request to storage client * Function can leave on failure. - * @param message - request message + * @param message - request message */ - void HandleGetDataL(const RMessage2& message); - + void HandleGetDataL(const RMessage2 &message); + void LaunchActivityL(); + + void WaitActivityL(const RMessage2 &message); - void WaitActivityL(const RMessage2& message); - + void GetThumbnailL(const RMessage2 &message); + void CancelNotify(); - - + + /** * Function deserialize data for request message * Function can leave on failure. */ - void ReadDataL(const RMessage2& src); - + void ReadDataL(const RMessage2 &src); + /** * Function handle data translation and forward request to storage client * Function can leave on failure. - * @param message - request message + * @param message - request message */ void LeaveIfNotZero(int errNo); private: /** * Reference to storage client */ - HsActivityDbClientInterface& mStorage; + HsActivityDbClientInterface &mStorage; RBuf8 mData; QVariantHash mActivity; QList mResult; diff -r a6d55a2e75be -r 782e3408c2ab activityfw/activitydatabase/hsactivitydbserver/s60/src/hsactivityserver_p.cpp --- a/activityfw/activitydatabase/hsactivitydbserver/s60/src/hsactivityserver_p.cpp Fri Mar 26 13:00:55 2010 +0200 +++ b/activityfw/activitydatabase/hsactivitydbserver/s60/src/hsactivityserver_p.cpp Fri Apr 16 14:45:49 2010 +0300 @@ -22,9 +22,9 @@ // // ----------------------------------------------------------------------------- // -HsActivityServerPrivate::HsActivityServerPrivate(HsActivityDbClientInterface& storage) -: - CServer2( EPriorityNormal, ESharableSessions), +HsActivityServerPrivate::HsActivityServerPrivate(HsActivityDbClientInterface &storage) + : + CServer2(EPriorityNormal, ESharableSessions), mStorage(storage) { } @@ -43,19 +43,19 @@ // bool HsActivityServerPrivate::start() { - return ( KErrNone == Start(KActivityServerName) ); + return (KErrNone == Start(KActivityServerName)); } // ----------------------------------------------------------------------------- // // ----------------------------------------------------------------------------- // -void HsActivityServerPrivate::notifyL(int applicationId, - const QString& activityName) +void HsActivityServerPrivate::notifyL(int applicationId, + const QString &activityName) { - if(mPendingMessage.end() != mPendingMessage.find(applicationId)) { - static_cast(mPendingMessage.find(applicationId).value().Session()) - ->LaunchActivityL(mPendingMessage.find(applicationId).value(), activityName ); + if (mPendingMessage.end() != mPendingMessage.find(applicationId)) { + static_cast(mPendingMessage.find(applicationId).value().Session()) + ->LaunchActivityL(mPendingMessage.find(applicationId).value(), activityName); mPendingMessage.erase(mPendingMessage.find(applicationId)); } } @@ -64,10 +64,10 @@ // // ----------------------------------------------------------------------------- // -void HsActivityServerPrivate::waitNotification(int applicationId, - const RMessage2& msg) +void HsActivityServerPrivate::waitNotification(int applicationId, + const RMessage2 &msg) { - if(mPendingMessage.find(applicationId) != mPendingMessage.end()) { + if (mPendingMessage.find(applicationId) != mPendingMessage.end()) { msg.Kill(EBadMessageNumber); } mPendingMessage.insert(applicationId,msg); @@ -77,21 +77,20 @@ // ----------------------------------------------------------------------------- // void HsActivityServerPrivate::cancelNotify(int applicationId) - { - if(mPendingMessage.end() != mPendingMessage.find(applicationId)) - { - static_cast(mPendingMessage.find(applicationId).value().Session()) - ->CancelNotify(mPendingMessage.find(applicationId).value()); - mPendingMessage.erase(mPendingMessage.find(applicationId)); - } - } +{ + if (mPendingMessage.end() != mPendingMessage.find(applicationId)) { + static_cast(mPendingMessage.find(applicationId).value().Session()) + ->CancelNotify(mPendingMessage.find(applicationId).value()); + mPendingMessage.erase(mPendingMessage.find(applicationId)); + } +} // ----------------------------------------------------------------------------- // // ----------------------------------------------------------------------------- // -CSession2* HsActivityServerPrivate::NewSessionL(const TVersion&, - const RMessage2&)const +CSession2 *HsActivityServerPrivate::NewSessionL(const TVersion &, + const RMessage2&)const { - return new (ELeave) HsActivitySessionPrivate(mStorage); + return new(ELeave) HsActivitySessionPrivate(mStorage); } diff -r a6d55a2e75be -r 782e3408c2ab activityfw/activitydatabase/hsactivitydbserver/s60/src/hsactivitysession_p.cpp --- a/activityfw/activitydatabase/hsactivitydbserver/s60/src/hsactivitysession_p.cpp Fri Mar 26 13:00:55 2010 +0200 +++ b/activityfw/activitydatabase/hsactivitydbserver/s60/src/hsactivitysession_p.cpp Fri Apr 16 14:45:49 2010 +0300 @@ -19,14 +19,13 @@ #include "hsactivityglobals.h" #include "hsserializer.h" #include - -const char ActivityPrimaryKeyFormat [] = "%1:%2"; +#include // ----------------------------------------------------------------------------- // // ----------------------------------------------------------------------------- // -HsActivitySessionPrivate::HsActivitySessionPrivate(HsActivityDbClientInterface& storage) -: mStorage(storage), mAppId(KErrNotFound) +HsActivitySessionPrivate::HsActivitySessionPrivate(HsActivityDbClientInterface &storage) + : mStorage(storage), mAppId(KErrNotFound) { } @@ -36,34 +35,56 @@ // HsActivitySessionPrivate::~HsActivitySessionPrivate() { - CancelNotify(); - mData.Close(); + CancelNotify(); + mData.Close(); } // ----------------------------------------------------------------------------- // // ----------------------------------------------------------------------------- // -void HsActivitySessionPrivate::ServiceL(const RMessage2& message) +void HsActivitySessionPrivate::ServiceL(const RMessage2 &message) { mActivity.clear(); mResult.clear(); mName.clear(); - - int errNo(KErrNone); - switch(message.Function()) { - case AddActivity: HandleAddActivityL(message); break; - case UpdateActivity: HandleUpdateActivityL(message); break; - case RemoveActivity: HandleRemoveActivityL(message); break; - case RemoveApplicationActivities: HandleRemoveApplicationActivitiesL(message); break; - case Activities: HandleActivitiesL(message);break; - case ApplicationActivities: HandleApplicationActivitiesL(message);break; - case LaunchActivity: HandleLaunchActivityL(message);break; - case WaitActivity: HandleWaitActivityL(message);return; //!!!!! This message shouldn't be compleated !!!!! - case GetData: HandleGetDataL(message); break; - case CancelWait: HandleCancelWaitActivity(message); break; - default: - message.Panic(KErr400, CServer2::EBadMessageNumber); + + switch (message.Function()) { + case AddActivity: + HandleAddActivityL(message); + break; + case UpdateActivity: + HandleUpdateActivityL(message); + break; + case RemoveActivity: + HandleRemoveActivityL(message); + break; + case RemoveApplicationActivities: + HandleRemoveApplicationActivitiesL(message); + break; + case Activities: + HandleActivitiesL(message); + break; + case ApplicationActivities: + HandleApplicationActivitiesL(message); + break; + case LaunchActivity: + HandleLaunchActivityL(message); + break; + case WaitActivity: + HandleWaitActivityL(message); + return; //!!!!! This message shouldn't be compleated !!!!! + case GetThumbnail: + HandleGetThumbnailL(message); + break; + case GetData: + HandleGetDataL(message); + break; + case CancelWait: + HandleCancelWaitActivity(message); + break; + default: + message.Panic(KErr400, CServer2::EBadMessageNumber); } message.Complete(KErrNone); } @@ -81,7 +102,7 @@ // // ----------------------------------------------------------------------------- // -void HsActivitySessionPrivate::HandleAddActivityL(const RMessage2& message) +void HsActivitySessionPrivate::HandleAddActivityL(const RMessage2 &message) { ReadDataL(message); LeaveIfNotZero(mStorage.addActivity(mActivity)); @@ -91,7 +112,7 @@ // // ----------------------------------------------------------------------------- // -void HsActivitySessionPrivate::HandleUpdateActivityL(const RMessage2& message) +void HsActivitySessionPrivate::HandleUpdateActivityL(const RMessage2 &message) { ReadDataL(message); LeaveIfNotZero(mStorage.updateActivity(mActivity)); @@ -101,7 +122,7 @@ // // ----------------------------------------------------------------------------- // -void HsActivitySessionPrivate::HandleRemoveActivityL(const RMessage2& message) +void HsActivitySessionPrivate::HandleRemoveActivityL(const RMessage2 &message) { ReadDataL(message); LeaveIfNotZero(mStorage.removeActivity(mActivity)); @@ -111,7 +132,7 @@ // // ----------------------------------------------------------------------------- // -void HsActivitySessionPrivate::HandleRemoveApplicationActivitiesL(const RMessage2& message) +void HsActivitySessionPrivate::HandleRemoveApplicationActivitiesL(const RMessage2 &message) { ReadDataL(message); LeaveIfNotZero(mStorage.removeApplicationActivities(mActivity)); @@ -121,7 +142,7 @@ // // ----------------------------------------------------------------------------- // -void HsActivitySessionPrivate::HandleActivitiesL(const RMessage2& message) +void HsActivitySessionPrivate::HandleActivitiesL(const RMessage2 &message) { int errNo(KErrNone); QT_TRYCATCH_LEAVING(errNo = mStorage.activities(mResult)); @@ -135,7 +156,7 @@ // // ----------------------------------------------------------------------------- // -void HsActivitySessionPrivate::HandleApplicationActivitiesL(const RMessage2& message) +void HsActivitySessionPrivate::HandleApplicationActivitiesL(const RMessage2 &message) { int errNo(KErrNone); ReadDataL(message); @@ -150,7 +171,7 @@ // // ----------------------------------------------------------------------------- // -void HsActivitySessionPrivate::HandleLaunchActivityL(const RMessage2& message) +void HsActivitySessionPrivate::HandleLaunchActivityL(const RMessage2 &message) { ReadDataL(message); LaunchActivityL(); @@ -160,7 +181,7 @@ // // ----------------------------------------------------------------------------- // -void HsActivitySessionPrivate::HandleWaitActivityL(const RMessage2& message) +void HsActivitySessionPrivate::HandleWaitActivityL(const RMessage2 &message) { ReadDataL(message); WaitActivityL(message); @@ -170,16 +191,26 @@ // // ----------------------------------------------------------------------------- // -void HsActivitySessionPrivate::HandleCancelWaitActivity(const RMessage2& /*message*/) - { - CancelNotify(); - } +void HsActivitySessionPrivate::HandleGetThumbnailL(const RMessage2 &message) +{ + ReadDataL(message); + GetThumbnailL(message); +} // ----------------------------------------------------------------------------- // // ----------------------------------------------------------------------------- // -void HsActivitySessionPrivate::HandleGetDataL(const RMessage2& message) +void HsActivitySessionPrivate::HandleCancelWaitActivity(const RMessage2& /*message*/) +{ + CancelNotify(); +} + +// ----------------------------------------------------------------------------- +// +// ----------------------------------------------------------------------------- +// +void HsActivitySessionPrivate::HandleGetDataL(const RMessage2 &message) { message.WriteL(0, mData); } @@ -190,25 +221,25 @@ // void HsActivitySessionPrivate::LaunchActivityL() { - CServer2* const server(const_cast(Server())); - if(mActivity.end() == mActivity.find(ActivityApplicationKeyword) || - mActivity.end() == mActivity.find(ActivityActivityKeyword)) { + CServer2 *const server(const_cast(Server())); + if (mActivity.end() == mActivity.find(ActivityApplicationKeyword) || + mActivity.end() == mActivity.find(ActivityActivityKeyword)) { User::Leave(KErrCorrupt); } - static_cast - (server)->notifyL(mActivity.find(ActivityApplicationKeyword).value().toInt(), - mActivity.find(ActivityActivityKeyword).value().toString()); + static_cast + (server)->notifyL(mActivity.find(ActivityApplicationKeyword).value().toInt(), + mActivity.find(ActivityActivityKeyword).value().toString()); } // ----------------------------------------------------------------------------- // // ----------------------------------------------------------------------------- // -void HsActivitySessionPrivate::LaunchActivityL(const RMessage2 &message, - const QString &name ) +void HsActivitySessionPrivate::LaunchActivityL(const RMessage2 &message, + const QString &name) { - if (mData.MaxSize() < name.toAscii().length()){ - mData.ReAlloc( name.toAscii().length()); + if (mData.MaxSize() < name.toAscii().length()) { + mData.ReAlloc(name.toAscii().length()); } mData.Copy(reinterpret_cast(name.toAscii().data()), name.toAscii().length()); @@ -220,15 +251,29 @@ // // ----------------------------------------------------------------------------- // -void HsActivitySessionPrivate::WaitActivityL(const RMessage2& msg) +void HsActivitySessionPrivate::WaitActivityL(const RMessage2 &msg) { - CServer2* const server(const_cast(Server())); - if(mActivity.end() == mActivity.find(ActivityApplicationKeyword)) { + CServer2 *const server(const_cast(Server())); + if (mActivity.end() == mActivity.find(ActivityApplicationKeyword)) { User::Leave(KErrCorrupt); } mAppId = mActivity.find(ActivityApplicationKeyword).value().toInt(); - static_cast - (server)->waitNotification(mAppId, msg); + static_cast + (server)->waitNotification(mAppId, msg); +} + +// ----------------------------------------------------------------------------- +// +// ----------------------------------------------------------------------------- +// +void HsActivitySessionPrivate::GetThumbnailL(const RMessage2 &message) +{ + if (mActivity.constEnd() == mActivity.constFind(ActivityScreenshotKeyword)) { + User::Leave(KErrGeneral); + } + mData << QPixmap(mActivity.constFind(ActivityScreenshotKeyword).value().toString()); + TPckgC dataSize(mData.Size()); + message.WriteL(1, dataSize); } // ----------------------------------------------------------------------------- @@ -236,36 +281,35 @@ // ----------------------------------------------------------------------------- // void HsActivitySessionPrivate::CancelNotify() - { - if ( mAppId != KErrNotFound ) - { - CServer2* const server(const_cast(Server())); - static_cast(server)->cancelNotify(mAppId); - mAppId = KErrNotFound; - } - } +{ + if (mAppId != KErrNotFound) { + CServer2 *const server(const_cast(Server())); + static_cast(server)->cancelNotify(mAppId); + mAppId = KErrNotFound; + } +} // ----------------------------------------------------------------------------- // // ----------------------------------------------------------------------------- // -void HsActivitySessionPrivate::CancelNotify(RMessage2& message) - { - message.Complete(KErrCancel); - } +void HsActivitySessionPrivate::CancelNotify(RMessage2 &message) +{ + message.Complete(KErrCancel); +} // ----------------------------------------------------------------------------- // // ----------------------------------------------------------------------------- // -void HsActivitySessionPrivate::ReadDataL(const RMessage2& src) +void HsActivitySessionPrivate::ReadDataL(const RMessage2 &src) { int srcLength = src.GetDesLength(0); User::LeaveIfError(srcLength); RBuf8 buffer; CleanupClosePushL(buffer); buffer.CreateL(srcLength); - src.ReadL( 0, buffer, 0); + src.ReadL(0, buffer, 0); if (buffer.Length() != srcLength) { User::Leave(KErrCorrupt); } diff -r a6d55a2e75be -r 782e3408c2ab activityfw/activitydatabase/hsactivitydbserver/s60/src/main.cpp --- a/activityfw/activitydatabase/hsactivitydbserver/s60/src/main.cpp Fri Mar 26 13:00:55 2010 +0200 +++ b/activityfw/activitydatabase/hsactivitydbserver/s60/src/main.cpp Fri Apr 16 14:45:49 2010 +0300 @@ -28,34 +28,34 @@ #include "hsactivitystorage.h" class HsActivityMainAppUi : public QS60MainAppUi - { +{ public: TBool FrameworkCallsRendezvous() const { return EFalse; } - }; +}; class HsActivityMainDocument : public QS60MainDocument - { +{ public: - HsActivityMainDocument(CEikApplication &mainApplication):QS60MainDocument(mainApplication){} - + HsActivityMainDocument(CEikApplication &mainApplication):QS60MainDocument(mainApplication) {} + CEikAppUi *CreateAppUiL() { - return (static_cast (new(ELeave)HsActivityMainAppUi)); + return (static_cast (new(ELeave)HsActivityMainAppUi)); } - }; +}; class HsActivityApplication : public QS60MainApplication - { +{ protected: CApaDocument *CreateDocumentL() { - return new (ELeave) HsActivityMainDocument(*this); - } - }; + return new(ELeave) HsActivityMainDocument(*this); + } +}; CApaApplication *newHsActivityApplication() { - return new HsActivityApplication; + return new HsActivityApplication; } int main(int argc, char *argv[]) @@ -64,20 +64,20 @@ HsActivityStorage storage; HsActivityServer server(storage); int retVal(KErrGeneral); - if( server.start() ){ - CEikonEnv * env = CEikonEnv::Static(); - if ( env ) { - CApaWindowGroupName* wgName = CApaWindowGroupName::NewLC(env->WsSession()); + if (server.start()) { + CEikonEnv *env = CEikonEnv::Static(); + if (env) { + CApaWindowGroupName *wgName = CApaWindowGroupName::NewLC(env->WsSession()); wgName->SetHidden(ETrue); // hides us from FSW and protects us from OOM FW etc. - wgName->SetSystem(ETrue); // Allow only application with PowerManagement cap to shut us down + wgName->SetSystem(ETrue); // Allow only application with PowerManagement cap to shut us down RWindowGroup &rootWindowGroup = env->RootWin(); wgName->SetWindowGroupName(rootWindowGroup); - rootWindowGroup.SetOrdinalPosition(-1, ECoeWinPriorityNormal); //move to background. + rootWindowGroup.SetOrdinalPosition(-1, ECoeWinPriorityNormal); //move to background. CleanupStack::PopAndDestroy(); - } + } RProcess::Rendezvous(KErrNone); retVal = app.exec(); - }else + } else RProcess::Rendezvous(retVal); return retVal; } diff -r a6d55a2e75be -r 782e3408c2ab activityfw/activitydatabase/hsactivitydbserver/src/hsactivityserver.cpp --- a/activityfw/activitydatabase/hsactivitydbserver/src/hsactivityserver.cpp Fri Mar 26 13:00:55 2010 +0200 +++ b/activityfw/activitydatabase/hsactivitydbserver/src/hsactivityserver.cpp Fri Apr 16 14:45:49 2010 +0300 @@ -21,8 +21,8 @@ // // ----------------------------------------------------------------------------- // -HsActivityServer::HsActivityServer(HsActivityDbClientInterface& storage) -: +HsActivityServer::HsActivityServer(HsActivityDbClientInterface &storage) + : d_ptr(new HsActivityServerPrivate(storage)) { } diff -r a6d55a2e75be -r 782e3408c2ab activityfw/activitydatabase/hsactivitydbserver/src/hsactivitystorage.cpp --- a/activityfw/activitydatabase/hsactivitydbserver/src/hsactivitystorage.cpp Fri Mar 26 13:00:55 2010 +0200 +++ b/activityfw/activitydatabase/hsactivitydbserver/src/hsactivitystorage.cpp Fri Apr 16 14:45:49 2010 +0300 @@ -22,8 +22,8 @@ // ----------------------------------------------------------------------------- // HsActivityStorage::HsActivityStorage() -: -d_ptr(new HsActivityStoragePrivate()) + : + d_ptr(new HsActivityStoragePrivate()) { } @@ -40,7 +40,7 @@ // // ----------------------------------------------------------------------------- // -int HsActivityStorage::addActivity(const QVariantHash& activity) +int HsActivityStorage::addActivity(const QVariantHash &activity) { return d_ptr->addActivity(activity); } @@ -49,7 +49,7 @@ // // ----------------------------------------------------------------------------- // -int HsActivityStorage::updateActivity(const QVariantHash& activity) +int HsActivityStorage::updateActivity(const QVariantHash &activity) { return d_ptr->updateActivity(activity); } @@ -58,7 +58,7 @@ // // ----------------------------------------------------------------------------- // -int HsActivityStorage::removeActivity(const QVariantHash& activity) +int HsActivityStorage::removeActivity(const QVariantHash &activity) { return d_ptr->removeActivity(activity); } @@ -67,7 +67,7 @@ // // ----------------------------------------------------------------------------- // -int HsActivityStorage::removeApplicationActivities(const QVariantHash& activity) +int HsActivityStorage::removeApplicationActivities(const QVariantHash &activity) { return d_ptr->removeApplicationActivities(activity); } @@ -77,7 +77,7 @@ // ----------------------------------------------------------------------------- // int HsActivityStorage::activities(QList& result) -{ +{ return d_ptr->activities(result); } @@ -85,7 +85,7 @@ // // ----------------------------------------------------------------------------- // -int HsActivityStorage::applicationActivities(QList& result, +int HsActivityStorage::applicationActivities(QList& result, const QVariantHash &activity) { return d_ptr->applicationActivities(result, activity); diff -r a6d55a2e75be -r 782e3408c2ab activityfw/activitydatabase/hsactivitydbserver/src/hsactivitystorage_p.cpp --- a/activityfw/activitydatabase/hsactivitydbserver/src/hsactivitystorage_p.cpp Fri Mar 26 13:00:55 2010 +0200 +++ b/activityfw/activitydatabase/hsactivitydbserver/src/hsactivitystorage_p.cpp Fri Apr 16 14:45:49 2010 +0300 @@ -37,12 +37,12 @@ settings.setValue(ActivityStorageProperty, ActivityDefaultStorage); } QString databaseFile = settings.value(ActivityStorageProperty).toString(); - + if (QSqlDatabase::contains(ActivityStorageName)) { mConn = QSqlDatabase::database(ActivityStorageName); - } else { + } else { mConn = QSqlDatabase::addDatabase(ActivityStorageDriver, ActivityStorageName); - mConn.setDatabaseName(databaseFile); + mConn.setDatabaseName(databaseFile); if (!mConn.open()) { qWarning(qPrintable(mConn.lastError().text())); return; @@ -72,13 +72,13 @@ QByteArray streamedData; QDataStream stream(&streamedData, QIODevice::WriteOnly); stream << activity; - + //insert data QSqlQuery query(mConn); query.prepare(ActivitySelectActivityQuery); bind(query, activity); exec(query); - if(query.next()) { + if (query.next()) { return KErrGeneral; } query.prepare(ActivityInsertActivityQuery); @@ -99,7 +99,7 @@ QByteArray streamedData; QDataStream stream(&streamedData, QIODevice::WriteOnly); stream << activity; - + // update QSqlQuery query(mConn); query.prepare(ActivityUpdateActivityQuery); @@ -131,8 +131,8 @@ // // ----------------------------------------------------------------------------- // -int HsActivityStoragePrivate::requestedActivityName(QString& result, - const QVariantHash &activity) +int HsActivityStoragePrivate::requestedActivityName(QString &result, + const QVariantHash &activity) { QSqlQuery query(mConn); query.prepare(ActivitySelectActiveQuery); @@ -159,8 +159,8 @@ // // ----------------------------------------------------------------------------- // -int HsActivityStoragePrivate::applicationActivities(QList & result, - const QVariantHash & condition) +int HsActivityStoragePrivate::applicationActivities(QList & result, + const QVariantHash &condition) { return activities(result, ActivityApplicationActivitiesQuery, condition); } @@ -188,7 +188,7 @@ // bool HsActivityStoragePrivate::checkTables() { - return (QStringList("Activities") == mConn.tables()); + return (QStringList("Activities") == mConn.tables()); } // ----------------------------------------------------------------------------- @@ -202,34 +202,34 @@ qErrnoWarning(qPrintable(mConn.lastError().text())); return; } - + // drop any existing tables QSqlQuery query(mConn); - foreach (const QString &tableName, mConn.tables()) { + foreach(const QString &tableName, mConn.tables()) { query.prepare(ActivityDropQuery); query.bindValue(ActivityTableKeyword, tableName); exec(query); } - + // create new table query.prepare(ActivityCreateQuery); exec(query); - + //finish sql transaction if (!mConn.commit()) { qErrnoWarning(qPrintable(mConn.lastError().text())); - } + } } // ----------------------------------------------------------------------------- // // ----------------------------------------------------------------------------- // -int HsActivityStoragePrivate::getSqlErrorCode(const QSqlQuery& query) +int HsActivityStoragePrivate::getSqlErrorCode(const QSqlQuery &query) { const QSqlError err(query.lastError()); const QString errStr(err.text()); - + if (QSqlError ::NoError == err.type()) { return 0; } else { @@ -242,7 +242,7 @@ // // ----------------------------------------------------------------------------- // -bool HsActivityStoragePrivate::exec(QSqlQuery& query) +bool HsActivityStoragePrivate::exec(QSqlQuery &query) { const bool retVal = query.exec(); qErrnoWarning(qPrintable(query.lastQuery())); @@ -256,30 +256,30 @@ // // ----------------------------------------------------------------------------- // -bool HsActivityStoragePrivate::exec(const QString &queryStr, const QVariantHash& params) +bool HsActivityStoragePrivate::exec(const QString &queryStr, const QVariantHash ¶ms) { QSqlQuery query(mConn); query.prepare(queryStr); bind(query, params); query.exec(); return getSqlErrorCode(query); - + } // ----------------------------------------------------------------------------- // // ----------------------------------------------------------------------------- // -void HsActivityStoragePrivate::bind( QSqlQuery& query, - const QVariantHash &activity, - const QVariantHash &additionalData) +void HsActivityStoragePrivate::bind(QSqlQuery &query, + const QVariantHash &activity, + const QVariantHash &additionalData) { const QChar tag(' '); - QString queryString( query.lastQuery() ); + QString queryString(query.lastQuery()); QVariantHash::const_iterator iter; int offset(0); QStringList tokens; - - //explode SQL query to tokens + + //explode SQL query to tokens do { offset = queryString.indexOf(tag, 0); if (0 < offset) { @@ -292,24 +292,24 @@ break; } } while (true); - + //current Sql driver doesnt support proper query formating. //reuest filtering data has to be binded in right order. QStringList::iterator token = tokens.begin(); //iterate all tokens for (; token != tokens.end(); token = tokens.erase(token)) { //iterate all provided data and chcek if it match pattern - for ( iter = activity.constBegin(); - iter != activity.constEnd(); - ++iter ) { - if( (*token).contains(iter.key()) ){ + for (iter = activity.constBegin(); + iter != activity.constEnd(); + ++iter) { + if ((*token).contains(iter.key())) { query.bindValue(iter.key(), iter.value()); break; } } - for (iter = additionalData.constBegin(); - iter != additionalData.constEnd(); - ++iter) { + for (iter = additionalData.constBegin(); + iter != additionalData.constEnd(); + ++iter) { if ((*token).contains(iter.key())) { query.bindValue(iter.key(), iter.value()); break; @@ -322,12 +322,12 @@ // // ----------------------------------------------------------------------------- // -int HsActivityStoragePrivate::activities(QList &results, - const QString &queryStr, - const QVariantHash &conditions) +int HsActivityStoragePrivate::activities(QList &results, + const QString &queryStr, + const QVariantHash &conditions) { results.clear(); - + QSqlQuery query(mConn); query.prepare(queryStr); bind(query, conditions); diff -r a6d55a2e75be -r 782e3408c2ab activityfw/activitydatabase/hsactivitydbserver/src/main.cpp --- a/activityfw/activitydatabase/hsactivitydbserver/src/main.cpp Fri Mar 26 13:00:55 2010 +0200 +++ b/activityfw/activitydatabase/hsactivitydbserver/src/main.cpp Fri Apr 16 14:45:49 2010 +0300 @@ -20,15 +20,22 @@ #include "hsactivityserver.h" #include "hsactivitystorage.h" - +#ifdef Q_OS_SYMBIAN +#include +#include +#endif int main(int argc, char *argv[]) { +#ifdef Q_OS_SYMBIAN + CCoeEnv::Static()->RootWin().SetOrdinalPosition(0, ECoeWinPriorityNeverAtFront); +#endif + QCoreApplication app(argc, argv); HsActivityStorage storage; HsActivityServer server(storage); int retVal(KErrGeneral); - if( server.start() ){ + if (server.start()) { retVal = app.exec(); } return retVal; diff -r a6d55a2e75be -r 782e3408c2ab activityfw/activitydatabase/inc/hsactivitydbclientinterface.h --- a/activityfw/activitydatabase/inc/hsactivitydbclientinterface.h Fri Mar 26 13:00:55 2010 +0200 +++ b/activityfw/activitydatabase/inc/hsactivitydbclientinterface.h Fri Apr 16 14:45:49 2010 +0300 @@ -21,8 +21,7 @@ /** * Enumerate supported functions */ -enum ClientFunctions -{ +enum ClientFunctions { AddActivity =0, UpdateActivity, RemoveActivity, @@ -32,72 +31,74 @@ ApplicationActivities, WaitActivity, LaunchActivity, + GetThumbnail, GetData, CancelWait }; const char ActivityApplicationKeyword [] = ":ApplicationId"; const char ActivityActivityKeyword [] = ":ActivityName"; +const char ActivityScreenshotKeyword [] = "screenshot"; class HsActivityDbClientInterface { public: - + /** * Function save provided avtivity in activity storage * @param activity - activity to store - * @return 0 on succees, error code otherwise + * @return 0 on succees, error code otherwise */ virtual int addActivity(const QVariantHash &activity) =0; - + /** * Function update exiting activity * @param activity - filtering rules - * @return 0 on succees, error code otherwise + * @return 0 on succees, error code otherwise */ virtual int updateActivity(const QVariantHash &activity) =0; - + /** * Function delete activity * @param activity - filtering rules - * @return 0 on succees, error code otherwise + * @return 0 on succees, error code otherwise */ virtual int removeActivity(const QVariantHash &activity) =0; - + /** * Function delete activity for application * @param activity - filtering rules - * @return 0 on succees, error code otherwise + * @return 0 on succees, error code otherwise */ virtual int removeApplicationActivities(const QVariantHash &activity) =0; - + /** * Function return list of all activity * @param result - destination list - * @return 0 on succees, error code otherwise + * @return 0 on succees, error code otherwise */ virtual int activities(QList& result) =0; - + /** * Function return list of all activity * @param result - destination list, * @param activity - filtering rules - * @return 0 on succees, error code otherwise + * @return 0 on succees, error code otherwise */ - virtual int applicationActivities(QList& result, + virtual int applicationActivities(QList& result, const QVariantHash &activity) =0; - + /** * Function subscribe to activity * @param activity - filtering rules - * @return 0 on succees, error code otherwise + * @return 0 on succees, error code otherwise */ virtual int waitActivity(const QVariantHash &activity)=0; - + /** * Function launch application activity - * @param activity - filtering rules - * @return 0 on succees, error code otherwise + * @param activity - filtering rules + * @return 0 on succees, error code otherwise */ virtual int launchActivity(const QVariantHash &activity)=0; }; diff -r a6d55a2e75be -r 782e3408c2ab activityfw/activitydatabase/s60/inc/hsactivityglobals.h --- a/activityfw/activitydatabase/s60/inc/hsactivityglobals.h Fri Mar 26 13:00:55 2010 +0200 +++ b/activityfw/activitydatabase/s60/inc/hsactivityglobals.h Fri Apr 16 14:45:49 2010 +0300 @@ -19,8 +19,8 @@ #include const TUid KActivityServerUid = {0x200267B4}; -_LIT( KActivityServerName, "hsactivitydbserver" ); -_LIT( KErr400, "Bad Reqest" ); -_LIT( KErr403, "Access denied" ); +_LIT(KActivityServerName, "hsactivitydbserver"); +_LIT(KErr400, "Bad Reqest"); +_LIT(KErr403, "Access denied"); #endif diff -r a6d55a2e75be -r 782e3408c2ab activityfw/activitydatabase/s60/inc/hsserializer.h --- a/activityfw/activitydatabase/s60/inc/hsserializer.h Fri Mar 26 13:00:55 2010 +0200 +++ b/activityfw/activitydatabase/s60/inc/hsserializer.h Fri Apr 16 14:45:49 2010 +0300 @@ -11,30 +11,40 @@ * * Contributors: * -* Description: +* Description: * */ #ifndef HSSERIALIZER_H #define HSSERIALIZER_H #include +#include +/** + * Operator serialize QPixmap to RBuf8 + */ +RBuf8 &operator <<(RBuf8 &dst, const QPixmap &src); + +/** + * Operator deserialize TDesc8 to QPixmap + */ +QPixmap &operator <<(QPixmap &dst, const TDesC8 &src); /** * Operator serialize VarinatHash to RBuf8 */ -RBuf8& operator <<(RBuf8& dst, const QVariantHash& src); +RBuf8 &operator <<(RBuf8 &dst, const QVariantHash &src); /** * Operator deserialize RBuf8 to VarinatHash */ -QVariantHash& operator <<(QVariantHash& dst, const TDesC8& src); +QVariantHash &operator <<(QVariantHash &dst, const TDesC8 &src); /** * Operator serialize QList to RBuf8 */ -RBuf8& operator <<(RBuf8& dst, const QList& src); +RBuf8 &operator <<(RBuf8 &dst, const QList& src); /** * Operator deserialize RBuf8 to QList */ -QList& operator <<(QList& dst, const TDesC8& src); +QList& operator <<(QList& dst, const TDesC8 &src); #endif diff -r a6d55a2e75be -r 782e3408c2ab activityfw/activitydatabase/s60/src/hsserializer.cpp --- a/activityfw/activitydatabase/s60/src/hsserializer.cpp Fri Mar 26 13:00:55 2010 +0200 +++ b/activityfw/activitydatabase/s60/src/hsserializer.cpp Fri Apr 16 14:45:49 2010 +0300 @@ -11,7 +11,7 @@ * * Contributors: * -* Description: +* Description: * */ #include "hsserializer.h" @@ -20,15 +20,15 @@ // // ----------------------------------------------------------------------------- // -RBuf8& operator <<(RBuf8& dst, const QVariantHash& src) +RBuf8 &operator <<(RBuf8 &dst, const QPixmap &src) { QByteArray buffer; QDataStream stream(&buffer, QIODevice::WriteOnly); - + QT_TRYCATCH_LEAVING(stream << src); const int dataLength(buffer.length()); - const unsigned char* dataPtr(reinterpret_cast(buffer.constData())); - if( dst.MaxLength() < dataLength ) { + const unsigned char *dataPtr(reinterpret_cast(buffer.constData())); + if (dst.MaxLength() < dataLength) { dst.ReAllocL(dataLength); } dst.Copy(dataPtr, dataLength); @@ -39,11 +39,11 @@ // // ----------------------------------------------------------------------------- // -QVariantHash& operator <<(QVariantHash& dst, const TDesC8& src) +QPixmap &operator <<(QPixmap &dst, const TDesC8 &src) { - QByteArray buffer( QByteArray::fromRawData(reinterpret_cast(src.Ptr()), - src.Length()) ); - + QByteArray buffer(QByteArray::fromRawData(reinterpret_cast(src.Ptr()), + src.Length()) ); + QDataStream stream(&buffer, QIODevice::ReadOnly); QT_TRYCATCH_LEAVING(stream >> dst); return dst; @@ -53,17 +53,18 @@ // // ----------------------------------------------------------------------------- // -RBuf8& operator <<(RBuf8& dst, const QList& src) +RBuf8 &operator <<(RBuf8 &dst, const QVariantHash &src) { QByteArray buffer; QDataStream stream(&buffer, QIODevice::WriteOnly); - + QT_TRYCATCH_LEAVING(stream << src); - - if( dst.MaxLength() < buffer.length() ) { - dst.ReAllocL(buffer.length()); + const int dataLength(buffer.length()); + const unsigned char *dataPtr(reinterpret_cast(buffer.constData())); + if (dst.MaxLength() < dataLength) { + dst.ReAllocL(dataLength); } - dst.Copy(reinterpret_cast(buffer.data()), buffer.length()); + dst.Copy(dataPtr, dataLength); return dst; } @@ -71,12 +72,44 @@ // // ----------------------------------------------------------------------------- // -QList& operator <<(QList& dst, const TDesC8& src) +QVariantHash &operator <<(QVariantHash &dst, const TDesC8 &src) { - QByteArray buffer(QByteArray::fromRawData(reinterpret_cast(src.Ptr()), - src.Length())); - + QByteArray buffer(QByteArray::fromRawData(reinterpret_cast(src.Ptr()), + src.Length()) ); + QDataStream stream(&buffer, QIODevice::ReadOnly); QT_TRYCATCH_LEAVING(stream >> dst); return dst; } + +// ----------------------------------------------------------------------------- +// +// ----------------------------------------------------------------------------- +// +RBuf8 &operator <<(RBuf8 &dst, const QList& src) +{ + QByteArray buffer; + QDataStream stream(&buffer, QIODevice::WriteOnly); + + QT_TRYCATCH_LEAVING(stream << src); + + if (dst.MaxLength() < buffer.length()) { + dst.ReAllocL(buffer.length()); + } + dst.Copy(reinterpret_cast(buffer.data()), buffer.length()); + return dst; +} + +// ----------------------------------------------------------------------------- +// +// ----------------------------------------------------------------------------- +// +QList& operator <<(QList& dst, const TDesC8 &src) +{ + QByteArray buffer(QByteArray::fromRawData(reinterpret_cast(src.Ptr()), + src.Length())); + + QDataStream stream(&buffer, QIODevice::ReadOnly); + QT_TRYCATCH_LEAVING(stream >> dst); + return dst; +} diff -r a6d55a2e75be -r 782e3408c2ab activityfw/activityfw.pro --- a/activityfw/activityfw.pro Fri Mar 26 13:00:55 2010 +0200 +++ b/activityfw/activityfw.pro Fri Apr 16 14:45:49 2010 +0300 @@ -21,7 +21,6 @@ symbian:SUBDIRS += activitydatabase SUBDIRS += activityserviceplugin \ - activitylauncher \ orbitintegration/hbactivityplugin diff -r a6d55a2e75be -r 782e3408c2ab activityfw/activitylauncher/activitylauncherview.cpp --- a/activityfw/activitylauncher/activitylauncherview.cpp Fri Mar 26 13:00:55 2010 +0200 +++ b/activityfw/activitylauncher/activitylauncherview.cpp Fri Apr 16 14:45:49 2010 +0300 @@ -11,7 +11,7 @@ * * Contributors: * -* Description: +* Description: * */ #include "activitylauncherview.h" @@ -35,25 +35,25 @@ { QServiceManager serviceManager; mActivityManager = serviceManager.loadInterface("com.nokia.qt.activities.ActivityManager"); - + if (!mActivityManager) { qFatal("Cannot initialize critical com.nokia.qt.activities.ActivityManager service"); } // create UI setTitle(tr("Activity launcher")); - QGraphicsLinearLayout* layout = new QGraphicsLinearLayout(Qt::Vertical); - QGraphicsLinearLayout* statusLayout = new QGraphicsLinearLayout(Qt::Horizontal); + QGraphicsLinearLayout *layout = new QGraphicsLinearLayout(Qt::Vertical); + QGraphicsLinearLayout *statusLayout = new QGraphicsLinearLayout(Qt::Horizontal); mStatusLabel = new HbLabel(this); mStatusLabel->setAlignment(Qt::AlignLeft); statusLayout->setMaximumHeight(15); - HbLabel* statusHeader = new HbLabel("Status: "); + HbLabel *statusHeader = new HbLabel("Status: "); statusHeader->setSizePolicy(QSizePolicy::Maximum, QSizePolicy::Maximum); statusLayout->addItem(statusHeader); statusLayout->addItem(mStatusLabel); - HbGridView* activities = new HbGridView(); + HbGridView *activities = new HbGridView(); connect(activities, SIGNAL(activated(QModelIndex)), this, SLOT(itemPressed(QModelIndex))); activities->setRowCount(1); activities->setColumnCount(1); @@ -73,7 +73,7 @@ ActivityLauncherView::~ActivityLauncherView() { - delete mActivityManager; + delete mActivityManager; } void ActivityLauncherView::getActivitiesList() @@ -84,13 +84,13 @@ mModel->clear(); foreach(const QVariantHash& activityEntry, mCurrentActivities) { - QStandardItem* newItem = new QStandardItem(QIcon(activityEntry.value("screenshot").value()), QString("%1").arg(activityEntry.value(ActivityActivityKeyword).toInt())); + QStandardItem *newItem = new QStandardItem(QIcon(activityEntry.value("screenshot").value()), QString("%1").arg(activityEntry.value(ActivityActivityKeyword).toInt())); mModel->invisibleRootItem()->appendRow(newItem); } mStatusLabel->setPlainText(QString("Ready (%1 activities)").arg(mCurrentActivities.count())); } -bool ActivityLauncherView::eventFilter(QObject* obj, QEvent* event) +bool ActivityLauncherView::eventFilter(QObject *obj, QEvent *event) { if (event->type() == QEvent::ApplicationActivate) { getActivitiesList(); @@ -98,7 +98,7 @@ return QObject::eventFilter(obj, event); } -void ActivityLauncherView::itemPressed(const QModelIndex& index) +void ActivityLauncherView::itemPressed(const QModelIndex &index) { QVariantHash activity = mCurrentActivities.at(index.row()); int applicationId = activity.value(ActivityApplicationKeyword).toInt(); diff -r a6d55a2e75be -r 782e3408c2ab activityfw/activitylauncher/activitylauncherview.h --- a/activityfw/activitylauncher/activitylauncherview.h Fri Mar 26 13:00:55 2010 +0200 +++ b/activityfw/activitylauncher/activitylauncherview.h Fri Apr 16 14:45:49 2010 +0300 @@ -11,7 +11,7 @@ * * Contributors: * -* Description: +* Description: * */ #ifndef ACTIVITYLAUNCHERVIEW_H @@ -22,7 +22,7 @@ class HbLabel; class QStandardItemModel; - + class ActivityLauncherView : public HbView { Q_OBJECT @@ -32,20 +32,20 @@ ~ActivityLauncherView(); private slots: - void itemPressed(const QModelIndex& index); + void itemPressed(const QModelIndex &index); protected: - bool eventFilter(QObject* obj, QEvent* event); + bool eventFilter(QObject *obj, QEvent *event); private: void getActivitiesList(); private: - QStandardItemModel* mModel; + QStandardItemModel *mModel; QList mCurrentActivities; - HbLabel* mStatusLabel; - - QObject* mActivityManager; + HbLabel *mStatusLabel; + + QObject *mActivityManager; }; #endif // ACTIVITYLAUNCHERVIEW_H diff -r a6d55a2e75be -r 782e3408c2ab activityfw/activitylauncher/main.cpp --- a/activityfw/activitylauncher/main.cpp Fri Mar 26 13:00:55 2010 +0200 +++ b/activityfw/activitylauncher/main.cpp Fri Apr 16 14:45:49 2010 +0300 @@ -11,7 +11,7 @@ * * Contributors: * -* Description: +* Description: * */ @@ -24,12 +24,12 @@ int main(int argc, char *argv[]) { - HbApplication app(argc, argv); + HbApplication app(argc, argv); HbMainWindow mainWindow; ActivityLauncherView mainView; mainWindow.addView(&mainView); mainWindow.show(); - return app.exec(); + return app.exec(); } diff -r a6d55a2e75be -r 782e3408c2ab activityfw/activityserviceplugin/activityclient.cpp --- a/activityfw/activityserviceplugin/activityclient.cpp Fri Mar 26 13:00:55 2010 +0200 +++ b/activityfw/activityserviceplugin/activityclient.cpp Fri Apr 16 14:45:49 2010 +0300 @@ -11,7 +11,7 @@ * * Contributors: * -* Description: +* Description: * */ @@ -55,3 +55,8 @@ { return d_ptr->waitActivity(); } + +QVariantHash ActivityClient::parseCommandLine(const QStringList &commandLineParams) const +{ + return d_ptr->parseCommandLine(commandLineParams); +} diff -r a6d55a2e75be -r 782e3408c2ab activityfw/activityserviceplugin/activityclient.h --- a/activityfw/activityserviceplugin/activityclient.h Fri Mar 26 13:00:55 2010 +0200 +++ b/activityfw/activityserviceplugin/activityclient.h Fri Apr 16 14:45:49 2010 +0300 @@ -11,7 +11,7 @@ * * Contributors: * -* Description: +* Description: * */ #ifndef ACTIVITYCLIENT_H @@ -26,7 +26,7 @@ class ActivityClient : public QObject { -Q_OBJECT + Q_OBJECT public: ActivityClient(QObject *parent = 0); @@ -39,14 +39,15 @@ QList activities() const; QVariant activityData(const QString &activityId) const; bool waitActivity(); + QVariantHash parseCommandLine(const QStringList &commandLineParams) const; signals: void activityRequested(const QString &activityId); - + private: ActivityClientPrivate *d_ptr; friend class ActivityClientPrivate; - + }; #endif // ACTIVITYCLIENT_H diff -r a6d55a2e75be -r 782e3408c2ab activityfw/activityserviceplugin/activityclient_p.cpp --- a/activityfw/activityserviceplugin/activityclient_p.cpp Fri Mar 26 13:00:55 2010 +0200 +++ b/activityfw/activityserviceplugin/activityclient_p.cpp Fri Apr 16 14:45:49 2010 +0300 @@ -11,7 +11,7 @@ * * Contributors: * -* Description: +* Description: * */ #include "activityclient_p.h" @@ -19,14 +19,18 @@ #include "activitydatastorage.h" #include +#include #include #include +#include +#include +#include -ActivityClientPrivate::ActivityClientPrivate(ActivityClient *q) : QObject(q) +ActivityClientPrivate::ActivityClientPrivate(ActivityClient *q) : QObject(q), isconnected(false) { mDataStorage = new ActivityDataStorage(); mServerClient = new HsActivityDbClient(); - mServerClient->connect(); + isconnected = ( KErrNone == mServerClient->connect()); connect(mServerClient, SIGNAL(activityRequested(QString)), q, SIGNAL(activityRequested(QString))); } @@ -38,66 +42,118 @@ bool ActivityClientPrivate::addActivity(const QString &activityId, const QVariant &data, const QVariantHash ¶meters) { - QVariantHash activity(parameters); - mDataStorage->addActivity(activityId, data); - RProcess process; - - activity.insert(ActivityApplicationKeyword, static_cast(process.SecureId().iId)); - activity.insert(ActivityActivityKeyword, activityId); - mServerClient->addActivity(activity); - + if (isconnected) { + mDataStorage->addActivity(activityId, data); + QVariantHash activity(parameters); + RProcess process; + registerThumbnail(activityId, activity); + activity.insert(ActivityApplicationKeyword, static_cast(process.SecureId().iId)); + activity.insert(ActivityActivityKeyword, activityId); + mServerClient->addActivity(activity); + } // @todo make those operations atomic // @todo return real result - return true; + return isconnected; } bool ActivityClientPrivate::removeActivity(const QString &activityId) { - QVariantHash activity; - RProcess process; - activity.insert(ActivityApplicationKeyword, static_cast(process.SecureId().iId)); - activity.insert(ActivityActivityKeyword, activityId); - mDataStorage->removeActivity(activityId); - mServerClient->removeActivity(activity); + if (isconnected) { + mDataStorage->removeActivity(activityId); + QVariantHash activity; + RProcess process; + activity.insert(ActivityApplicationKeyword, static_cast(process.SecureId().iId)); + activity.insert(ActivityActivityKeyword, activityId); + mServerClient->removeActivity(activity); + } // @todo make those operations atomic // @todo return real result - return true; + return isconnected; } bool ActivityClientPrivate::updateActivity(const QString &activityId, const QVariant &data, const QVariantHash ¶meters) { - QVariantHash activity(parameters); - RProcess process; - activity.insert(ActivityApplicationKeyword, static_cast(process.SecureId().iId)); - activity.insert(ActivityActivityKeyword, activityId); - mDataStorage->updateActivity(activityId, data); - mServerClient->updateActivity(activity); + if (isconnected) { + mDataStorage->updateActivity(activityId, data); + QVariantHash activity(parameters); + RProcess process; + registerThumbnail(activityId, activity); + activity.insert(ActivityApplicationKeyword, static_cast(process.SecureId().iId)); + activity.insert(ActivityActivityKeyword, activityId); + mServerClient->updateActivity(activity); + } // @todo make those operations atomic // @todo return real result - return true; + return isconnected; } QList ActivityClientPrivate::activities() const { - QVariantHash activity; - RProcess process; - activity.insert(ActivityApplicationKeyword, static_cast(process.SecureId().iId)); - QList activities; - - mServerClient->applicationActivities(activities, activity); + if (isconnected) { + QVariantHash activity; + RProcess process; + activity.insert(ActivityApplicationKeyword, static_cast(process.SecureId().iId)); + mServerClient->applicationActivities(activities, activity); + } return activities; } QVariant ActivityClientPrivate::activityData(const QString &activityId) const { - return mDataStorage->activityData(activityId); + return isconnected ? mDataStorage->activityData(activityId) : QVariant(); } bool ActivityClientPrivate::waitActivity() { - RProcess process; - QVariantHash activity; - activity.insert(ActivityApplicationKeyword, static_cast(process.SecureId().iId)); - return !mServerClient->waitActivity(activity); + bool retVal(isconnected); + if (isconnected) { + RProcess process; + QVariantHash activity; + activity.insert(ActivityApplicationKeyword, static_cast(process.SecureId().iId)); + retVal = !mServerClient->waitActivity(activity); + } + return retVal; } + +QVariantHash ActivityClientPrivate::parseCommandLine(const QStringList &commandLineParams) const +{ + QVariantHash activityParams; + int activityMarkerIndex = commandLineParams.indexOf("-activity"); + if (activityMarkerIndex != -1 && commandLineParams.count() - 1 > activityMarkerIndex) { + QUrl activityUri(commandLineParams.at(activityMarkerIndex+1)); + if (activityUri.scheme() == "appto") { + QList > parameters = activityUri.queryItems(); + for (QList >::const_iterator i = parameters.constBegin(); i != parameters.constEnd(); ++i) { + activityParams.insert(i->first, i->second); + } + + if (activityParams.contains("activityname") && !activityParams.value("activityname").toString().isEmpty()) { + return activityParams; + } + } + } + return QVariantHash(); +} + +void ActivityClientPrivate::registerThumbnail(const QString &name, QVariantHash &activity) +{ + QVariantHash::const_iterator findIterator(activity.constFind(ActivityScreenshotKeyword)); + if (activity.constEnd() != findIterator && + findIterator.value().canConvert()) { + const QString thumbnailManagerName = thumbnailName(name); + if (findIterator.value().value().save(thumbnailManagerName)) { + activity.insert(ActivityScreenshotKeyword, thumbnailManagerName); + } else { + activity.remove(ActivityScreenshotKeyword); + } + } +} + +QString ActivityClientPrivate::thumbnailName(const QString &activityId) const +{ + return QDir::toNativeSeparators(qApp->applicationDirPath() + + "/" + + QString::number(qHash(activityId), 16) + + ".png"); +} diff -r a6d55a2e75be -r 782e3408c2ab activityfw/activityserviceplugin/activityclient_p.h --- a/activityfw/activityserviceplugin/activityclient_p.h Fri Mar 26 13:00:55 2010 +0200 +++ b/activityfw/activityserviceplugin/activityclient_p.h Fri Apr 16 14:45:49 2010 +0300 @@ -11,7 +11,7 @@ * * Contributors: * -* Description: +* Description: * */ #ifndef ACTIVITYCLIENT_P_H @@ -26,11 +26,10 @@ class ActivityDataStorage; class ActivityServerClient; class HsActivityDbClient; - -class ActivityClientPrivate : public QObject +class ActivityClientPrivate : public QObject { -Q_OBJECT + Q_OBJECT public: ActivityClientPrivate(ActivityClient *q); @@ -43,12 +42,16 @@ QList activities() const; QVariant activityData(const QString &activityId) const; bool waitActivity(); - - + QVariantHash parseCommandLine(const QStringList &commandLineParams) const; + private: - ActivityClient* q_ptr; - ActivityDataStorage* mDataStorage; - HsActivityDbClient* mServerClient; + void registerThumbnail(const QString &, QVariantHash&); + QString thumbnailName(const QString &) const; + +private: + ActivityDataStorage *mDataStorage; + HsActivityDbClient *mServerClient; + bool isconnected; }; #endif // ACTIVITYCLIENT_P_H diff -r a6d55a2e75be -r 782e3408c2ab activityfw/activityserviceplugin/activitydatastorage.cpp --- a/activityfw/activityserviceplugin/activitydatastorage.cpp Fri Mar 26 13:00:55 2010 +0200 +++ b/activityfw/activityserviceplugin/activitydatastorage.cpp Fri Apr 16 14:45:49 2010 +0300 @@ -11,7 +11,7 @@ * * Contributors: * -* Description: +* Description: * */ #include "activitydatastorage.h" @@ -28,9 +28,9 @@ QSqlDatabase database; if (QSqlDatabase::contains(KConnectionName)) { database = QSqlDatabase::database(KConnectionName); - } else { + } else { database = QSqlDatabase::addDatabase("QSQLITE", KConnectionName); - database.setDatabaseName("activitydatastorage.db"); + database.setDatabaseName("activitydatastorage.db"); if (!database.open()) { qFatal(qPrintable(database.lastError().text())); } @@ -49,13 +49,13 @@ bool ActivityDataStorage::addActivity(const QString &activityId, const QVariant &data) { QSqlDatabase database = QSqlDatabase::database(KConnectionName); - + QByteArray streamedData; { QDataStream stream(&streamedData, QIODevice::WriteOnly); stream << data; - } - + } + // insert data QSqlQuery query(database); if (!query.prepare("INSERT INTO Activities(Name, Data) VALUES(:Name, :Data)")) { @@ -67,8 +67,8 @@ if (!query.exec()) { qCritical(qPrintable(query.lastError().text())); return false; - } - + } + return true; } @@ -86,13 +86,13 @@ bool ActivityDataStorage::updateActivity(const QString &activityId, const QVariant &data) { QSqlDatabase database = QSqlDatabase::database(KConnectionName); - + QByteArray streamedData; { QDataStream stream(&streamedData, QIODevice::WriteOnly); stream << data; - } - + } + // update data QSqlQuery query(database); if (!query.prepare("UPDATE Activities SET Data = :Data WHERE Name = :Name")) { @@ -105,7 +105,7 @@ qCritical(qPrintable(query.lastError().text())); return false; } - + return query.numRowsAffected() > 0; } @@ -117,13 +117,13 @@ qCritical(qPrintable(query.lastError().text())); return QVariant(); } - + QVariant result; if (query.next()) { QByteArray data(query.value(0).toByteArray()); QDataStream stream(&data, QIODevice::ReadOnly); stream >> result; - } + } return result; } @@ -131,17 +131,17 @@ { QStringList expectedTables("Activities"); QStringList actualTables = QSqlDatabase::database(KConnectionName).tables(); - return (expectedTables == actualTables); + return (expectedTables == actualTables); } void ActivityDataStorage::recreateTables() { QSqlDatabase database = QSqlDatabase::database(KConnectionName); - + if (!database.transaction()) { qFatal(qPrintable(database.lastError().text())); } - + // drop any existing tables { QSqlQuery dropQuery(database); @@ -158,14 +158,14 @@ QString statement( "CREATE TABLE Activities(" "Name TEXT NOT NULL PRIMARY KEY UNIQUE," - "Data BLOB NOT NULL)"); - + "Data BLOB NOT NULL)"); + if (!createQuery.exec(statement)) { qFatal(qPrintable(createQuery.lastError().text())); } } - + if (!database.commit()) { qFatal(qPrintable(database.lastError().text())); - } + } } diff -r a6d55a2e75be -r 782e3408c2ab activityfw/activityserviceplugin/activitydatastorage.h --- a/activityfw/activityserviceplugin/activitydatastorage.h Fri Mar 26 13:00:55 2010 +0200 +++ b/activityfw/activityserviceplugin/activitydatastorage.h Fri Apr 16 14:45:49 2010 +0300 @@ -11,7 +11,7 @@ * * Contributors: * -* Description: +* Description: * */ #ifndef ACTIVITYDATASTORAGE_H @@ -20,23 +20,23 @@ #include #include -class ActivityDataStorage +class ActivityDataStorage { - + public: ActivityDataStorage(); ~ActivityDataStorage(); - + public: bool addActivity(const QString &activityId, const QVariant &data); bool removeActivity(const QString &activityId); bool updateActivity(const QString &activityId, const QVariant &data); QVariant activityData(const QString &activityId) const; - + private: bool checkTables(); void recreateTables(); - + }; #endif // ACTIVITYDATASTORAGE_H diff -r a6d55a2e75be -r 782e3408c2ab activityfw/activityserviceplugin/activitymanager.cpp --- a/activityfw/activityserviceplugin/activitymanager.cpp Fri Mar 26 13:00:55 2010 +0200 +++ b/activityfw/activityserviceplugin/activitymanager.cpp Fri Apr 16 14:45:49 2010 +0300 @@ -11,7 +11,7 @@ * * Contributors: * -* Description: +* Description: * */ @@ -26,27 +26,32 @@ { } -QList ActivityManager::activitiesList() -{ - return d_ptr->activitiesList(); +QList ActivityManager::activitiesList() +{ + return d_ptr->activitiesList(); } void ActivityManager::launchActivity(const QString &uri) -{ - d_ptr->launchActivity(uri); +{ + d_ptr->launchActivity(uri); } void ActivityManager::launchActivity(int applicationId, const QString &activityId) -{ +{ d_ptr->launchActivity(applicationId, activityId); } void ActivityManager::removeActivity(int applicationId, const QString &activityId) -{ +{ d_ptr->removeActivity(applicationId, activityId); } void ActivityManager::removeApplicationActivities(int applicationId) -{ +{ d_ptr->removeApplicationActivities(applicationId); } + +void ActivityManager::getThumbnail(const QString &thumbnailId, void *userData) +{ + d_ptr->getThumbnail(thumbnailId, userData); +} diff -r a6d55a2e75be -r 782e3408c2ab activityfw/activityserviceplugin/activitymanager.h --- a/activityfw/activityserviceplugin/activitymanager.h Fri Mar 26 13:00:55 2010 +0200 +++ b/activityfw/activityserviceplugin/activitymanager.h Fri Apr 16 14:45:49 2010 +0300 @@ -11,7 +11,7 @@ * * Contributors: * -* Description: +* Description: * */ #ifndef ACTIVITYMANAGER_H @@ -20,13 +20,14 @@ #include #include #include +#include class ActivityManagerPrivate; class ActivityManager : public QObject { -Q_OBJECT + Q_OBJECT public: ActivityManager(QObject *parent = 0); @@ -34,16 +35,19 @@ public slots: QList activitiesList(); - void launchActivity(const QString &uri); - void launchActivity(int applicationId, const QString &activityId); - void removeActivity(int applicationId, const QString &activityId); - void removeApplicationActivities(int applicationId); - + void launchActivity(const QString &uri); + void launchActivity(int applicationId, const QString &activityId); + void removeActivity(int applicationId, const QString &activityId); + void removeApplicationActivities(int applicationId); + void getThumbnail(const QString &thumbnailId, void * =0); + +signals: + void thumbnailReady(QPixmap, void *); + private: ActivityManagerPrivate *d_ptr; - + friend class ActivityManagerPrivate; - }; #endif // ACTIVITYMANAGER_H diff -r a6d55a2e75be -r 782e3408c2ab activityfw/activityserviceplugin/activitymanager_p.cpp --- a/activityfw/activityserviceplugin/activitymanager_p.cpp Fri Mar 26 13:00:55 2010 +0200 +++ b/activityfw/activityserviceplugin/activitymanager_p.cpp Fri Apr 16 14:45:49 2010 +0300 @@ -11,7 +11,7 @@ * * Contributors: * -* Description: +* Description: * */ #include "activitymanager_p.h" @@ -40,7 +40,7 @@ } void ActivityManagerPrivate::launchActivity(const QString &uri) -{ +{ // @todo use the same parser as in HbApplicationPrivate (if possible) QRegExp uriMatcher("^appto://(.+)\\?activityname=(.+)$"); if (uriMatcher.indexIn(uri) != -1) { @@ -48,15 +48,14 @@ Q_ASSERT(list.count() == 3); launchActivity(list.at(1).toInt(), list.at(2)); } else { - qWarning("Activity URI parsing error"); + qWarning("Activity URI parsing error"); } } void ActivityManagerPrivate::launchActivity(int applicationId, const QString &activityId) -{ - +{ ApplicationLauncher applicationLauncher; - if(applicationLauncher.isRunning(applicationId)) { + if (applicationLauncher.isRunning(applicationId)) { QVariantHash activity; activity.insert(ActivityApplicationKeyword, applicationId); activity.insert(ActivityActivityKeyword, activityId); @@ -68,7 +67,7 @@ } void ActivityManagerPrivate::removeActivity(int applicationId, const QString &activityId) -{ +{ QVariantHash activity; activity.insert(ActivityApplicationKeyword, applicationId); activity.insert(ActivityActivityKeyword, activityId); @@ -81,3 +80,10 @@ activity.insert(ActivityApplicationKeyword, applicationId); mServerClient->removeApplicationActivities(activity); } + +void ActivityManagerPrivate::getThumbnail(const QString &thumbnailId, void *userData) +{ + QPixmap ico; + mServerClient->getThumbnail(ico, thumbnailId); + emit q_ptr->thumbnailReady(ico, userData); +} diff -r a6d55a2e75be -r 782e3408c2ab activityfw/activityserviceplugin/activitymanager_p.h --- a/activityfw/activityserviceplugin/activitymanager_p.h Fri Mar 26 13:00:55 2010 +0200 +++ b/activityfw/activityserviceplugin/activitymanager_p.h Fri Apr 16 14:45:49 2010 +0300 @@ -11,7 +11,7 @@ * * Contributors: * -* Description: +* Description: * */ #ifndef ACTIVITYMANAGER_P_H @@ -28,7 +28,7 @@ class ActivityManagerPrivate : public QObject { -Q_OBJECT + Q_OBJECT public: ActivityManagerPrivate(ActivityManager *q); @@ -36,16 +36,15 @@ public slots: QList activitiesList(); - void launchActivity(const QString &uri); - void launchActivity(int applicationId, const QString &activityId); - void removeActivity(int applicationId, const QString &activityId); - void removeApplicationActivities(int applicationId); + void launchActivity(const QString &uri); + void launchActivity(int applicationId, const QString &activityId); + void removeActivity(int applicationId, const QString &activityId); + void removeApplicationActivities(int applicationId); + void getThumbnail(const QString &thumbnailId, void *); private: ActivityManager *q_ptr; HsActivityDbClient *mServerClient; - - }; #endif // ACTIVITYMANAGER_P_H diff -r a6d55a2e75be -r 782e3408c2ab activityfw/activityserviceplugin/activityserviceplugin.cpp --- a/activityfw/activityserviceplugin/activityserviceplugin.cpp Fri Mar 26 13:00:55 2010 +0200 +++ b/activityfw/activityserviceplugin/activityserviceplugin.cpp Fri Apr 16 14:45:49 2010 +0300 @@ -11,7 +11,7 @@ * * Contributors: * -* Description: +* Description: * */ @@ -24,14 +24,14 @@ #include "activityclient.h" #include "activitymanager.h" -QObject* ActivityServicePlugin::createInstance(const QServiceInterfaceDescriptor &descriptor, QServiceContext *context, QAbstractSecuritySession *session) +QObject *ActivityServicePlugin::createInstance(const QServiceInterfaceDescriptor &descriptor, QServiceContext *context, QAbstractSecuritySession *session) { Q_UNUSED(context); Q_UNUSED(session); if (descriptor.interfaceName() == "com.nokia.qt.activities.ActivityClient") { return new ActivityClient(); - } else if (descriptor.interfaceName() == "com.nokia.qt.activities.ActivityManager") { + } else if (descriptor.interfaceName() == "com.nokia.qt.activities.ActivityManager") { return new ActivityManager(); } else { return NULL; diff -r a6d55a2e75be -r 782e3408c2ab activityfw/activityserviceplugin/activityserviceplugin.h --- a/activityfw/activityserviceplugin/activityserviceplugin.h Fri Mar 26 13:00:55 2010 +0200 +++ b/activityfw/activityserviceplugin/activityserviceplugin.h Fri Apr 16 14:45:49 2010 +0300 @@ -11,7 +11,7 @@ * * Contributors: * -* Description: +* Description: * */ #ifndef ACTIVITYSERVICEPLUGIN_H @@ -26,10 +26,10 @@ { Q_OBJECT Q_INTERFACES(QtMobility::QServicePluginInterface) - + public: - QObject* createInstance(const QServiceInterfaceDescriptor &descriptor, QServiceContext *context, QAbstractSecuritySession *session); - + QObject *createInstance(const QServiceInterfaceDescriptor &descriptor, QServiceContext *context, QAbstractSecuritySession *session); + }; #endif //ACTIVITYSERVICEPLUGIN_H diff -r a6d55a2e75be -r 782e3408c2ab activityfw/activityserviceplugin/activityserviceplugin.pro --- a/activityfw/activityserviceplugin/activityserviceplugin.pro Fri Mar 26 13:00:55 2010 +0200 +++ b/activityfw/activityserviceplugin/activityserviceplugin.pro Fri Apr 16 14:45:49 2010 +0300 @@ -42,8 +42,11 @@ HEADERS += ./s60/applicationlauncher_p.h - LIBS += -lhsactivitydbclient \ - -lxqutils \ + LIBS += -lapparc \ + -lapgrfx \ + -lcone \ + -lhsactivitydbclient \ + -lxqutils } @@ -58,6 +61,8 @@ load(data_caging_paths) TARGET.EPOCALLOWDLLDATA = 1 TARGET.CAPABILITY = ALL -TCB + TARGET.UID3 = 0x200267B2 + plugin.sources = activityserviceplugin.dll plugin.path = $$QT_PLUGINS_BASE_DIR diff -r a6d55a2e75be -r 782e3408c2ab activityfw/activityserviceplugin/applicationlauncher.cpp --- a/activityfw/activityserviceplugin/applicationlauncher.cpp Fri Mar 26 13:00:55 2010 +0200 +++ b/activityfw/activityserviceplugin/applicationlauncher.cpp Fri Apr 16 14:45:49 2010 +0300 @@ -11,7 +11,7 @@ * * Contributors: * -* Description: +* Description: * */ diff -r a6d55a2e75be -r 782e3408c2ab activityfw/activityserviceplugin/applicationlauncher.h --- a/activityfw/activityserviceplugin/applicationlauncher.h Fri Mar 26 13:00:55 2010 +0200 +++ b/activityfw/activityserviceplugin/applicationlauncher.h Fri Apr 16 14:45:49 2010 +0300 @@ -11,7 +11,7 @@ * * Contributors: * -* Description: +* Description: * */ #ifndef APPLICATIONLAUNCHER_H @@ -27,15 +27,15 @@ public: ApplicationLauncher(); ~ApplicationLauncher(); - -public: + +public: bool isRunning(int applicationId); void startApplication(int applicationId, const QString &activityId); void bringToForeground(int applicationId); - -private: + +private: ApplicationLauncherPrivate *d_ptr; - + }; #endif // APPLICATIONLAUNCHER_H diff -r a6d55a2e75be -r 782e3408c2ab activityfw/activityserviceplugin/s60/activitydatabase_p.cpp --- a/activityfw/activityserviceplugin/s60/activitydatabase_p.cpp Fri Mar 26 13:00:55 2010 +0200 +++ b/activityfw/activityserviceplugin/s60/activitydatabase_p.cpp Fri Apr 16 14:45:49 2010 +0300 @@ -11,7 +11,7 @@ * * Contributors: * -* Description: +* Description: * */ @@ -34,13 +34,13 @@ { } -void ActivityDatabasePrivate::saveActivity(const QString &applicationName, const QString &activityName, const QVariantHash &activityMetadata) +void ActivityDatabasePrivate::saveActivity(const QString &applicationName, const QString &activityName, const QVariantHash &activityMetadata) { QVariantHash request(activityMetadata); request.insert(ActivityApplicationKeyword,applicationName); request.insert(ActivityActivityKeyword,activityName); mClient.saveActivity(request); - + } void ActivityDatabasePrivate::deleteActivity(const QString &applicationName, const QString &activityName) @@ -65,7 +65,7 @@ return retVal; } -QList ActivityDatabasePrivate::applicationActivitiesList(const QString & applicationName) +QList ActivityDatabasePrivate::applicationActivitiesList(const QString &applicationName) { QList result; QVariantHash request; diff -r a6d55a2e75be -r 782e3408c2ab activityfw/activityserviceplugin/s60/activitydatabase_p.h --- a/activityfw/activityserviceplugin/s60/activitydatabase_p.h Fri Mar 26 13:00:55 2010 +0200 +++ b/activityfw/activityserviceplugin/s60/activitydatabase_p.h Fri Apr 16 14:45:49 2010 +0300 @@ -11,7 +11,7 @@ * * Contributors: * -* Description: +* Description: * */ #ifndef ACTIVITYDATABASE_P_H @@ -20,24 +20,25 @@ #include #include #include -class ActivityDatabasePrivate { +class ActivityDatabasePrivate +{ public: ActivityDatabasePrivate(); ~ActivityDatabasePrivate(); - + public: - void saveActivity(const QString &applicationName, const QString &activityName, const QVariantHash &activityMetadata); + void saveActivity(const QString &applicationName, const QString &activityName, const QVariantHash &activityMetadata); void deleteActivity(const QString &applicationName, const QString &activityName); - void deleteApplicationActivities(const QString &applicationName); + void deleteApplicationActivities(const QString &applicationName); QList allActivitiesList(); - QList applicationActivitiesList(const QString &applicationName); + QList applicationActivitiesList(const QString &applicationName); QString requestedActivityName(const QString &applicationName); void setActivityRequestFlag(const QString &applicationName, const QString &activityName); void clearActivityRequestFlag(const QString &applicationName, const QString &activityName); - + private: - HsActivityDbClient mClient; + HsActivityDbClient mClient; }; #endif // ACTIVITYDATABASE_P_H diff -r a6d55a2e75be -r 782e3408c2ab activityfw/activityserviceplugin/s60/activityserverclient_p.cpp --- a/activityfw/activityserviceplugin/s60/activityserverclient_p.cpp Fri Mar 26 13:00:55 2010 +0200 +++ b/activityfw/activityserviceplugin/s60/activityserverclient_p.cpp Fri Apr 16 14:45:49 2010 +0300 @@ -11,7 +11,7 @@ * * Contributors: * -* Description: +* Description: * */ diff -r a6d55a2e75be -r 782e3408c2ab activityfw/activityserviceplugin/s60/activityserverclient_p.h --- a/activityfw/activityserviceplugin/s60/activityserverclient_p.h Fri Mar 26 13:00:55 2010 +0200 +++ b/activityfw/activityserviceplugin/s60/activityserverclient_p.h Fri Apr 16 14:45:49 2010 +0300 @@ -11,7 +11,7 @@ * * Contributors: * -* Description: +* Description: * */ #ifndef ACTIVITYSERVERCLIENT_P_H @@ -27,7 +27,7 @@ public: ActivityServerClientPrivate(); - + public: // API used by ActivityClient bool addActivity(const QString &activityId, const QVariantHash ¶meters); bool removeActivity(const QString &activityId); @@ -37,11 +37,11 @@ public: // API used by ActivityManager bool removeActivity(int applicationId, const QString &activityId); bool removeApplicationActivities(int applicationId); - QList activities(); - + QList activities(); + public: - ActivityServerClient* q_ptr; - + ActivityServerClient *q_ptr; + }; #endif // ACTIVITYSERVERCLIENT_P_H diff -r a6d55a2e75be -r 782e3408c2ab activityfw/activityserviceplugin/s60/applicationlauncher_p.cpp --- a/activityfw/activityserviceplugin/s60/applicationlauncher_p.cpp Fri Mar 26 13:00:55 2010 +0200 +++ b/activityfw/activityserviceplugin/s60/applicationlauncher_p.cpp Fri Apr 16 14:45:49 2010 +0300 @@ -11,14 +11,14 @@ * * Contributors: * -* Description: +* Description: * */ #include "applicationlauncher_p.h" #include #include -#include +#include #include #include @@ -32,33 +32,32 @@ void ApplicationLauncherPrivate::startApplication(int applicationId, const QString &activityId) { - QString actId = "\""+activityId+"\""; + QString actId = "\""+activityId+"\""; QString uri = QString("-activity appto://%1?activityname=%2").arg(uint(applicationId), 8, 16, QChar('0')).arg(actId); - - QT_TRAP_THROWING( - { - HBufC* uriAsDescriptor = XQConversions::qStringToS60Desc(uri); + + QT_TRAP_THROWING( { + HBufC *uriAsDescriptor = XQConversions::qStringToS60Desc(uri); CleanupStack::PushL(uriAsDescriptor); - + RApaLsSession apaLsSession; User::LeaveIfError(apaLsSession.Connect()); CleanupClosePushL(apaLsSession); - + TApaAppInfo appInfo; TInt retVal = apaLsSession.GetAppInfo(appInfo, TUid::Uid(applicationId)); - - if(retVal == KErrNone) { + + if (retVal == KErrNone) { RProcess application; User::LeaveIfError(application.Create(appInfo.iFullName, *uriAsDescriptor)); application.Resume(); } else { // @todo } - + CleanupStack::PopAndDestroy(&apaLsSession); CleanupStack::PopAndDestroy(uriAsDescriptor); } - ); + ); } void ApplicationLauncherPrivate::bringToForeground(int applicationId) diff -r a6d55a2e75be -r 782e3408c2ab activityfw/activityserviceplugin/s60/applicationlauncher_p.h --- a/activityfw/activityserviceplugin/s60/applicationlauncher_p.h Fri Mar 26 13:00:55 2010 +0200 +++ b/activityfw/activityserviceplugin/s60/applicationlauncher_p.h Fri Apr 16 14:45:49 2010 +0300 @@ -11,7 +11,7 @@ * * Contributors: * -* Description: +* Description: * */ #ifndef APPLICATIONLAUNCHER_P_H @@ -21,12 +21,12 @@ class ApplicationLauncherPrivate { - -public: + +public: bool isRunning(int applicationId); void startApplication(int applicationId, const QString &activityId); void bringToForeground(int applicationId); - + }; #endif // APPLICATIONLAUNCHER_P_H diff -r a6d55a2e75be -r 782e3408c2ab activityfw/activityserviceplugin/symbianinstaller/activityserviceinstaller/activityserviceinstaller.cpp --- a/activityfw/activityserviceplugin/symbianinstaller/activityserviceinstaller/activityserviceinstaller.cpp Fri Mar 26 13:00:55 2010 +0200 +++ b/activityfw/activityserviceplugin/symbianinstaller/activityserviceinstaller/activityserviceinstaller.cpp Fri Apr 16 14:45:49 2010 +0300 @@ -11,7 +11,7 @@ * * Contributors: * -* Description: +* Description: * */ @@ -26,9 +26,8 @@ QServiceManager manager; bool ok = manager.addService(":/activityserviceplugin.xml"); - if ( !ok ) - { - int err = manager.error(); - qFatal("%d ini", err); + if (!ok) { + int err = manager.error(); + qFatal("%d ini", err); } } diff -r a6d55a2e75be -r 782e3408c2ab activityfw/activityserviceplugin/win/activitydatabase_p.cpp --- a/activityfw/activityserviceplugin/win/activitydatabase_p.cpp Fri Mar 26 13:00:55 2010 +0200 +++ b/activityfw/activityserviceplugin/win/activitydatabase_p.cpp Fri Apr 16 14:45:49 2010 +0300 @@ -11,7 +11,7 @@ * * Contributors: * -* Description: +* Description: * */ #include "activitydatabase_p.h" @@ -38,14 +38,14 @@ QSqlDatabase database; if (QSqlDatabase::contains(KConnectionName)) { database = QSqlDatabase::database(KConnectionName); - } else { + } else { database = QSqlDatabase::addDatabase("QSQLITE", KConnectionName); - database.setDatabaseName(databaseFile); + database.setDatabaseName(databaseFile); if (!database.open()) { qFatal(qPrintable(database.lastError().text())); } - } - + } + if (!checkTables()) { recreateTables(); } @@ -56,30 +56,30 @@ QSqlDatabase::database(KConnectionName).close(); } -void ActivityDatabasePrivate::saveActivity(const QString &applicationName, const QString &activityName, const QVariantHash &activityMetadata) +void ActivityDatabasePrivate::saveActivity(const QString &applicationName, const QString &activityName, const QVariantHash &activityMetadata) { if (applicationName.isEmpty() || activityName.isEmpty() || activityMetadata.value("screenshot").isNull()) { qWarning("Activity entry is invalid, aborting save"); return; } - + QVariantHash activityData(activityMetadata); activityData.insert(ActivityApplicationKeyword, applicationName); - activityData.insert(ActivityActivityKeyword, activityName); - + activityData.insert(ActivityActivityKeyword, activityName); + // stream whole entry to bytearray QByteArray streamedData; { QDataStream stream(&streamedData, QIODevice::WriteOnly); stream << activityData; - } + } QSqlDatabase database = QSqlDatabase::database(KConnectionName); - + if (!database.transaction()) { qFatal(qPrintable(database.lastError().text())); } - + // update or insert data { QSqlQuery query(database); @@ -106,13 +106,13 @@ query.bindValue(":Data", streamedData); if (!query.exec()) { qFatal(qPrintable(query.lastError().text())); - } + } } } - + if (!database.commit()) { qFatal(qPrintable(database.lastError().text())); - } + } } void ActivityDatabasePrivate::deleteActivity(const QString &applicationName, const QString &activityName) @@ -143,13 +143,13 @@ return activitiesList(QString("SELECT Data FROM Activities WHERE ApplicationName = '%1'").arg(applicationName)); } -QList ActivityDatabasePrivate::activitiesList(const QString& sqlCommand) -{ +QList ActivityDatabasePrivate::activitiesList(const QString &sqlCommand) +{ QSqlQuery query(QSqlDatabase::database(KConnectionName)); if (!query.exec(sqlCommand)) { qFatal(qPrintable(query.lastError().text())); } - + QList result; while (query.next()) { QVariantHash activityEntry; @@ -159,7 +159,7 @@ stream >> activityEntry; } result.append(activityEntry); - } + } return result; } @@ -169,23 +169,23 @@ if (!query.exec(QString("SELECT ActivityName FROM Activities WHERE ApplicationName = '%1' AND RequestFlag").arg(applicationName))) { qFatal(qPrintable(query.lastError().text())); } - + QString result; if (query.next()) { result = query.value(0).toString(); - } + } return result; } void ActivityDatabasePrivate::setActivityRequestFlag(const QString &applicationName, const QString &activityName) { QSqlQuery query(QSqlDatabase::database(KConnectionName)); - + // clear old requests for given application if (!query.exec(QString("UPDATE Activities SET RequestFlag=0 WHERE ApplicationName = '%1'").arg(applicationName))) { qFatal(qPrintable(query.lastError().text())); } - + // set new request if (!query.exec(QString("UPDATE Activities SET RequestFlag=1 WHERE ApplicationName = '%1' AND ActivityName = '%2'").arg(applicationName).arg(activityName))) { qFatal(qPrintable(query.lastError().text())); @@ -206,17 +206,17 @@ { QStringList expectedTables("Activities"); QStringList actualTables = QSqlDatabase::database(KConnectionName).tables(); - return (expectedTables == actualTables); + return (expectedTables == actualTables); } void ActivityDatabasePrivate::recreateTables() { QSqlDatabase database = QSqlDatabase::database(KConnectionName); - + if (!database.transaction()) { qFatal(qPrintable(database.lastError().text())); } - + // drop any existing tables { QSqlQuery dropQuery(database); @@ -237,13 +237,13 @@ "RequestFlag BOOL NOT NULL DEFAULT FALSE," "Data BLOB NOT NULL," "PRIMARY KEY(ActivityName, ApplicationName))"); - + if (!createQuery.exec(statement)) { qFatal(qPrintable(createQuery.lastError().text())); } } - + if (!database.commit()) { qFatal(qPrintable(database.lastError().text())); - } + } } diff -r a6d55a2e75be -r 782e3408c2ab activityfw/activityserviceplugin/win/activitydatabase_p.h --- a/activityfw/activityserviceplugin/win/activitydatabase_p.h Fri Mar 26 13:00:55 2010 +0200 +++ b/activityfw/activityserviceplugin/win/activitydatabase_p.h Fri Apr 16 14:45:49 2010 +0300 @@ -11,7 +11,7 @@ * * Contributors: * -* Description: +* Description: * */ #ifndef ACTIVITYDATABASE_P_H @@ -20,29 +20,30 @@ #include #include -class ActivityDatabasePrivate { +class ActivityDatabasePrivate +{ public: ActivityDatabasePrivate(); ~ActivityDatabasePrivate(); - + public: - void saveActivity(const QString &applicationName, const QString &activityName, const QVariantHash &activityMetadata); + void saveActivity(const QString &applicationName, const QString &activityName, const QVariantHash &activityMetadata); void deleteActivity(const QString &applicationName, const QString &activityName); - void deleteApplicationActivities(const QString &applicationName); + void deleteApplicationActivities(const QString &applicationName); QList allActivitiesList(); - QList applicationActivitiesList(const QString &applicationName); + QList applicationActivitiesList(const QString &applicationName); QString requestedActivityName(const QString &applicationName); void setActivityRequestFlag(const QString &applicationName, const QString &activityName); void clearActivityRequestFlag(const QString &applicationName, const QString &activityName); private: - QList activitiesList(const QString& sqlCommand); - + QList activitiesList(const QString &sqlCommand); + private: bool checkTables(); void recreateTables(); - + }; #endif // ACTIVITYDATABASE_P_H diff -r a6d55a2e75be -r 782e3408c2ab activityfw/activityserviceplugin/win/applicationlauncher_p.cpp --- a/activityfw/activityserviceplugin/win/applicationlauncher_p.cpp Fri Mar 26 13:00:55 2010 +0200 +++ b/activityfw/activityserviceplugin/win/applicationlauncher_p.cpp Fri Apr 16 14:45:49 2010 +0300 @@ -11,7 +11,7 @@ * * Contributors: * -* Description: +* Description: * */ #include "applicationlauncher_p.h" diff -r a6d55a2e75be -r 782e3408c2ab activityfw/activityserviceplugin/win/applicationlauncher_p.h --- a/activityfw/activityserviceplugin/win/applicationlauncher_p.h Fri Mar 26 13:00:55 2010 +0200 +++ b/activityfw/activityserviceplugin/win/applicationlauncher_p.h Fri Apr 16 14:45:49 2010 +0300 @@ -11,7 +11,7 @@ * * Contributors: * -* Description: +* Description: * */ #ifndef APPLICATIONLAUNCHER_P_H @@ -21,12 +21,12 @@ class ApplicationLauncherPrivate { - -public: + +public: bool isRunning(int applicationId); void startApplication(int applicationId, const QString &activityId); void bringToForeground(int applicationId); - + }; #endif // APPLICATIONLAUNCHER_P_H diff -r a6d55a2e75be -r 782e3408c2ab activityfw/orbitintegration/hbactivityplugin/hbactivityplugin.cpp --- a/activityfw/orbitintegration/hbactivityplugin/hbactivityplugin.cpp Fri Mar 26 13:00:55 2010 +0200 +++ b/activityfw/orbitintegration/hbactivityplugin/hbactivityplugin.cpp Fri Apr 16 14:45:49 2010 +0300 @@ -11,7 +11,7 @@ * * Contributors: * -* Description: +* Description: * */ @@ -25,7 +25,7 @@ HbActivityPlugin::HbActivityPlugin(QObject *parent) : HbActivityPluginInterface(parent), mActivityClient(0) { QServiceManager serviceManager; - + if (serviceManager.findInterfaces("ActivityService").isEmpty()) { // clean old entries serviceManager.removeService("ActivityService"); @@ -35,11 +35,11 @@ } } - mActivityClient = serviceManager.loadInterface("com.nokia.qt.activities.ActivityClient"); + mActivityClient = serviceManager.loadInterface("com.nokia.qt.activities.ActivityClient"); if (!mActivityClient) { qWarning("Cannot initialize critical com.nokia.qt.activities.ActivityClient service."); } - + connect(mActivityClient, SIGNAL(activityRequested(QString)), this, SIGNAL(activityRequested(QString))); } @@ -51,11 +51,11 @@ bool HbActivityPlugin::addActivity(const QString &activityId, const QVariant &data, const QVariantHash ¶meters) { bool retVal(false); - QMetaObject::invokeMethod(mActivityClient, - "addActivity", - Q_RETURN_ARG(bool, retVal), - Q_ARG(QString, activityId), - Q_ARG(QVariant, data), + QMetaObject::invokeMethod(mActivityClient, + "addActivity", + Q_RETURN_ARG(bool, retVal), + Q_ARG(QString, activityId), + Q_ARG(QVariant, data), Q_ARG(QVariantHash, parameters)); return retVal; } @@ -63,9 +63,9 @@ bool HbActivityPlugin::removeActivity(const QString &activityId) { bool retVal(false); - QMetaObject::invokeMethod(mActivityClient, - "removeActivity", - Q_RETURN_ARG(bool, retVal), + QMetaObject::invokeMethod(mActivityClient, + "removeActivity", + Q_RETURN_ARG(bool, retVal), Q_ARG(QString, activityId)); return retVal; } @@ -73,9 +73,9 @@ bool HbActivityPlugin::updateActivity(const QString &activityId, const QVariant &data, const QVariantHash ¶meters) { bool retVal(false); - QMetaObject::invokeMethod(mActivityClient, - "updateActivity", - Q_RETURN_ARG(bool, retVal), + QMetaObject::invokeMethod(mActivityClient, + "updateActivity", + Q_RETURN_ARG(bool, retVal), Q_ARG(QString, activityId), Q_ARG(QVariant, data), Q_ARG(QVariantHash, parameters)); @@ -84,8 +84,8 @@ QList HbActivityPlugin::activities() { QList data; - QMetaObject::invokeMethod(mActivityClient, - "activities", + QMetaObject::invokeMethod(mActivityClient, + "activities", Q_RETURN_ARG(QList, data)); return data; } @@ -93,8 +93,8 @@ QVariant HbActivityPlugin::activityData(const QString &activityId) { QVariant data; - QMetaObject::invokeMethod(mActivityClient, - "activityData", + QMetaObject::invokeMethod(mActivityClient, + "activityData", Q_RETURN_ARG(QVariant, data), Q_ARG(QString, activityId)); return data; @@ -103,10 +103,20 @@ bool HbActivityPlugin::waitActivity() { bool retVal(false); - QMetaObject::invokeMethod(mActivityClient, - "waitActivity", + QMetaObject::invokeMethod(mActivityClient, + "waitActivity", Q_RETURN_ARG(bool, retVal)); return retVal; } -Q_EXPORT_PLUGIN2(hbactivityplugin, HbActivityPlugin) +QVariantHash HbActivityPlugin::parseCommandLine(const QStringList &commandLineParams) +{ + QVariantHash retVal; + QMetaObject::invokeMethod(mActivityClient, + "parseCommandLine", + Q_RETURN_ARG(QVariantHash, retVal), + Q_ARG(QStringList, commandLineParams)); + return retVal; +} + +Q_EXPORT_PLUGIN2(hbactivityplugin, HbActivityPlugin) diff -r a6d55a2e75be -r 782e3408c2ab activityfw/orbitintegration/hbactivityplugin/hbactivityplugin.h --- a/activityfw/orbitintegration/hbactivityplugin/hbactivityplugin.h Fri Mar 26 13:00:55 2010 +0200 +++ b/activityfw/orbitintegration/hbactivityplugin/hbactivityplugin.h Fri Apr 16 14:45:49 2010 +0300 @@ -11,7 +11,7 @@ * * Contributors: * -* Description: +* Description: * */ @@ -24,11 +24,11 @@ { Q_OBJECT Q_INTERFACES(HbActivityPluginInterface) - + public: HbActivityPlugin(QObject *parent = 0); ~HbActivityPlugin(); - + public: virtual bool addActivity(const QString &activityId, const QVariant &data, const QVariantHash ¶meters); virtual bool removeActivity(const QString &activityId); @@ -36,10 +36,11 @@ virtual QList activities(); virtual QVariant activityData(const QString &activityId); virtual bool waitActivity(); + virtual QVariantHash parseCommandLine(const QStringList &commandLineParams); private: QObject *mActivityClient; - + }; #endif //HBACTIVITYPLUGIN_H diff -r a6d55a2e75be -r 782e3408c2ab activityfw/orbitintegration/hbactivityplugin/hbactivityplugin.pro --- a/activityfw/orbitintegration/hbactivityplugin/hbactivityplugin.pro Fri Mar 26 13:00:55 2010 +0200 +++ b/activityfw/orbitintegration/hbactivityplugin/hbactivityplugin.pro Fri Apr 16 14:45:49 2010 +0300 @@ -34,7 +34,7 @@ pluginDep.sources = hbactivityplugin.dll pluginDep.path = $$QT_PLUGINS_BASE_DIR DEPLOYMENT += pluginDep - + TARGET.UID3 = 0x200267B1 TARGET.EPOCALLOWDLLDATA = 1 TARGET.CAPABILITY = ALL -TCB } diff -r a6d55a2e75be -r 782e3408c2ab activityfw/orbitintegration/hbactivityplugin/hbactivityplugininterface.h --- a/activityfw/orbitintegration/hbactivityplugin/hbactivityplugininterface.h Fri Mar 26 13:00:55 2010 +0200 +++ b/activityfw/orbitintegration/hbactivityplugin/hbactivityplugininterface.h Fri Apr 16 14:45:49 2010 +0300 @@ -11,7 +11,7 @@ * * Contributors: * -* Description: +* Description: * */ @@ -31,7 +31,7 @@ public: HbActivityPluginInterface(QObject *parent = 0) : QObject(parent) {} - + public: virtual bool addActivity(const QString &activityId, const QVariant &data, const QVariantHash ¶meters) = 0; virtual bool removeActivity(const QString &activityId) = 0; @@ -39,10 +39,11 @@ virtual QList activities() = 0; virtual QVariant activityData(const QString &activityId) = 0; virtual bool waitActivity() = 0; + virtual QVariantHash parseCommandLine(const QStringList &commandLineParams) = 0; signals: void activityRequested(const QString &activityId); - + }; Q_DECLARE_INTERFACE(HbActivityPluginInterface, "HbActivityPluginInterface/1.0") diff -r a6d55a2e75be -r 782e3408c2ab activityfw/rom/activitymanager_core.iby --- a/activityfw/rom/activitymanager_core.iby Fri Mar 26 13:00:55 2010 +0200 +++ b/activityfw/rom/activitymanager_core.iby Fri Apr 16 14:45:49 2010 +0300 @@ -21,10 +21,6 @@ file=ABI_DIR\BUILD_DIR\activityserviceplugin.dll SHARED_LIB_DIR\activityserviceplugin.dll data=\epoc32\data\z\resource\qt\plugins\activityserviceplugin.qtplugin resource\qt\plugins\activityserviceplugin.qtplugin -file=ABI_DIR\BUILD_DIR\activitylauncher.exe PROGRAMS_DIR\activitylauncher.exe -data=ZPRIVATE\10003a3f\import\apps\activitylauncher_reg.rsc private\10003a3f\import\apps\activitylauncher_reg.rsc -data=\epoc32\data\z\resource\apps\activitylauncher.rsc resource\apps\activitylauncher.rsc - file=ABI_DIR\BUILD_DIR\hsactivitydbserver.exe PROGRAMS_DIR\hsactivitydbserver.exe data=ZPRIVATE\10003a3f\import\apps\hsactivitydbserver_reg.rsc private\10003a3f\import\apps\hsactivitydbserver_reg.rsc data=\epoc32\data\z\resource\apps\hsactivitydbserver.rsc resource\apps\hsactivitydbserver.rsc diff -r a6d55a2e75be -r 782e3408c2ab activityfw/sis/activitymanager.pkg --- a/activityfw/sis/activitymanager.pkg Fri Mar 26 13:00:55 2010 +0200 +++ b/activityfw/sis/activitymanager.pkg Fri Apr 16 14:45:49 2010 +0300 @@ -31,10 +31,6 @@ "/epoc32/release/armv5/urel/activityserviceplugin.dll"-"!:\sys\bin\activityserviceplugin.dll" "/epoc32/data/z/resource/qt/plugins/activityserviceplugin.qtplugin"-"!:\resource\qt\plugins\activityserviceplugin.qtplugin" -"/epoc32/release/armv5/urel/activitylauncher.exe" - "!:\sys\bin\activitylauncher.exe" -"/epoc32/data/z/resource/apps/activitylauncher.rsc" - "!:\resource\apps\activitylauncher.rsc" -"/epoc32/data/z/private/10003a3f/import/apps/activitylauncher_reg.rsc" - "!:\private\10003a3f\import\apps\activitylauncher_reg.rsc" - "/epoc32/release/armv5/urel/hsactivitydbserver.exe" - "!:\sys\bin\hsactivitydbserver.exe" "/epoc32/data/z/resource/apps/hsactivitydbserver.rsc" - "!:\resource\apps\hsactivitydbserver.rsc" "/epoc32/data/z/private/10003a3f/import/apps/hsactivitydbserver_reg.rsc" - "!:\private\10003a3f\import\apps\hsactivitydbserver_reg.rsc" diff -r a6d55a2e75be -r 782e3408c2ab activityfw/sis/stubs/activitymanager_stub.pkg --- a/activityfw/sis/stubs/activitymanager_stub.pkg Fri Mar 26 13:00:55 2010 +0200 +++ b/activityfw/sis/stubs/activitymanager_stub.pkg Fri Apr 16 14:45:49 2010 +0300 @@ -32,14 +32,9 @@ ;Unique Vendor name :"Nokia" -;"" - "Z:\sys\bin\activityserviceinstaller.exe" "" - "Z:\sys\bin\activityserviceplugin.dll" "" - "Z:\resource\qt\plugins\activityserviceplugin.qtplugin" -"" - "Z:\sys\bin\activitylauncher.exe" -"" - "Z:\resource\apps\activitylauncher.rsc" -"" - "Z:\private\10003a3f\import\apps\activitylauncher_reg.rsc" - "" - "Z:\sys\bin\hsactivitydbserver.exe" "" - "Z:\resource\apps\hsactivitydbserver.rsc" "" - "Z:\private\10003a3f\import\apps\hsactivitydbserver_reg.rsc" diff -r a6d55a2e75be -r 782e3408c2ab activityfw/sis/stubs/activitymanager_stub.sis Binary file activityfw/sis/stubs/activitymanager_stub.sis has changed diff -r a6d55a2e75be -r 782e3408c2ab appfoundation/appfoundation.pro --- a/appfoundation/appfoundation.pro Fri Mar 26 13:00:55 2010 +0200 +++ b/appfoundation/appfoundation.pro Fri Apr 16 14:45:49 2010 +0300 @@ -16,11 +16,9 @@ TEMPLATE = subdirs -SUBDIRS+= servicemodel \ - statemodel \ +SUBDIRS+= statemodel \ appruntimemodel CONFIG += ordered tests:include(appfoundation_tests.pri) - diff -r a6d55a2e75be -r 782e3408c2ab appfoundation/appfoundation_tests.pri --- a/appfoundation/appfoundation_tests.pri Fri Mar 26 13:00:55 2010 +0200 +++ b/appfoundation/appfoundation_tests.pri Fri Apr 16 14:45:49 2010 +0300 @@ -14,7 +14,5 @@ # Description: # -SUBDIRS += ./appruntimemodel/tsrc \ - ./servicemodel/tsrc \ +SUBDIRS += ./appruntimemodel/tsrc \ ./statemodel/tsrc - diff -r a6d55a2e75be -r 782e3408c2ab bagetmodel/bagetmodel.pri --- a/bagetmodel/bagetmodel.pri Fri Mar 26 13:00:55 2010 +0200 +++ /dev/null Thu Jan 01 00:00:00 1970 +0000 @@ -1,26 +0,0 @@ -# -# 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: bagetmodel.pri -# - -HEADERS += ./inc/*.h - -SOURCES += ./src/*.cpp - -DEPENDPATH += . \ - inc \ - src - -INCLUDEPATH += . \ - inc diff -r a6d55a2e75be -r 782e3408c2ab bagetmodel/bagetmodel.pro --- a/bagetmodel/bagetmodel.pro Fri Mar 26 13:00:55 2010 +0200 +++ /dev/null Thu Jan 01 00:00:00 1970 +0000 @@ -1,27 +0,0 @@ -# -# 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: bagetmodel.pro -# - -TEMPLATE = lib - -include (../common.pri) - -symbian: { -TARGET.UID3 = 0x20027053 -} - -DEFINES += BAGETMODEL_LIB - -include(bagetmodel.pri) diff -r a6d55a2e75be -r 782e3408c2ab bagetmodel/inc/baget.h --- a/bagetmodel/inc/baget.h Fri Mar 26 13:00:55 2010 +0200 +++ /dev/null Thu Jan 01 00:00:00 1970 +0000 @@ -1,75 +0,0 @@ -/* -* 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: Base class for all bagets. -* -*/ - -#ifndef BAGET_H -#define BAGET_H - -#include - -#include "bagetmodel_global.h" - -enum BagetState -{ - BagetStateConstructed = 0, - BagetStateRunning, - BagetStateSuspended, - BagetStateStopped -}; - -class BagetPrivate; - -class BAGETMODEL_EXPORT Baget : public QGraphicsWidget -{ - Q_OBJECT - -public: - - Baget(QGraphicsItem *parent = 0, Qt::WindowFlags flags = 0); - virtual ~Baget(); - - BagetState currentState(); - -public slots: - - void start(); - void stop(); - void resume(); - void suspend(); - -signals: - - void faulted(); - -protected: - - virtual bool onStart() = 0; - virtual bool onStop() = 0; - virtual bool onResume(); - virtual bool onSuspend(); - -private: - - Q_DISABLE_COPY(Baget) - -private: - - BagetPrivate * const m_d; - friend class BagetPrivate; - -}; - -#endif // BAGET_H diff -r a6d55a2e75be -r 782e3408c2ab bagetmodel/inc/baget_p.h --- a/bagetmodel/inc/baget_p.h Fri Mar 26 13:00:55 2010 +0200 +++ /dev/null Thu Jan 01 00:00:00 1970 +0000 @@ -1,49 +0,0 @@ -/* -* 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: Private implementation of Baget. -* -*/ - -#ifndef BAGET_P_H -#define BAGET_P_H - -#include "baget.h" - -class BagetPrivate -{ - -public: - - BagetPrivate(Baget * const bagetPublic); - ~BagetPrivate(); - - void start(); - void stop(); - void resume(); - void suspend(); - - BagetState currentState(); - -private: - - Q_DISABLE_COPY(BagetPrivate) - -private: - - Baget *m_q; - BagetState mState; - -}; - -#endif // BAGET_P_H diff -r a6d55a2e75be -r 782e3408c2ab bagetmodel/inc/bagetfactory.h --- a/bagetmodel/inc/bagetfactory.h Fri Mar 26 13:00:55 2010 +0200 +++ /dev/null Thu Jan 01 00:00:00 1970 +0000 @@ -1,67 +0,0 @@ -/* -* 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: Baget factory. -* -*/ - -#ifndef BAGETFACTORY_H -#define BAGETFACTORY_H - -#include - -#include "ibagetprovider.h" -#include "bagetmodel_global.h" - -class QPluginLoader; - -class BAGETMODEL_EXPORT BagetPluginUnloader : public QObject -{ - Q_OBJECT - -public: - - BagetPluginUnloader(QPluginLoader *pluginLoader, QObject *parent = 0); - ~BagetPluginUnloader(); - -private: - - QPluginLoader *mPluginLoader; - -}; - -class BagetFactoryPrivate; - -class BAGETMODEL_EXPORT BagetFactory : public QObject -{ - Q_OBJECT - -public: - - BagetFactory(const QString& pluginDirectory, QObject *parent = 0); - virtual ~BagetFactory(); - - Baget *createBaget(const BagetToken &token); - -private: - - Q_DISABLE_COPY(BagetFactory) - -private: - - BagetFactoryPrivate *m_d; - friend class BagetFactoryPrivate; - -}; - -#endif // BAGETFACTORY_H diff -r a6d55a2e75be -r 782e3408c2ab bagetmodel/inc/bagetfactory_p.h --- a/bagetmodel/inc/bagetfactory_p.h Fri Mar 26 13:00:55 2010 +0200 +++ /dev/null Thu Jan 01 00:00:00 1970 +0000 @@ -1,45 +0,0 @@ -/* -* 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: Baget factory's private implementation. -* -*/ - -#ifndef BAGETFACTORY_P_H -#define BAGETFACTORY_P_H - -class BagetFactory; - -class BagetFactoryPrivate -{ - -public: - - BagetFactoryPrivate(const QString& pluginDirectory, - BagetFactory* bagetFactoryPublic); - ~BagetFactoryPrivate(); - - Baget *createBaget(const BagetToken &token); - -private: - - Q_DISABLE_COPY(BagetFactoryPrivate) - -public: - - BagetFactory *m_q; - QString mPluginDirectory; - -}; - -#endif // BAGETFACTORY_P_H diff -r a6d55a2e75be -r 782e3408c2ab bagetmodel/inc/bagetmodel_global.h --- a/bagetmodel/inc/bagetmodel_global.h Fri Mar 26 13:00:55 2010 +0200 +++ /dev/null Thu Jan 01 00:00:00 1970 +0000 @@ -1,34 +0,0 @@ -/* -* 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: bagetmodel_global.h -* -*/ - - -#ifndef BAGEMODEL_GLOBAL_H -#define BAGEMODEL_GLOBAL_H - -#include - -#ifdef BAGETMODEL_LIB - #define BAGETMODEL_EXPORT Q_DECL_EXPORT -#else - #ifdef BAGETMODEL_TEST - #define BAGETMODEL_EXPORT - #else - #define BAGETMODEL_EXPORT Q_DECL_IMPORT - #endif -#endif - -#endif // BAGEMODEL_GLOBAL_H diff -r a6d55a2e75be -r 782e3408c2ab bagetmodel/inc/ibagetprovider.h --- a/bagetmodel/inc/ibagetprovider.h Fri Mar 26 13:00:55 2010 +0200 +++ /dev/null Thu Jan 01 00:00:00 1970 +0000 @@ -1,88 +0,0 @@ -/* -* 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: Baget provider interface. -* -*/ - -#ifndef IBAGETPROVIDER_H -#define IBAGETPROVIDER_H - -#include -#include - -/*! - \class BagetToken - \brief Represents a Baget that can be created. - - Bagets are located in baget providers. Each provider - exposes its contained Bagets as baget tokens. A token has all - the needed information for Baget selection and creation. -*/ -class BagetToken -{ - -public: - - /*! - The name of the library/plugin that contains the Baget. - */ - QString mLibrary; - - /*! - Uniquely identifies the Baget. - */ - QString mUri; - -}; - -class Baget; - -/*! - \class IBagetProvider - \brief Defines a mechanism for retrieving a Baget. - - Interface that defines a mechanism for retrieving a Baget. - Each Baget provider implements this interface. -*/ -class IBagetProvider -{ - -public: - - /*! - Destructor. - */ - virtual ~IBagetProvider() {} - -public: - - /*! - Returns contained Bagets as a list of baget tokens. - \return Contained Bagets as tokens. - */ - virtual QList bagets() = 0; - - /*! - Creates and returns a Baget based on the given token. - \param token Identifies the Baget to be created. - \return The created Baget or null in failure cases. - */ - virtual Baget *createBaget(const BagetToken &token) = 0; - -}; - -Q_DECLARE_METATYPE(BagetToken) -Q_DECLARE_INTERFACE(IBagetProvider, "com.nokia.baget.ibagetprovider/1.0") - -#endif // IBAGETPROVIDER_H diff -r a6d55a2e75be -r 782e3408c2ab bagetmodel/src/baget.cpp --- a/bagetmodel/src/baget.cpp Fri Mar 26 13:00:55 2010 +0200 +++ /dev/null Thu Jan 01 00:00:00 1970 +0000 @@ -1,169 +0,0 @@ -/* -* 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: Base class for all bagets. -* -*/ - -#include "baget.h" -#include "baget_p.h" - -/*! - \enum BagetState - Lists states that the baget can be in. -*/ - -/* - \var BagetState BagetStateConstructed - Baget is in this state right after construction. -*/ - -/* - \var BagetState BagetStateRunning - Baget is performing regular operations (animations, etc.). - Baget is set to Running state after a call to start (if previously Constructed or Stopped) - or resume (if previously Suspended) methods. - \sa Baget::start() - \sa Baget::resume() -*/ - -/* - \var BagetState BagetStateSuspended - Baget operations are suspended (e.g. animation timers stopped). - Baget is set to Suspended after a call to suspend (if previously Running) method. - \sa Baget::suspend() -*/ - -/* - \var BagetState BagetStateStopped - Baget finished all processing and released all resources. - Baget is set to Stopped after a call to stop (if previously Running or Suspended) method. - \sa Baget::stop() -*/ - -/*! - \class Baget - \brief Base class for all Bagets. - - Baget (BAckGround widgET) is a widget intended to be displayed in the background - of an application view. It does not respond to user input. It usually performs some - animations to make the view more appealing. - Bagets are intended for use with HbStackedLayout as the bottom most QGraphicsWidget. - */ - -/*! - Constructs a new Baget with \a parent and \a flags. - */ -Baget::Baget(QGraphicsItem *parent, Qt::WindowFlags flags) : - QGraphicsWidget(parent, flags), m_d(new BagetPrivate(this)) -{ -} - -/*! - Destructs the class. - */ -Baget::~Baget() -{ - delete m_d; -} - -/*! - \fn void Baget::faulted() - - This signal is emitted if a fault occurs when changing Baget's state. - */ - -/*! - Returns the state that the Baget is currently in. - \return The current state. - */ -BagetState Baget::currentState() -{ - return m_d->currentState(); -} - -/*! - Initiates Baget's processing. - */ -void Baget::start() -{ - m_d->start(); -} - -/*! - Stops Baget's processing. - After this call Baget should also free all resources. - */ -void Baget::stop() -{ - m_d->stop(); -} - -/*! - Resumes Baget's processing. - */ -void Baget::resume() -{ - m_d->resume(); -} - -/*! - Suspends Baget's processing. - */ -void Baget::suspend() -{ - m_d->suspend(); -} - -/*! - \fn virtual bool Baget::onStart() = 0 - - After a call it should start Baget's processing. - Returns true if the operation secceeded, otherwise false - in this case - the faulted() signal will be emitted by the base class. - \return Indicates if the operation succeeded. - */ - -/*! - \fn virtual bool Baget::onStop() = 0 - - After a call it should stop Baget's processing and - free all resources. - Returns true if the operation secceeded, otherwise false - in this case - the faulted() signal will be emitted by the base class. - \return Indicates if the operation succeeded. - */ - -/*! - After a call it should resume Baget's processing. - Returns true if the operation secceeded, otherwise false - in this case - the faulted() signal will be emitted by the base class. - The default implementation does nothing and always returns true. - \return Indicates if the operation succeeded. - */ -bool Baget::onResume() -{ - return true; -} - -/*! - After a call it should suspend Baget's processing. - Returns true if the operation secceeded, otherwise false - in this case - the faulted() signal will be emitted by the base class. - The default implementation does nothing and always returns true. - \return Indicates if the operation succeeded. - */ -bool Baget::onSuspend() -{ - return true; -} diff -r a6d55a2e75be -r 782e3408c2ab bagetmodel/src/baget_p.cpp --- a/bagetmodel/src/baget_p.cpp Fri Mar 26 13:00:55 2010 +0200 +++ /dev/null Thu Jan 01 00:00:00 1970 +0000 @@ -1,129 +0,0 @@ -/* -* 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: Private implementation of Baget. -* -*/ - -#include "baget_p.h" - -/*! - \class BagetPrivate - \brief Private implementation of Baget. - */ - -/*! - Constructs a new BagetPrivate with \a bagetPublic. - */ -BagetPrivate::BagetPrivate(Baget * const bagetPublic) : - m_q(bagetPublic), mState(BagetStateConstructed) -{ -} - -/*! - Destructs the class. - */ -BagetPrivate::~BagetPrivate() -{ -} - -/*! - Manages Baget's start. - */ -void BagetPrivate::start() -{ - switch (mState) - { - case BagetStateConstructed: - case BagetStateStopped: - break; - - default: - return; - } - - mState = BagetStateRunning; - if (!m_q->onStart()) { - emit m_q->faulted(); - } -} - -/*! - Manages Baget's stop. - */ -void BagetPrivate::stop() -{ - switch (mState) - { - case BagetStateRunning: - case BagetStateSuspended: - break; - - default: - return; - } - - mState = BagetStateStopped; - if (!m_q->onStop()) { - emit m_q->faulted(); - } -} - -/*! - Manages Baget's resume. - */ -void BagetPrivate::resume() -{ - switch (mState) - { - case BagetStateSuspended: - break; - - default: - return; - } - - mState = BagetStateRunning; - if (!m_q->onResume()) { - emit m_q->faulted(); - } -} - -/*! - Manages Baget's suspend. - */ -void BagetPrivate::suspend() -{ - switch (mState) - { - case BagetStateRunning: - break; - - default: - return; - } - - mState = BagetStateSuspended; - if (!m_q->onSuspend()) { - emit m_q->faulted(); - } -} - -/*! - Returns Baget's current state. - \return The current state. - */ -BagetState BagetPrivate::currentState() -{ - return mState; -} diff -r a6d55a2e75be -r 782e3408c2ab bagetmodel/src/bagetfactory.cpp --- a/bagetmodel/src/bagetfactory.cpp Fri Mar 26 13:00:55 2010 +0200 +++ /dev/null Thu Jan 01 00:00:00 1970 +0000 @@ -1,174 +0,0 @@ -/* -* 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: Widget factory. -* -*/ - -#include -#include -#include -#include - -#include "bagetfactory.h" -#include "bagetfactory_p.h" -#include "baget.h" -#include "ibagetprovider.h" - -/*! - \class BagetPluginUnloader - \brief Unloads plugin and deletes plugin loader. - - Holds plugin loader instance and unloads and destroys plugin - on it's destructor. - */ - -/*! - Constructs a new BagetPluginUnloader with \a pluginLoader and \a parent. - */ -BagetPluginUnloader::BagetPluginUnloader(QPluginLoader *pluginLoader, QObject *parent) : - QObject(parent), mPluginLoader(pluginLoader) -{ -} - -/*! - Destructs the class. - */ -BagetPluginUnloader::~BagetPluginUnloader() -{ - if (mPluginLoader) { - mPluginLoader->unload(); - delete mPluginLoader; - } -} - -/*! - \class BagetFactoryPrivate - \brief Private implementation of the BagetFactory. - */ - -/*! - Constructs a new BagetFactoryPrivate with \a pluginDirectory and \a bagetFactoryPublic. - */ -BagetFactoryPrivate::BagetFactoryPrivate(const QString& pluginDirectory, - BagetFactory *bagetFactoryPublic) : - m_q(bagetFactoryPublic), mPluginDirectory(pluginDirectory) -{ -} - -/*! - Destructs the class. - */ -BagetFactoryPrivate::~BagetFactoryPrivate() -{ -} - -/*! - Creates and returns a Baget based on the given token. - \param token Identifies the Baget to be created. - \return The created Baget. - */ -Baget *BagetFactoryPrivate::createBaget(const BagetToken &token) -{ - QStringList pluginPaths; - - // check plugin dirs from root of different drives - QFileInfoList drives = QDir::drives(); - for(int i=0; i < drives.count(); i++) { - QFileInfo drive = drives.at(i); - QString driveLetter = drive.absolutePath(); - QString path = driveLetter + mPluginDirectory; - if (QDir(path).exists()) { - pluginPaths << path; - } - } - - // check plugin dir relative to current dir - if (QDir(mPluginDirectory).exists() && - !pluginPaths.contains(QDir(mPluginDirectory).absolutePath())) { - pluginPaths << mPluginDirectory; - } - - IBagetProvider *provider(0); - QPluginLoader *loader = new QPluginLoader(); - QObject *plugin(0); - - for(int i=0; i < pluginPaths.count(); i++) { - QString path = pluginPaths.at(i); - QString fileName = QDir(path).absoluteFilePath(token.mLibrary); - - loader->setFileName(fileName); - plugin = loader->instance(); - provider = qobject_cast(plugin); - if (provider) { - break; - } - } - - Baget *baget(0); - - if (provider) { - baget = provider->createBaget(token); - if (!baget) { - qWarning() << "Baget creation failed."; - qWarning() << token.mLibrary << "cannot provide" << token.mUri; - loader->unload(); - delete loader; - } else { - // unload plugin once baget gets deleted - BagetPluginUnloader *unloader = new BagetPluginUnloader(loader); - unloader->connect(baget, SIGNAL(destroyed()), SLOT(deleteLater())); - } - } else { - qDebug() << "Baget creation failed."; - qWarning() << token.mLibrary << "- provider not found"; - loader->unload(); - delete loader; - } - - return baget; -} - -/*! - \class BagetFactory - \brief Finds and creates baget widgets. - - Baget factory creates an instance of a Baget - based on a BagetToken that is given to it. - */ - -/*! - Constructs a new BagetFactory with \a pluginDirectory and \a parent. - */ -BagetFactory::BagetFactory(const QString& pluginDirectory, QObject *parent) : - QObject(parent), m_d(new BagetFactoryPrivate(pluginDirectory, this)) -{ -} - -/*! - Destructs the class. - */ -BagetFactory::~BagetFactory() -{ - delete m_d; -} - -/*! - Creates and returns a Baget based on the given token. - \param token Identifies the Baget to be created. - \return The created Baget. - */ -Baget* BagetFactory::createBaget(const BagetToken &token) -{ - return m_d->createBaget(token); -} diff -r a6d55a2e75be -r 782e3408c2ab common.pri --- a/common.pri Fri Mar 26 13:00:55 2010 +0200 +++ b/common.pri Fri Apr 16 14:45:49 2010 +0300 @@ -81,7 +81,6 @@ $$PWD/homescreensrv_plat/appruntimemodel_api \ $$PWD/homescreensrv_plat/contentstorage_api \ $$PWD/homescreensrv_plat/hswidgetmodel_api \ - $$PWD/homescreensrv_plat/servicemodel_api \ $$PWD/homescreensrv_plat/statemodel_api \ $$PWD/homescreensrv_plat/homescreen_information_api/inc } diff -r a6d55a2e75be -r 782e3408c2ab contentpublishingsrv/contentpublishingserver/cpserver/inc/cpserver.h --- a/contentpublishingsrv/contentpublishingserver/cpserver/inc/cpserver.h Fri Mar 26 13:00:55 2010 +0200 +++ b/contentpublishingsrv/contentpublishingserver/cpserver/inc/cpserver.h Fri Apr 16 14:45:49 2010 +0300 @@ -110,7 +110,7 @@ /** * Returns notifications array */ - RPointerArray& CCPServer::GetNotifications( ); + RPointerArray& GetNotifications( ); private: // From CActive diff -r a6d55a2e75be -r 782e3408c2ab contentpublishingsrv/contentpublishingutils/contentpublishingmap/src/cpliwmap.cpp --- a/contentpublishingsrv/contentpublishingutils/contentpublishingmap/src/cpliwmap.cpp Fri Mar 26 13:00:55 2010 +0200 +++ b/contentpublishingsrv/contentpublishingutils/contentpublishingmap/src/cpliwmap.cpp Fri Apr 16 14:45:49 2010 +0300 @@ -827,7 +827,7 @@ { TBool result( EFalse ); TInt pos( 0 ); - const TLiwGenericParam* paramForValue = iMap->FindFirst( pos, aProperty ); + iMap->FindFirst( pos, aProperty ); if ( pos != KErrNotFound ) { result = ETrue; diff -r a6d55a2e75be -r 782e3408c2ab contentstorage/bwins/caextendedmenuu.def --- a/contentstorage/bwins/caextendedmenuu.def Fri Mar 26 13:00:55 2010 +0200 +++ /dev/null Thu Jan 01 00:00:00 1970 +0000 @@ -1,3 +0,0 @@ -EXPORTS - ?GetItemIcon@CaMenuIconUtility@@SAPAVCAknIcon@@ABVCCaInnerEntry@@@Z @ 1 NONAME ; class CAknIcon * CaMenuIconUtility::GetItemIcon(class CCaInnerEntry const &) - diff -r a6d55a2e75be -r 782e3408c2ab contentstorage/bwins/camenuu.def --- a/contentstorage/bwins/camenuu.def Fri Mar 26 13:00:55 2010 +0200 +++ b/contentstorage/bwins/camenuu.def Fri Apr 16 14:45:49 2010 +0300 @@ -19,4 +19,6 @@ ?AddL@CCaStorageProxy@@QAEXPAVCCaInnerEntry@@H@Z @ 18 NONAME ; void CCaStorageProxy::AddL(class CCaInnerEntry *, int) ?CustomSortL@CCaStorageProxy@@QAEXABV?$RArray@H@@H@Z @ 19 NONAME ; void CCaStorageProxy::CustomSortL(class RArray const &, int) ?LoadDataBaseFromRomL@CCaStorageProxy@@QAEXXZ @ 20 NONAME ; void CCaStorageProxy::LoadDataBaseFromRomL(void) + ?NewL@CCaMmcWatcher@@SAPAV1@AAVRFs@@PAVMMmcWatcherCallback@@@Z @ 21 NONAME ; class CCaMmcWatcher * CCaMmcWatcher::NewL(class RFs &, class MMmcWatcherCallback *) + ?NewLC@CCaMmcWatcher@@SAPAV1@AAVRFs@@PAVMMmcWatcherCallback@@@Z @ 22 NONAME ; class CCaMmcWatcher * CCaMmcWatcher::NewLC(class RFs &, class MMmcWatcherCallback *) diff -r a6d55a2e75be -r 782e3408c2ab contentstorage/bwins/cautilsu.def --- a/contentstorage/bwins/cautilsu.def Fri Mar 26 13:00:55 2010 +0200 +++ b/contentstorage/bwins/cautilsu.def Fri Apr 16 14:45:49 2010 +0300 @@ -24,68 +24,76 @@ ?SetAttributeNameL@CCaLocalizationEntry@@QAEXABVTDesC16@@@Z @ 23 NONAME ; void CCaLocalizationEntry::SetAttributeNameL(class TDesC16 const &) ?GetCount@CCaInnerQuery@@QBEIXZ @ 24 NONAME ; unsigned int CCaInnerQuery::GetCount(void) const ?GetParentId@CCaInnerNotifierFilter@@QBEHXZ @ 25 NONAME ; int CCaInnerNotifierFilter::GetParentId(void) const - ?GetStringId@CCaLocalizationEntry@@QBEABVRBuf16@@XZ @ 26 NONAME ; class RBuf16 const & CCaLocalizationEntry::GetStringId(void) const - ?GetFlags@CCaInnerEntry@@QBEIXZ @ 27 NONAME ; unsigned int CCaInnerEntry::GetFlags(void) const - ?NewL@CCaEntryAttribute@@SAPAV1@ABVTDesC16@@@Z @ 28 NONAME ; class CCaEntryAttribute * CCaEntryAttribute::NewL(class TDesC16 const &) - ?SetParentId@CCaInnerNotifierFilter@@QAEXH@Z @ 29 NONAME ; void CCaInnerNotifierFilter::SetParentId(int) - ?SetFlagsOn@CCaInnerQuery@@QAEXI@Z @ 30 NONAME ; void CCaInnerQuery::SetFlagsOn(unsigned int) - ?SetTypeNames@CCaInnerNotifierFilter@@QAEXPAVCDesC16ArrayFlat@@@Z @ 31 NONAME ; void CCaInnerNotifierFilter::SetTypeNames(class CDesC16ArrayFlat *) - ?NewLC@CCaLocalizationEntry@@SAPAV1@XZ @ 32 NONAME ; class CCaLocalizationEntry * CCaLocalizationEntry::NewLC(void) - ?NewL@CCaInnerNotifierFilter@@SAPAV1@W4TNotifierType@1@@Z @ 33 NONAME ; class CCaInnerNotifierFilter * CCaInnerNotifierFilter::NewL(enum CCaInnerNotifierFilter::TNotifierType) - ?GetTableName@CCaLocalizationEntry@@QBEABVRBuf16@@XZ @ 34 NONAME ; class RBuf16 const & CCaLocalizationEntry::GetTableName(void) const - ?GetFlagsOff@CCaInnerQuery@@QBEIXZ @ 35 NONAME ; unsigned int CCaInnerQuery::GetFlagsOff(void) const - ?InternalizeL@CCaInnerEntry@@QAEXAAVRReadStream@@@Z @ 36 NONAME ; void CCaInnerEntry::InternalizeL(class RReadStream &) - ?GetAttributeName@CCaLocalizationEntry@@QBEABVRBuf16@@XZ @ 37 NONAME ; class RBuf16 const & CCaLocalizationEntry::GetAttributeName(void) const - ?GetTUint@MenuUtils@@SAHABVTDesC16@@AAI@Z @ 38 NONAME ; int MenuUtils::GetTUint(class TDesC16 const &, unsigned int &) - ?AddAttributeL@CCaInnerQuery@@QAEXABVTDesC16@@0@Z @ 39 NONAME ; void CCaInnerQuery::AddAttributeL(class TDesC16 const &, class TDesC16 const &) - ?Exist@RCaEntryAttrArray@@QAEHABVTDesC16@@@Z @ 40 NONAME ; int RCaEntryAttrArray::Exist(class TDesC16 const &) - ?AddAttributeL@CCaInnerEntry@@QAEXABVTDesC16@@0@Z @ 41 NONAME ; void CCaInnerEntry::AddAttributeL(class TDesC16 const &, class TDesC16 const &) - ?GetParentId@CCaInnerQuery@@QBEHXZ @ 42 NONAME ; int CCaInnerQuery::GetParentId(void) const - ?SetDescriptionL@CCaInnerEntry@@QAEXABVTDesC16@@@Z @ 43 NONAME ; void CCaInnerEntry::SetDescriptionL(class TDesC16 const &) - ?SetEntryRole@CCaInnerNotifierFilter@@QAEXW4TEntryRole@@@Z @ 44 NONAME ; void CCaInnerNotifierFilter::SetEntryRole(enum TEntryRole) - ?GetFlagsOn@CCaInnerQuery@@QBEIXZ @ 45 NONAME ; unsigned int CCaInnerQuery::GetFlagsOn(void) const - ?GetIconId@CCaInnerEntry@@QBEHXZ @ 46 NONAME ; int CCaInnerEntry::GetIconId(void) const - ?SetIconDataL@CCaInnerEntry@@QAEXABVTDesC16@@00@Z @ 47 NONAME ; void CCaInnerEntry::SetIconDataL(class TDesC16 const &, class TDesC16 const &, class TDesC16 const &) - ?GetEntryRole@CCaInnerNotifierFilter@@QBE?AW4TEntryRole@@XZ @ 48 NONAME ; enum TEntryRole CCaInnerNotifierFilter::GetEntryRole(void) const - ?GetId@CCaInnerEntry@@QBEHXZ @ 49 NONAME ; int CCaInnerEntry::GetId(void) const - ?SetEntryTypeNames@CCaInnerQuery@@QAEXPAVCDesC16ArrayFlat@@@Z @ 50 NONAME ; void CCaInnerQuery::SetEntryTypeNames(class CDesC16ArrayFlat *) - ?GetNotifierType@CCaInnerNotifierFilter@@QBE?AW4TNotifierType@1@XZ @ 51 NONAME ; enum CCaInnerNotifierFilter::TNotifierType CCaInnerNotifierFilter::GetNotifierType(void) const - ?ExternalizeL@CCaInnerEntry@@QBEXAAVRWriteStream@@@Z @ 52 NONAME ; void CCaInnerEntry::ExternalizeL(class RWriteStream &) const - ?SetRole@CCaInnerQuery@@QAEXH@Z @ 53 NONAME ; void CCaInnerQuery::SetRole(int) - ?GetIcon@CCaInnerEntry@@QBEABUTIconAttributes@1@XZ @ 54 NONAME ; struct CCaInnerEntry::TIconAttributes const & CCaInnerEntry::GetIcon(void) const - ?NewL@CCaLocalizationEntry@@SAPAV1@XZ @ 55 NONAME ; class CCaLocalizationEntry * CCaLocalizationEntry::NewL(void) - ?InternalizeL@CCaInnerNotifierFilter@@QAEXAAVRReadStream@@@Z @ 56 NONAME ; void CCaInnerNotifierFilter::InternalizeL(class RReadStream &) - ?InternalizeL@RCaIdsArray@@QAEXAAVRReadStream@@@Z @ 57 NONAME ; void RCaIdsArray::InternalizeL(class RReadStream &) - ?MarshalDataLC@RCaIdsArray@@QBEPAVHBufC8@@XZ @ 58 NONAME ; class HBufC8 * RCaIdsArray::MarshalDataLC(void) const - ?GetEntryTypeNames@CCaInnerQuery@@QBEPBVCDesC16ArrayFlat@@XZ @ 59 NONAME ; class CDesC16ArrayFlat const * CCaInnerQuery::GetEntryTypeNames(void) const - ?SetValueL@CCaEntryAttribute@@QAEXABVTDesC16@@@Z @ 60 NONAME ; void CCaEntryAttribute::SetValueL(class TDesC16 const &) - ?ExternalizeL@CCaInnerQuery@@QBEXAAVRWriteStream@@@Z @ 61 NONAME ; void CCaInnerQuery::ExternalizeL(class RWriteStream &) const - ?GetLocalizedString@CCaLocalizationEntry@@QBEABVRBuf16@@XZ @ 62 NONAME ; class RBuf16 const & CCaLocalizationEntry::GetLocalizedString(void) const - ?InternalizeL@CCaInnerQuery@@QAEXAAVRReadStream@@@Z @ 63 NONAME ; void CCaInnerQuery::InternalizeL(class RReadStream &) - ?NewLC@CCaEntryAttribute@@SAPAV1@ABVTDesC16@@@Z @ 64 NONAME ; class CCaEntryAttribute * CCaEntryAttribute::NewLC(class TDesC16 const &) - ?GetTypeNames@CCaInnerNotifierFilter@@QBEPAVCDesC16ArrayFlat@@XZ @ 65 NONAME ; class CDesC16ArrayFlat * CCaInnerNotifierFilter::GetTypeNames(void) const - ?NewL@CCaInnerEntry@@SAPAV1@XZ @ 66 NONAME ; class CCaInnerEntry * CCaInnerEntry::NewL(void) - ?SetRole@CCaInnerEntry@@QAEXI@Z @ 67 NONAME ; void CCaInnerEntry::SetRole(unsigned int) - ?NewLC@CCaInnerEntry@@SAPAV1@XZ @ 68 NONAME ; class CCaInnerEntry * CCaInnerEntry::NewLC(void) - ?SetTableNameL@CCaLocalizationEntry@@QAEXABVTDesC16@@@Z @ 69 NONAME ; void CCaLocalizationEntry::SetTableNameL(class TDesC16 const &) - ?GetAttributes@CCaInnerEntry@@QBEABVRCaEntryAttrArray@@XZ @ 70 NONAME ; class RCaEntryAttrArray const & CCaInnerEntry::GetAttributes(void) const - ?GetRowId@CCaLocalizationEntry@@QBEHXZ @ 71 NONAME ; int CCaLocalizationEntry::GetRowId(void) const - ?SetIdsL@CCaInnerQuery@@QAEXABV?$RArray@H@@@Z @ 72 NONAME ; void CCaInnerQuery::SetIdsL(class RArray const &) - ?SetFlagsOff@CCaInnerQuery@@QAEXI@Z @ 73 NONAME ; void CCaInnerQuery::SetFlagsOff(unsigned int) - ?RemoveAttributeL@CCaInnerEntry@@QAEXABVTDesC16@@@Z @ 74 NONAME ; void CCaInnerEntry::RemoveAttributeL(class TDesC16 const &) - ?GetRole@CCaInnerEntry@@QBEIXZ @ 75 NONAME ; unsigned int CCaInnerEntry::GetRole(void) const - ?GetIds@CCaInnerQuery@@QBEABV?$RArray@H@@XZ @ 76 NONAME ; class RArray const & CCaInnerQuery::GetIds(void) const - ?ExternalizeL@RCaEntriesArray@@QBEXAAVRWriteStream@@@Z @ 77 NONAME ; void RCaEntriesArray::ExternalizeL(class RWriteStream &) const - ?NewL@CCaInnerQuery@@SAPAV1@XZ @ 78 NONAME ; class CCaInnerQuery * CCaInnerQuery::NewL(void) - ?SetUid@CCaInnerQuery@@QAEXI@Z @ 79 NONAME ; void CCaInnerQuery::SetUid(unsigned int) - ?GetDescription@CCaInnerEntry@@QBEABVRBuf16@@XZ @ 80 NONAME ; class RBuf16 const & CCaInnerEntry::GetDescription(void) const - ?GetRole@CCaInnerQuery@@QBEHXZ @ 81 NONAME ; int CCaInnerQuery::GetRole(void) const - ?GetEntryTypeName@CCaInnerEntry@@QBEABVRBuf16@@XZ @ 82 NONAME ; class RBuf16 const & CCaInnerEntry::GetEntryTypeName(void) const - ?NewLC@CCaInnerQuery@@SAPAV1@XZ @ 83 NONAME ; class CCaInnerQuery * CCaInnerQuery::NewLC(void) - ?SetTextL@CCaInnerEntry@@QAEXABVTDesC16@@@Z @ 84 NONAME ; void CCaInnerEntry::SetTextL(class TDesC16 const &) - ?SetParentId@CCaInnerQuery@@QAEXH@Z @ 85 NONAME ; void CCaInnerQuery::SetParentId(int) - ?GetIds@CCaInnerNotifierFilter@@QBE?AV?$RArray@H@@XZ @ 86 NONAME ; class RArray CCaInnerNotifierFilter::GetIds(void) const - ?SetStringIdL@CCaLocalizationEntry@@QAEXABVTDesC16@@@Z @ 87 NONAME ; void CCaLocalizationEntry::SetStringIdL(class TDesC16 const &) - ?SetTextId@CCaLocalizationEntry@@QAEXI@Z @ 88 NONAME ; void CCaLocalizationEntry::SetTextId(unsigned int) - ?RemoveAttribute@RCaEntryAttrArray@@QAEXABVTDesC16@@@Z @ 89 NONAME ; void RCaEntryAttrArray::RemoveAttribute(class TDesC16 const &) + ?SetId@CCaInnerIconDescription@@QAEXH@Z @ 26 NONAME ; void CCaInnerIconDescription::SetId(int) + ?GetStringId@CCaLocalizationEntry@@QBEABVRBuf16@@XZ @ 27 NONAME ; class RBuf16 const & CCaLocalizationEntry::GetStringId(void) const + ?GetFlags@CCaInnerEntry@@QBEIXZ @ 28 NONAME ; unsigned int CCaInnerEntry::GetFlags(void) const + ?NewL@CCaInnerIconDescription@@SAPAV1@XZ @ 29 NONAME ; class CCaInnerIconDescription * CCaInnerIconDescription::NewL(void) + ?NewL@CCaEntryAttribute@@SAPAV1@ABVTDesC16@@@Z @ 30 NONAME ; class CCaEntryAttribute * CCaEntryAttribute::NewL(class TDesC16 const &) + ?SetFileNameL@CCaInnerIconDescription@@QAEXABVTDesC16@@@Z @ 31 NONAME ; void CCaInnerIconDescription::SetFileNameL(class TDesC16 const &) + ?SetParentId@CCaInnerNotifierFilter@@QAEXH@Z @ 32 NONAME ; void CCaInnerNotifierFilter::SetParentId(int) + ?SetFlagsOn@CCaInnerQuery@@QAEXI@Z @ 33 NONAME ; void CCaInnerQuery::SetFlagsOn(unsigned int) + ?SetTypeNames@CCaInnerNotifierFilter@@QAEXPAVCDesC16ArrayFlat@@@Z @ 34 NONAME ; void CCaInnerNotifierFilter::SetTypeNames(class CDesC16ArrayFlat *) + ?NewLC@CCaLocalizationEntry@@SAPAV1@XZ @ 35 NONAME ; class CCaLocalizationEntry * CCaLocalizationEntry::NewLC(void) + ?NewL@CCaInnerNotifierFilter@@SAPAV1@W4TNotifierType@1@@Z @ 36 NONAME ; class CCaInnerNotifierFilter * CCaInnerNotifierFilter::NewL(enum CCaInnerNotifierFilter::TNotifierType) + ?GetTableName@CCaLocalizationEntry@@QBEABVRBuf16@@XZ @ 37 NONAME ; class RBuf16 const & CCaLocalizationEntry::GetTableName(void) const + ?GetFlagsOff@CCaInnerQuery@@QBEIXZ @ 38 NONAME ; unsigned int CCaInnerQuery::GetFlagsOff(void) const + ?InternalizeL@CCaInnerEntry@@QAEXAAVRReadStream@@@Z @ 39 NONAME ; void CCaInnerEntry::InternalizeL(class RReadStream &) + ?GetAttributeName@CCaLocalizationEntry@@QBEABVRBuf16@@XZ @ 40 NONAME ; class RBuf16 const & CCaLocalizationEntry::GetAttributeName(void) const + ?AddAttributeL@CCaInnerQuery@@QAEXABVTDesC16@@0@Z @ 41 NONAME ; void CCaInnerQuery::AddAttributeL(class TDesC16 const &, class TDesC16 const &) + ?GetTUint@MenuUtils@@SAHABVTDesC16@@AAI@Z @ 42 NONAME ; int MenuUtils::GetTUint(class TDesC16 const &, unsigned int &) + ?Exist@RCaEntryAttrArray@@QAEHABVTDesC16@@@Z @ 43 NONAME ; int RCaEntryAttrArray::Exist(class TDesC16 const &) + ?AddAttributeL@CCaInnerEntry@@QAEXABVTDesC16@@0@Z @ 44 NONAME ; void CCaInnerEntry::AddAttributeL(class TDesC16 const &, class TDesC16 const &) + ?GetParentId@CCaInnerQuery@@QBEHXZ @ 45 NONAME ; int CCaInnerQuery::GetParentId(void) const + ?SetDescriptionL@CCaInnerEntry@@QAEXABVTDesC16@@@Z @ 46 NONAME ; void CCaInnerEntry::SetDescriptionL(class TDesC16 const &) + ?SetEntryRole@CCaInnerNotifierFilter@@QAEXW4TEntryRole@@@Z @ 47 NONAME ; void CCaInnerNotifierFilter::SetEntryRole(enum TEntryRole) + ?GetFlagsOn@CCaInnerQuery@@QBEIXZ @ 48 NONAME ; unsigned int CCaInnerQuery::GetFlagsOn(void) const + ?GetIconId@CCaInnerEntry@@QBEHXZ @ 49 NONAME ; int CCaInnerEntry::GetIconId(void) const + ?SetIconDataL@CCaInnerEntry@@QAEXABVTDesC16@@00@Z @ 50 NONAME ; void CCaInnerEntry::SetIconDataL(class TDesC16 const &, class TDesC16 const &, class TDesC16 const &) + ?GetEntryRole@CCaInnerNotifierFilter@@QBE?AW4TEntryRole@@XZ @ 51 NONAME ; enum TEntryRole CCaInnerNotifierFilter::GetEntryRole(void) const + ?GetId@CCaInnerEntry@@QBEHXZ @ 52 NONAME ; int CCaInnerEntry::GetId(void) const + ?SetEntryTypeNames@CCaInnerQuery@@QAEXPAVCDesC16ArrayFlat@@@Z @ 53 NONAME ; void CCaInnerQuery::SetEntryTypeNames(class CDesC16ArrayFlat *) + ?GetNotifierType@CCaInnerNotifierFilter@@QBE?AW4TNotifierType@1@XZ @ 54 NONAME ; enum CCaInnerNotifierFilter::TNotifierType CCaInnerNotifierFilter::GetNotifierType(void) const + ?ExternalizeL@CCaInnerEntry@@QBEXAAVRWriteStream@@@Z @ 55 NONAME ; void CCaInnerEntry::ExternalizeL(class RWriteStream &) const + ?SetRole@CCaInnerQuery@@QAEXH@Z @ 56 NONAME ; void CCaInnerQuery::SetRole(int) + ?NewL@CCaLocalizationEntry@@SAPAV1@XZ @ 57 NONAME ; class CCaLocalizationEntry * CCaLocalizationEntry::NewL(void) + ?InternalizeL@CCaInnerNotifierFilter@@QAEXAAVRReadStream@@@Z @ 58 NONAME ; void CCaInnerNotifierFilter::InternalizeL(class RReadStream &) + ?InternalizeL@RCaIdsArray@@QAEXAAVRReadStream@@@Z @ 59 NONAME ; void RCaIdsArray::InternalizeL(class RReadStream &) + ?MarshalDataLC@RCaIdsArray@@QBEPAVHBufC8@@XZ @ 60 NONAME ; class HBufC8 * RCaIdsArray::MarshalDataLC(void) const + ?GetEntryTypeNames@CCaInnerQuery@@QBEPBVCDesC16ArrayFlat@@XZ @ 61 NONAME ; class CDesC16ArrayFlat const * CCaInnerQuery::GetEntryTypeNames(void) const + ?SetValueL@CCaEntryAttribute@@QAEXABVTDesC16@@@Z @ 62 NONAME ; void CCaEntryAttribute::SetValueL(class TDesC16 const &) + ?SetSkinIdL@CCaInnerIconDescription@@QAEXABVTDesC16@@@Z @ 63 NONAME ; void CCaInnerIconDescription::SetSkinIdL(class TDesC16 const &) + ?ExternalizeL@CCaInnerQuery@@QBEXAAVRWriteStream@@@Z @ 64 NONAME ; void CCaInnerQuery::ExternalizeL(class RWriteStream &) const + ?GetLocalizedString@CCaLocalizationEntry@@QBEABVRBuf16@@XZ @ 65 NONAME ; class RBuf16 const & CCaLocalizationEntry::GetLocalizedString(void) const + ?InternalizeL@CCaInnerQuery@@QAEXAAVRReadStream@@@Z @ 66 NONAME ; void CCaInnerQuery::InternalizeL(class RReadStream &) + ?NewLC@CCaEntryAttribute@@SAPAV1@ABVTDesC16@@@Z @ 67 NONAME ; class CCaEntryAttribute * CCaEntryAttribute::NewLC(class TDesC16 const &) + ?GetTypeNames@CCaInnerNotifierFilter@@QBEPAVCDesC16ArrayFlat@@XZ @ 68 NONAME ; class CDesC16ArrayFlat * CCaInnerNotifierFilter::GetTypeNames(void) const + ?NewL@CCaInnerEntry@@SAPAV1@XZ @ 69 NONAME ; class CCaInnerEntry * CCaInnerEntry::NewL(void) + ?SetRole@CCaInnerEntry@@QAEXI@Z @ 70 NONAME ; void CCaInnerEntry::SetRole(unsigned int) + ?NewLC@CCaInnerEntry@@SAPAV1@XZ @ 71 NONAME ; class CCaInnerEntry * CCaInnerEntry::NewLC(void) + ?SetTableNameL@CCaLocalizationEntry@@QAEXABVTDesC16@@@Z @ 72 NONAME ; void CCaLocalizationEntry::SetTableNameL(class TDesC16 const &) + ?GetAttributes@CCaInnerEntry@@QBEABVRCaEntryAttrArray@@XZ @ 73 NONAME ; class RCaEntryAttrArray const & CCaInnerEntry::GetAttributes(void) const + ?GetRowId@CCaLocalizationEntry@@QBEHXZ @ 74 NONAME ; int CCaLocalizationEntry::GetRowId(void) const + ?NewLC@CCaInnerIconDescription@@SAPAV1@XZ @ 75 NONAME ; class CCaInnerIconDescription * CCaInnerIconDescription::NewLC(void) + ?SetIdsL@CCaInnerQuery@@QAEXABV?$RArray@H@@@Z @ 76 NONAME ; void CCaInnerQuery::SetIdsL(class RArray const &) + ?SetFlagsOff@CCaInnerQuery@@QAEXI@Z @ 77 NONAME ; void CCaInnerQuery::SetFlagsOff(unsigned int) + ?Icon@CCaInnerEntry@@QBEPBVCCaInnerIconDescription@@XZ @ 78 NONAME ; class CCaInnerIconDescription const * CCaInnerEntry::Icon(void) const + ?SetApplicationIdL@CCaInnerIconDescription@@QAEXABVTDesC16@@@Z @ 79 NONAME ; void CCaInnerIconDescription::SetApplicationIdL(class TDesC16 const &) + ?RemoveAttributeL@CCaInnerEntry@@QAEXABVTDesC16@@@Z @ 80 NONAME ; void CCaInnerEntry::RemoveAttributeL(class TDesC16 const &) + ?GetRole@CCaInnerEntry@@QBEIXZ @ 81 NONAME ; unsigned int CCaInnerEntry::GetRole(void) const + ?GetIds@CCaInnerQuery@@QBEABV?$RArray@H@@XZ @ 82 NONAME ; class RArray const & CCaInnerQuery::GetIds(void) const + ?ExternalizeL@RCaEntriesArray@@QBEXAAVRWriteStream@@@Z @ 83 NONAME ; void RCaEntriesArray::ExternalizeL(class RWriteStream &) const + ?NewL@CCaInnerQuery@@SAPAV1@XZ @ 84 NONAME ; class CCaInnerQuery * CCaInnerQuery::NewL(void) + ?SetUid@CCaInnerQuery@@QAEXI@Z @ 85 NONAME ; void CCaInnerQuery::SetUid(unsigned int) + ?GetDescription@CCaInnerEntry@@QBEABVRBuf16@@XZ @ 86 NONAME ; class RBuf16 const & CCaInnerEntry::GetDescription(void) const + ?GetRole@CCaInnerQuery@@QBEHXZ @ 87 NONAME ; int CCaInnerQuery::GetRole(void) const + ?GetEntryTypeName@CCaInnerEntry@@QBEABVRBuf16@@XZ @ 88 NONAME ; class RBuf16 const & CCaInnerEntry::GetEntryTypeName(void) const + ?NewLC@CCaInnerQuery@@SAPAV1@XZ @ 89 NONAME ; class CCaInnerQuery * CCaInnerQuery::NewLC(void) + ?SetTextL@CCaInnerEntry@@QAEXABVTDesC16@@@Z @ 90 NONAME ; void CCaInnerEntry::SetTextL(class TDesC16 const &) + ?SetParentId@CCaInnerQuery@@QAEXH@Z @ 91 NONAME ; void CCaInnerQuery::SetParentId(int) + ?GetIds@CCaInnerNotifierFilter@@QBE?AV?$RArray@H@@XZ @ 92 NONAME ; class RArray CCaInnerNotifierFilter::GetIds(void) const + ?SetStringIdL@CCaLocalizationEntry@@QAEXABVTDesC16@@@Z @ 93 NONAME ; void CCaLocalizationEntry::SetStringIdL(class TDesC16 const &) + ?SetTextId@CCaLocalizationEntry@@QAEXI@Z @ 94 NONAME ; void CCaLocalizationEntry::SetTextId(unsigned int) + ?RemoveAttribute@RCaEntryAttrArray@@QAEXABVTDesC16@@@Z @ 95 NONAME ; void RCaEntryAttrArray::RemoveAttribute(class TDesC16 const &) + ?Find@RCaEntryAttrArray@@QAEHABVTDesC16@@AAVTPtrC16@@@Z @ 96 NONAME ; int RCaEntryAttrArray::Find(class TDesC16 const &, class TPtrC16 &) + ?FindAttribute@CCaInnerEntry@@QAEHABVTDesC16@@AAVTPtrC16@@@Z @ 97 NONAME ; int CCaInnerEntry::FindAttribute(class TDesC16 const &, class TPtrC16 &) diff -r a6d55a2e75be -r 782e3408c2ab contentstorage/caclient/caclient.pro --- a/contentstorage/caclient/caclient.pro Fri Mar 26 13:00:55 2010 +0200 +++ b/contentstorage/caclient/caclient.pro Fri Apr 16 14:45:49 2010 +0300 @@ -19,8 +19,6 @@ HB = hbcore MOBILITY = serviceframework -# temporary solution to solve problems with SF in MW dependency -qtAddLibrary(QtServiceFramework) DEFINES += CACLIENT_LIB @@ -44,17 +42,20 @@ ../extinc \ ../inc -LIBS += -lcautils \ - -lcaextendedmenu \ +LIBS += -lavkon \ + -lcautils \ -lestor \ -lbafl \ -laknicon \ -lcharconv \ -lfbscli \ -lbitgdi \ - -lxqutils + -lxqutils \ + -lsif \ + -lscrclient \ + -laknicon + include(caclient_s60.pri) -include(cahandler.pri) } win32: { diff -r a6d55a2e75be -r 782e3408c2ab contentstorage/caclient/cahandler.pri --- a/contentstorage/caclient/cahandler.pri Fri Mar 26 13:00:55 2010 +0200 +++ /dev/null Thu Jan 01 00:00:00 1970 +0000 @@ -1,41 +0,0 @@ -# -# 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: -# - -INCLUDEPATH += ../cahandler/inc \ - ../cahandler/app/inc \ - ../cahandler/url/inc \ - ../cahandler/tapp/inc - -HEADERS += ../cahandler/inc/*.h \ - ../cahandler/app/inc/*.h \ - ../cahandler/url/inc/*.h \ - ../cahandler/tapp/inc/catapphandler.h - -SOURCES += ../cahandler/app/src/*.cpp \ - ../cahandler/url/src/*.cpp \ - ../cahandler/tapp/src/catapphandler.cpp - -LIBS += -lswinstcli \ - -lapgrfx \ - -lws32 \ - -lapparc \ - -lsisregistryclient \ - -leikcore \ - -lcone \ - -lefsrv \ - -lxqservice - - diff -r a6d55a2e75be -r 782e3408c2ab contentstorage/caclient/inc/caclient_defines.h --- a/contentstorage/caclient/inc/caclient_defines.h Fri Mar 26 13:00:55 2010 +0200 +++ b/contentstorage/caclient/inc/caclient_defines.h Fri Apr 16 14:45:49 2010 +0300 @@ -14,9 +14,10 @@ * Description: caclient_defines.h * */ - + const char APPLICATION_UID_ATTRIBUTE_NAME[] = "application:uid"; const char APPLICATION_ENTRY_TYPE_NAME[] = "application"; const char WIDGET_ENTRY_TYPE_NAME[] = "widget"; const char URL_ENTRY_TYPE_NAME[] = "url"; -const char TEMPLATED_APPLICATION_ENTRY_TYPE_NAME[] = "templatedApplication"; \ No newline at end of file +const char PACKAGE_ENTRY_TYPE_NAME[] = "package"; +const char TEMPLATED_APPLICATION_ENTRY_TYPE_NAME[] = "templatedApplication"; diff -r a6d55a2e75be -r 782e3408c2ab contentstorage/caclient/inc/caitemmodel_p.h --- a/contentstorage/caclient/inc/caitemmodel_p.h Fri Mar 26 13:00:55 2010 +0200 +++ b/contentstorage/caclient/inc/caitemmodel_p.h Fri Apr 16 14:45:49 2010 +0300 @@ -55,7 +55,7 @@ void setIconSize(const QSize &size); QSize getIconSize() const; QModelIndex root(); - CaEntry *entry(const QModelIndex &modelIndex) const; + QSharedPointer entry(const QModelIndex &modelIndex) const; void setSecondLineVisibility(bool secondLineVisibility); bool secondLineVisibility() const; QVariant displayRole(const QModelIndex &modelIndex) const; @@ -75,7 +75,8 @@ void updateParentEntry(); void updateItemData(int id); void addItem(int id); - void handleAddItems(QList &itemsList); + void addItemBlock(const QList &itemsList); + void handleAddItems(const QList &itemsList); int itemRow(int id); void removeItem(int id); void removeItems(const QList &itemsList); @@ -94,7 +95,7 @@ // data CaItemModel *const m_q; - CaEntry *mParentEntry;//own + QSharedPointer mParentEntry; CaQuery mQuery; QSharedPointer mService; CaItemModelList mEntries; diff -r a6d55a2e75be -r 782e3408c2ab contentstorage/caclient/inc/caitemmodellist.h --- a/contentstorage/caclient/inc/caitemmodellist.h Fri Mar 26 13:00:55 2010 +0200 +++ b/contentstorage/caclient/inc/caitemmodellist.h Fri Apr 16 14:45:49 2010 +0300 @@ -41,7 +41,7 @@ ~CaItemModelList(); void clear(); int count() const; - CaEntry *at(int row) const; + QSharedPointer at(int row) const; void reloadEntries(const CaQuery &query); void updateEntry(int id); void updateEntries(const CaQuery &query); @@ -60,7 +60,7 @@ private: // data QList mOrderedList; - QHash mEntriesHash; + QHash > mEntriesHash; QSharedPointer mService; }; diff -r a6d55a2e75be -r 782e3408c2ab contentstorage/caclient/inc/caservice_p.h --- a/contentstorage/caclient/inc/caservice_p.h Fri Mar 26 13:00:55 2010 +0200 +++ b/contentstorage/caclient/inc/caservice_p.h Fri Apr 16 14:45:49 2010 +0300 @@ -35,11 +35,11 @@ explicit CaServicePrivate(CaService *servicePublic); ~CaServicePrivate(); - QList getEntries(const QList &entryIdList) const; - QList getEntries(const CaQuery &query) const; + QList< QSharedPointer > getEntries(const QList &entryIdList) const; + QList< QSharedPointer > getEntries(const CaQuery &query) const; QList getEntryIds(const CaQuery &query) const; - CaEntry *createEntry(const CaEntry &entry); + QSharedPointer createEntry(const CaEntry &entry); bool removeEntries(const QList &entryIdList); diff -r a6d55a2e75be -r 782e3408c2ab contentstorage/caclient/installs_win32.pri --- a/contentstorage/caclient/installs_win32.pri Fri Mar 26 13:00:55 2010 +0200 +++ b/contentstorage/caclient/installs_win32.pri Fri Apr 16 14:45:49 2010 +0300 @@ -16,7 +16,7 @@ # take path from common.pri cadb.path = $$DESTDIR -cadb.files = ./../castorage/data/castorage.db +cadb.files = ./../castorage/data/stub/castorage.db cadb.CONFIG += no_build INSTALLS += cadb diff -r a6d55a2e75be -r 782e3408c2ab contentstorage/caclient/s60/inc/cabitmapadapter.h --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/contentstorage/caclient/s60/inc/cabitmapadapter.h Fri Apr 16 14:45:49 2010 +0300 @@ -0,0 +1,62 @@ +/* + * 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: + * + */ + +#ifndef BITMAPADAPTER_H +#define BITMAPADAPTER_H + +// INCLUDES + +// CLASS DECLARATION +#include + +class CFbsBitmap; + +/** + * CaBitmapAdapter + * + */ +class CaBitmapAdapter +{ +public: + + //Static convertion methods between Symbian and Qt objects + + /** + * Make bitmap copy, used to get rid of compression for extended bitmap + * @param input input bitmap. + * @return copied bitmap. + */ + static CFbsBitmap *copyBitmapLC(CFbsBitmap *input); + + /** + * Convert bitmap + * @param input bitmap. + * @return qPixmap. + */ + static QPixmap fromSymbianCFbsBitmap(CFbsBitmap *aBitmap); + + /** + * Convert from bitmap and mask to qpixmap + * @param input bitmap. + * @param pixmap to prepare. + * @return void. + */ + static void fromBitmapAndMaskToPixmapL(CFbsBitmap* fbsBitmap, CFbsBitmap* fbsMask, QPixmap& pixmap); + +}; + +#endif // BITMAPADAPTER_H diff -r a6d55a2e75be -r 782e3408c2ab contentstorage/caclient/s60/inc/caclientproxy.h --- a/contentstorage/caclient/s60/inc/caclientproxy.h Fri Mar 26 13:00:55 2010 +0200 +++ b/contentstorage/caclient/s60/inc/caclientproxy.h Fri Apr 16 14:45:49 2010 +0300 @@ -108,7 +108,7 @@ * @param sourceList List of results. * @return error code */ - ErrorCode getData(const QList &entryIdList, QList &sourceList); + ErrorCode getData(const QList &entryIdList, QList< QSharedPointer > &sourceList); /** * Method for fetching entries. @@ -117,7 +117,7 @@ * @param sourceList List of results. * @return error code */ - ErrorCode getData(const CaQuery &query, QList &sourceList); + ErrorCode getData(const CaQuery &query, QList< QSharedPointer > &sourceList); /** * Method for fetching entries. @@ -199,7 +199,7 @@ * @param sourceList list of entries. */ void getDataL(const QList &entryIdList, - QList &sourceList); + QList< QSharedPointer > &sourceList); /** * Method for fetching entries. Symbian specific. @@ -207,7 +207,7 @@ * @param sourceList list of entries. */ void getDataL(const CaQuery &query, - QList &sourceList); + QList< QSharedPointer > &sourceList); /** * Method for fetching entries. Symbian specific. diff -r a6d55a2e75be -r 782e3408c2ab contentstorage/caclient/s60/inc/cahandler.h --- a/contentstorage/caclient/s60/inc/cahandler.h Fri Mar 26 13:00:55 2010 +0200 +++ b/contentstorage/caclient/s60/inc/cahandler.h Fri Apr 16 14:45:49 2010 +0300 @@ -21,16 +21,17 @@ #include #include -class CaEntry; +class CCaInnerEntry; class QString; -class CaHandler: public QObject +class CaHandler { - Q_OBJECT - public: - virtual int execute(const CaEntry &entry, + virtual ~CaHandler() {} + virtual int execute(CCaInnerEntry &innerEntry, const QString &commandName) = 0; }; +Q_DECLARE_INTERFACE(CaHandler, "com.nokia.homescreen.ICommandHandler") + #endif diff -r a6d55a2e75be -r 782e3408c2ab contentstorage/caclient/s60/inc/cahandlerproxy.h --- a/contentstorage/caclient/s60/inc/cahandlerproxy.h Fri Mar 26 13:00:55 2010 +0200 +++ b/contentstorage/caclient/s60/inc/cahandlerproxy.h Fri Apr 16 14:45:49 2010 +0300 @@ -25,6 +25,7 @@ #include #include "cahandlerloader.h" + class CaEntry; class CaHandlerProxy diff -r a6d55a2e75be -r 782e3408c2ab contentstorage/caclient/s60/inc/camenuiconmifutility.h --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/contentstorage/caclient/s60/inc/camenuiconmifutility.h Fri Apr 16 14:45:49 2010 +0300 @@ -0,0 +1,45 @@ +/* + * 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: + * + */ + +#ifndef MENUICONMIFUTILITY_H +#define MENUICONMIFUTILITY_H + +// INCLUDES + +// CLASS DECLARATION +#include + +/** + * CaMenuIconMifUtility + * + */ +class CaMenuIconMifUtility +{ +public: + + /** + * Create pixmap from filename + * @param fileName icon filename. + * @param icon size. + * @param pixmap to fill. + * @return void. + */ + static void GetPixmapByFilenameL(TDesC& fileName, const QSize &size, + QPixmap& pixmap); +}; + +#endif // MENUICONMIFUTILITY_H diff -r a6d55a2e75be -r 782e3408c2ab contentstorage/caclient/s60/inc/caobjectadapter.h --- a/contentstorage/caclient/s60/inc/caobjectadapter.h Fri Mar 26 13:00:55 2010 +0200 +++ b/contentstorage/caclient/s60/inc/caobjectadapter.h Fri Apr 16 14:45:49 2010 +0300 @@ -22,6 +22,7 @@ // CLASS DECLARATION #include +#include #include @@ -83,7 +84,7 @@ */ static void convertL( const RPointerArray& fromEntriesArray, - QList& toEntriesArray); + QList< QSharedPointer > & toEntriesArray); /** * Converts QList of ids to RArray of TInts. @@ -108,13 +109,6 @@ TInt internalErrorCode); /** - * Creates icon. - * @param entry entry. - * @return HbIcon. - */ - static HbIcon makeIcon(const CaEntry &entry, const QSize &size); - - /** * Converts notifier type to inner notifier type. * @param from notifier type. * @param to resulting inner notifier type. @@ -149,19 +143,6 @@ int id); private: - /** - * Creates icon. Leaving version. - * @param entry entry. - * @return HbIcon. - */ - static HbIcon makeIconL(const CaEntry &entry, const QSize &size); - - /** - * Make bitmap copy, used to get rid of compression for extended bitmap - * @param input input bitmap. - * @return copied bitmap. - */ - static CFbsBitmap *copyBitmapLC(CFbsBitmap *input); /** * Maps a given sort subject and the order to be applied diff -r a6d55a2e75be -r 782e3408c2ab contentstorage/caclient/s60/inc/caqtsfhandlerloader.h --- a/contentstorage/caclient/s60/inc/caqtsfhandlerloader.h Fri Mar 26 13:00:55 2010 +0200 +++ b/contentstorage/caclient/s60/inc/caqtsfhandlerloader.h Fri Apr 16 14:45:49 2010 +0300 @@ -28,8 +28,11 @@ public CaHandlerLoader { public: + CaQtSfHandlerLoader(); CaHandler *loadHandler(const QString &entryTypeName, const QString &commandName); +protected: + void registerPlugins() const; }; #endif diff -r a6d55a2e75be -r 782e3408c2ab contentstorage/caclient/s60/src/cabitmapadapter.cpp --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/contentstorage/caclient/s60/src/cabitmapadapter.cpp Fri Apr 16 14:45:49 2010 +0300 @@ -0,0 +1,125 @@ +/* + * Copyright (c)2008 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: ?Description + * + */ + +#include +#include +#include +#include + +#include +#include +#include +#include +#include +#include +#include + +#include "cadef.h" +#include "cabitmapadapter.h" + +static QImage::Format TDisplayMode2Format(TDisplayMode mode) +{ + QImage::Format format; + switch (mode) { + case EGray2: + format = QImage::Format_MonoLSB; + break; + case EColor256: + case EGray256: + format = QImage::Format_Indexed8; + break; + case EColor4K: + format = QImage::Format_RGB444; + break; + case EColor64K: + format = QImage::Format_RGB16; + break; + case EColor16M: + format = QImage::Format_RGB888; + break; + case EColor16MU: + format = QImage::Format_RGB32; + break; + case EColor16MA: + format = QImage::Format_ARGB32; + break; + case EColor16MAP: + format = QImage::Format_ARGB32_Premultiplied; + break; + default: + format = QImage::Format_Invalid; + break; + } + return format; +} + +QPixmap CaBitmapAdapter::fromSymbianCFbsBitmap(CFbsBitmap *aBitmap) +{ + aBitmap->BeginDataAccess(); + uchar *data = (uchar *)aBitmap->DataAddress(); + TSize size = aBitmap->SizeInPixels(); + TDisplayMode displayMode = aBitmap->DisplayMode(); + + // QImage format must match to bitmap format + QImage image(data, size.iWidth, size.iHeight, TDisplayMode2Format( + displayMode)); + aBitmap->EndDataAccess(); + + // No data copying happens because + // image format matches native OpenVG format. + // So QPixmap actually points to CFbsBitmap data. + return QPixmap::fromImage(image); +} + +// ----------------------------------------------------------------------------- +// copying compressed bitmap +//---------------------------------------------------------------------------- +CFbsBitmap *CaBitmapAdapter::copyBitmapLC(CFbsBitmap *input) +{ + CFbsBitmap *bmp = new(ELeave) CFbsBitmap(); + CleanupStack::PushL(bmp); + bmp->Create(input->SizeInPixels(), input->DisplayMode()); + + CFbsBitmapDevice *bitmapDevice = CFbsBitmapDevice::NewL(bmp); + CleanupStack::PushL(bitmapDevice); + CFbsBitGc *bmpGc; + bitmapDevice->CreateContext(bmpGc); + bmpGc->BitBlt(TPoint(0,0), input); + delete bmpGc; + CleanupStack::PopAndDestroy(bitmapDevice); + return bmp; +} + +void CaBitmapAdapter::fromBitmapAndMaskToPixmapL(CFbsBitmap* fbsBitmap, + CFbsBitmap* fbsMask, QPixmap& pixmap) +{ + if (fbsBitmap->Header().iCompression == ENoBitmapCompression) { + pixmap = CaBitmapAdapter::fromSymbianCFbsBitmap(fbsBitmap); + QPixmap mask = CaBitmapAdapter::fromSymbianCFbsBitmap(fbsMask); + pixmap.setAlphaChannel(mask); + } else { // we need special handling for icons in 9.2 (NGA) + // let's hope that in future it will be in QT code + CFbsBitmap *temp(NULL); + temp = CaBitmapAdapter::copyBitmapLC(fbsBitmap); + pixmap = CaBitmapAdapter::fromSymbianCFbsBitmap(temp); + CleanupStack::PopAndDestroy(); + temp = CaBitmapAdapter::copyBitmapLC(fbsMask); + QPixmap mask = CaBitmapAdapter::fromSymbianCFbsBitmap(temp); + CleanupStack::PopAndDestroy(); + pixmap.setAlphaChannel(mask); + } +} diff -r a6d55a2e75be -r 782e3408c2ab contentstorage/caclient/s60/src/caclientproxy.cpp --- a/contentstorage/caclient/s60/src/caclientproxy.cpp Fri Mar 26 13:00:55 2010 +0200 +++ b/contentstorage/caclient/s60/src/caclientproxy.cpp Fri Apr 16 14:45:49 2010 +0300 @@ -128,7 +128,7 @@ // //---------------------------------------------------------------------------- ErrorCode CaClientProxy::getData(const QList &entryIdList, - QList &sourceList) + QList< QSharedPointer > &sourceList) { TRAPD(error, getDataL(entryIdList, sourceList)); @@ -142,7 +142,7 @@ // //---------------------------------------------------------------------------- ErrorCode CaClientProxy::getData(const CaQuery &query, - QList &sourceList) + QList< QSharedPointer > &sourceList) { TRAPD(error, getDataL(query, sourceList)); @@ -281,7 +281,7 @@ // //---------------------------------------------------------------------------- void CaClientProxy::getDataL(const QList &entryIdList, - QList &sourceList) + QList< QSharedPointer > &sourceList) { CCaInnerQuery *query = CCaInnerQuery::NewLC(); RArray array; @@ -301,7 +301,7 @@ // //---------------------------------------------------------------------------- void CaClientProxy::getDataL(const CaQuery &query, - QList &sourceList) + QList< QSharedPointer > &sourceList) { CCaInnerQuery *innerQuery = CCaInnerQuery::NewLC(); CaObjectAdapter::convertL(query, *innerQuery); diff -r a6d55a2e75be -r 782e3408c2ab contentstorage/caclient/s60/src/cahandlerproxy.cpp --- a/contentstorage/caclient/s60/src/cahandlerproxy.cpp Fri Mar 26 13:00:55 2010 +0200 +++ b/contentstorage/caclient/s60/src/cahandlerproxy.cpp Fri Apr 16 14:45:49 2010 +0300 @@ -19,10 +19,12 @@ #include "cahandler.h" #include "cahandlerproxy.h" #include "cahandlerloader.h" +#include "cainnerentry.h" +#include "caobjectadapter.h" /*! \class CaHandlerProxy - \ingroup + \ingroup \brief Forwards execute request to an implemenation provided by specific handler loader. \sa CaHandlerLoader @@ -60,9 +62,15 @@ TInt result = KErrNotFound; if (handler != NULL) { - result = handler->execute(entry, commandName); + QScopedPointer innerEntry(NULL); + TRAP(result, + innerEntry.reset(CCaInnerEntry::NewL()); + CaObjectAdapter::convertL(entry, *innerEntry); + ) + if (result == KErrNone) { + result = handler->execute(*innerEntry, commandName); + } } - return result; } diff -r a6d55a2e75be -r 782e3408c2ab contentstorage/caclient/s60/src/camenuiconmifutility.cpp --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/contentstorage/caclient/s60/src/camenuiconmifutility.cpp Fri Apr 16 14:45:49 2010 +0300 @@ -0,0 +1,59 @@ +/* + * Copyright (c)2008 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: ?Description + * + */ + +#include +#include +#include +#include +#include // avkon +#include // fbsbitmap + +#include "cabitmapadapter.h" +#include "camenuiconmifutility.h" + + +void CaMenuIconMifUtility::GetPixmapByFilenameL(TDesC& fileName, + const QSize &size, QPixmap& pixmap) +{ + CFbsBitmap *bitamp(0); + CFbsBitmap *mask(0); + + if ( AknIconUtils::IsMifFile(fileName)) { + // SVG icon + // SVG always has only one icon + TInt bitmapIndex = 0; + TInt maskIndex = 1; + AknIconUtils::ValidateLogicalAppIconId( fileName, + bitmapIndex, maskIndex ); + + AknIconUtils::CreateIconLC( bitamp, mask, fileName, + bitmapIndex, maskIndex ); + } + + AknIconUtils::DisableCompression(bitamp); + AknIconUtils::SetSize(bitamp, TSize(size.width(), size.height()), + EAspectRatioPreservedAndUnusedSpaceRemoved); + + AknIconUtils::DisableCompression(mask); + AknIconUtils::SetSize(mask, TSize(size.width(), size.height()), + EAspectRatioPreservedAndUnusedSpaceRemoved); + + CaBitmapAdapter::fromBitmapAndMaskToPixmapL(bitamp, mask, pixmap); + + // bitmap and icon, AknsUtils::CreateIconLC doesn't specify the order + CleanupStack::Pop(2); +} diff -r a6d55a2e75be -r 782e3408c2ab contentstorage/caclient/s60/src/camenuiconutility.cpp --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/contentstorage/caclient/s60/src/camenuiconutility.cpp Fri Apr 16 14:45:49 2010 +0300 @@ -0,0 +1,236 @@ +/* + * 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: + * + */ + +// conversion +#include +// apparc +#include +#include +// cfbsbitmap +#include + +#include +#include "camenuiconutility.h" +#include "camenuiconmifutility.h" +#include "cabitmapadapter.h" +#include "caentry.h" +#include "caquery.h" +#include "caservice.h" +#include "cadef.h" + +const QString appUidAttributeName("application:uid"); + +/*! + Get icon from entry. + \param entry const reference to CaEntry. + \retval icon. + */ +LOCAL_C HbIcon getIconFromEntry(const CaEntry& entry) +{ + HbIcon icon; + QString skinId(entry.iconDescription().skinId()); + if (!skinId.isEmpty()) { + icon = HbIcon(skinId); + } + + if (icon.isNull() || !(icon.size().isValid())) { + QString fileName(entry.iconDescription().filename()); + if (!fileName.isEmpty()) { + + // TODO: + // work-around for HbIcon::size() method locking files if returns + // default size, error id: ou1cimx1#279208 Case: mcl06HsDo07 - + // "Cannot delete file" when trying to uninstall sisx file + + if (entry.entryTypeName() == XQConversions::s60DescToQString( + KCaTypeWidget)) { + icon = QIcon(fileName); + qWarning("Widget icon created by QIcon, " + "as work-around for HbIcon::size"); + } else { + icon = HbIcon(fileName); + } + } + } + return icon; +} + +/*! + Get icon from apparc. + \param entry const reference to CaEntry. + \param sie const reference to icon size. + \retval icon. + */ +LOCAL_C HbIcon getIconFromApparcL(const CaEntry& entry, const QSize &size) +{ + HbIcon icon; + + RApaLsSession apaLsSession; + CleanupClosePushL(apaLsSession); + User::LeaveIfError(apaLsSession.Connect()); + + QString uidString(entry.attribute(appUidAttributeName)); + TUid uid; + uid = uid.Uid(uidString.toInt()); + + CApaAppServiceInfoArray* skinArray(NULL); + TRAPD( err, skinArray = apaLsSession.GetAppServiceOpaqueDataLC(uid, TUid::Uid(0x2002DCF3)); + if (err == KErrNone && skinArray ) { + TArray tmpArray( skinArray->Array() ); + if ( tmpArray.Count() ) { + TPtrC8 opaque(tmpArray[0].OpaqueData()); + const TPtrC16 iconName((TText16*) opaque.Ptr(),(opaque.Length()+1)>>1); + icon = HbIcon( XQConversions:: s60DescToQString( iconName ) ); + } + } + CleanupStack::PopAndDestroy(skinArray); + ); + + if (icon.isNull() || !(icon.size().isValid())) { + TSize iconSize(size.width(), size.height()); + CApaMaskedBitmap* apaMaskedBitmap = CApaMaskedBitmap::NewLC(); + TInt err = apaLsSession.GetAppIcon(uid,iconSize,*apaMaskedBitmap); + + TInt iconsCount(0); + apaLsSession.NumberOfOwnDefinedIcons(uid, iconsCount); + + QPixmap pixmap; + if ((err == KErrNone) && (iconsCount > 0)) { + CaBitmapAdapter::fromBitmapAndMaskToPixmapL(apaMaskedBitmap, + apaMaskedBitmap->Mask(), pixmap); + + pixmap = pixmap.scaled(size, Qt::KeepAspectRatioByExpanding); + icon = HbIcon(QIcon(pixmap)); + } else { + HBufC* fileNameFromApparc; + TInt err2 = apaLsSession.GetAppIcon(uid,fileNameFromApparc); + CleanupStack::PushL(fileNameFromApparc); + if (err2 == KErrNone) { + QString fileName = XQConversions::s60DescToQString( + fileNameFromApparc->Des()); + if (fileName.contains(QString(".mif"))) { + + TPtr ptr(fileNameFromApparc->Des()); + CaMenuIconMifUtility::GetPixmapByFilenameL(ptr,size,pixmap); + + pixmap = pixmap.scaled(size, Qt::KeepAspectRatioByExpanding); + icon = HbIcon(QIcon(pixmap)); + } + } + CleanupStack::Pop(fileNameFromApparc); + } + + CleanupStack::PopAndDestroy(apaMaskedBitmap); + } + CleanupStack::PopAndDestroy(&apaLsSession); + + return icon; +} + +/*! + Get default icon from theme. + \param entry const reference to CaEntry. + \retval icon. + */ +LOCAL_C HbIcon getDefaultIcon(const CaEntry& entry) +{ + HbIcon icon; + + if (entry.entryTypeName() == + XQConversions::s60DescToQString(KCaTypeApp)) { + icon = HbIcon("qtg_large_application"); + } else if (entry.entryTypeName() == + XQConversions::s60DescToQString(KCaTypeFolder) || + entry.entryTypeName() == + XQConversions::s60DescToQString(KCaTypeCollection) || + entry.entryTypeName() == + XQConversions::s60DescToQString(KCaTypeCollectionDownload)) { + icon = HbIcon("qtg_large_application"); + } else if (entry.entryTypeName() == + XQConversions::s60DescToQString(KCaTypeUrl)) { + icon = HbIcon("qtg_large_application"); + } else if (entry.entryTypeName() == + XQConversions::s60DescToQString(KCaTypeWidget)) { + icon = HbIcon("qtg_large_application"); + } else if (entry.entryTypeName() == + XQConversions::s60DescToQString(KCaTypeTemplatedApp)) { + icon = HbIcon("qtg_large_application"); + } else if (entry.entryTypeName() == + XQConversions::s60DescToQString(KCaTypePackage)) { + icon = HbIcon("qtg_large_application"); + } + + return icon; +} + +/*! + Get entry by uid. + \param uid application uid. + \retval entry. + */ +LOCAL_C CaEntry getEntryByUid(int uid) +{ + CaEntry entry; + CaQuery query; + query.setAttribute(QString("application:uid"), QString::number(uid)); + QList< QSharedPointer > entries = CaService::instance()->getEntries(query); + if (!entries.isEmpty()) { + entry = *(entries.first()); + } + return entry; +} + +/*! + Get icon when uid is defined. + \param entry const reference to CaEntry. + \param sie const reference to icon size. + \retval icon. + */ +HbIcon CaMenuIconUtility::getApplicationIcon(int uid, + const QSize &size) +{ + HbIcon icon; + CaEntry entry; + entry = getEntryByUid(uid); + icon = getEntryIcon(entry, size); + return icon; +} + +/*! + Get icon. + \param entry const reference to CaEntry. + \param sie const reference to icon size. + \retval icon. + */ +HbIcon CaMenuIconUtility::getEntryIcon(const CaEntry& entry, + const QSize &size) +{ + HbIcon icon; + icon = getIconFromEntry(entry); + + if (icon.isNull() || !(icon.size().isValid())) { + TRAP_IGNORE(icon = getIconFromApparcL(entry, size)); + } + + if (icon.isNull() || !(icon.size().isValid())) { + icon = getDefaultIcon(entry); + } + + return icon; +} + + diff -r a6d55a2e75be -r 782e3408c2ab contentstorage/caclient/s60/src/caobjectadapter.cpp --- a/contentstorage/caclient/s60/src/caobjectadapter.cpp Fri Mar 26 13:00:55 2010 +0200 +++ b/contentstorage/caclient/s60/src/caobjectadapter.cpp Fri Apr 16 14:45:49 2010 +0300 @@ -34,65 +34,11 @@ #include "caentry_p.h" #include "cainnerquery.h" #include "caquery.h" -#include "camenuiconutility.h" + #include "canotifierfilter.h" #include "cainnernotifierfilter.h" #include "caclient_defines.h" -static QImage::Format TDisplayMode2Format(TDisplayMode mode) -{ - QImage::Format format; - switch (mode) { - case EGray2: - format = QImage::Format_MonoLSB; - break; - case EColor256: - case EGray256: - format = QImage::Format_Indexed8; - break; - case EColor4K: - format = QImage::Format_RGB444; - break; - case EColor64K: - format = QImage::Format_RGB16; - break; - case EColor16M: - format = QImage::Format_RGB888; - break; - case EColor16MU: - format = QImage::Format_RGB32; - break; - case EColor16MA: - format = QImage::Format_ARGB32; - break; - case EColor16MAP: - format = QImage::Format_ARGB32_Premultiplied; - break; - default: - format = QImage::Format_Invalid; - break; - } - return format; -} - -QPixmap fromSymbianCFbsBitmap(CFbsBitmap *aBitmap) -{ - aBitmap->BeginDataAccess(); - uchar *data = (uchar *)aBitmap->DataAddress(); - TSize size = aBitmap->SizeInPixels(); - TDisplayMode displayMode = aBitmap->DisplayMode(); - - // QImage format must match to bitmap format - QImage image(data, size.iWidth, size.iHeight, TDisplayMode2Format( - displayMode)); - aBitmap->EndDataAccess(); - - // No data copying happens because - // image format matches native OpenVG format. - // So QPixmap actually points to CFbsBitmap data. - return QPixmap::fromImage(image); -} - // --------------------------------------------------------------------------- // // --------------------------------------------------------------------------- @@ -181,10 +127,16 @@ const QMap attributesMap = fromQuery.attributes(); foreach(QString key, attributesMap.keys()) { - toQuery.AddAttributeL( - XQConversions::qStringToS60Desc(key)->Des(), - XQConversions::qStringToS60Desc( - attributesMap.value(key))->Des()); + if (key == APPLICATION_UID_ATTRIBUTE_NAME) { + const TInt32 uid = attributesMap.value(key).toInt(); + toQuery.SetUid(uid); + } + else { + toQuery.AddAttributeL( + XQConversions::qStringToS60Desc(key)->Des(), + XQConversions::qStringToS60Desc( + attributesMap.value(key))->Des()); + } } } @@ -206,16 +158,16 @@ toEntry.setFlags(static_cast(fromEntry.GetFlags())); // take care of converting icon attributes - const CCaInnerEntry::TIconAttributes &icon = fromEntry.GetIcon(); + const CCaInnerIconDescription* innerIcon = fromEntry.Icon(); + CaIconDescription iconDescription; - CaIconDescription iconDescription; - iconDescription.setId(icon.iId); + iconDescription.setId(innerIcon->Id()); iconDescription.setFilename( - XQConversions::s60DescToQString(icon.iFileName)); + XQConversions::s60DescToQString(innerIcon->FileName())); iconDescription.setSkinId( - XQConversions::s60DescToQString(icon.iSkinId)); + XQConversions::s60DescToQString(innerIcon->SkinId())); iconDescription.setApplicationId( - XQConversions::s60DescToQString(icon.iApplicationId)); + XQConversions::s60DescToQString(innerIcon->ApplicationId())); toEntry.setIconDescription(iconDescription); @@ -282,11 +234,11 @@ //---------------------------------------------------------------------------- void CaObjectAdapter::convertL( const RPointerArray &fromEntriesArray, - QList &toEntryList) + QList< QSharedPointer > &toEntryList) { for (int i = 0; i < fromEntriesArray.Count(); ++i) { - CaEntry *const toEntry = new CaEntry( - static_cast(fromEntriesArray[i]->GetRole())); + const QSharedPointer toEntry (new CaEntry( + static_cast(fromEntriesArray[i]->GetRole()))); CaObjectAdapter::convert(*fromEntriesArray[i], *toEntry); @@ -319,21 +271,6 @@ //---------------------------------------------------------------------------- // //---------------------------------------------------------------------------- -HbIcon CaObjectAdapter::makeIcon(const CaEntry &entry, const QSize &size) -{ - - HbIcon icon; - TRAPD(leaveCode, icon = makeIconL(entry, size)); - - USE_QDEBUG_IF(leaveCode) << "CaObjectAdapter::makeIcon leaveCode:" - << leaveCode; - - return icon; -} - -//---------------------------------------------------------------------------- -// -//---------------------------------------------------------------------------- ErrorCode CaObjectAdapter::convertErrorCode(int internalErrorCode) { ErrorCode error(NoErrorCode); @@ -357,94 +294,6 @@ return error; } - -// ----------------------------------------------------------------------------- -// copying compressed bitmap -//---------------------------------------------------------------------------- -CFbsBitmap *CaObjectAdapter::copyBitmapLC(CFbsBitmap *input) -{ - CFbsBitmap *bmp = new(ELeave) CFbsBitmap(); - CleanupStack::PushL(bmp); - bmp->Create(input->SizeInPixels(), input->DisplayMode()); - - CFbsBitmapDevice *bitmapDevice = CFbsBitmapDevice::NewL(bmp); - CleanupStack::PushL(bitmapDevice); - CFbsBitGc *bmpGc; - bitmapDevice->CreateContext(bmpGc); - bmpGc->BitBlt(TPoint(0,0), input); - delete bmpGc; - CleanupStack::PopAndDestroy(bitmapDevice); - return bmp; -} - -//---------------------------------------------------------------------------- -// -//---------------------------------------------------------------------------- -HbIcon CaObjectAdapter::makeIconL(const CaEntry &entry, const QSize &size) -{ - HbIcon icon; - QString skinId(entry.iconDescription().skinId()); - if (!skinId.isEmpty()) { - icon = HbIcon(skinId); - } - if (icon.isNull() || !(icon.size().isValid())) { - QString filename(entry.iconDescription().filename()); - if (!filename.isEmpty()) { - - // TODO: - // work-around for HbIcon::size() method locking files if returns - // default size, error id: ou1cimx1#279208 Case: mcl06HsDo07 - - // "Cannot delete file" when trying to uninstall sisx file - - if (entry.entryTypeName() == XQConversions::s60DescToQString(KCaTypeWidget)) { - icon = QIcon(filename); - qWarning("Widget icon created by QIcon, as work-around for HbIcon::size"); - } else { - icon = HbIcon(filename); - } - } - } - - //try to load symbian icon from multi-bitmap (mbm, mbg) - if (icon.isNull() || !(icon.size().isValid())) { - CCaInnerEntry *innerEntry = CCaInnerEntry::NewLC(); - CaObjectAdapter::convertL(entry, *innerEntry); - - CAknIcon *aknIcon = CaMenuIconUtility::GetItemIcon(*innerEntry); - QPixmap pixmap; - if (aknIcon) { - CleanupStack::PushL(aknIcon); - - //need to disable compression to properly convert the bitmap - AknIconUtils::DisableCompression(aknIcon->Bitmap()); - AknIconUtils::SetSize( - aknIcon->Bitmap(), TSize(size.width(), size.height()), - EAspectRatioPreservedAndUnusedSpaceRemoved); - if (aknIcon->Bitmap()->Header().iCompression - == ENoBitmapCompression) { - pixmap = fromSymbianCFbsBitmap(aknIcon->Bitmap()); - QPixmap mask = fromSymbianCFbsBitmap(aknIcon->Mask()); - pixmap.setAlphaChannel(mask); - } else { // we need special handling for icons in 9.2 (NGA) - // let's hope that in future it will be in QT code - CFbsBitmap *temp(NULL); - temp = copyBitmapLC(aknIcon->Bitmap()); - pixmap = fromSymbianCFbsBitmap(temp); - CleanupStack::PopAndDestroy(); - temp = copyBitmapLC(aknIcon->Mask()); - QPixmap mask = fromSymbianCFbsBitmap(temp); - CleanupStack::PopAndDestroy(); - pixmap.setAlphaChannel(mask); - } - pixmap = pixmap.scaled(size, Qt::KeepAspectRatioByExpanding); - CleanupStack::PopAndDestroy(aknIcon); - icon = HbIcon(QIcon(pixmap)); - } - CleanupStack::PopAndDestroy(innerEntry); - } - return icon; -} - //---------------------------------------------------------------------------- // //---------------------------------------------------------------------------- diff -r a6d55a2e75be -r 782e3408c2ab contentstorage/caclient/s60/src/caqtsfhandlerloader.cpp --- a/contentstorage/caclient/s60/src/caqtsfhandlerloader.cpp Fri Mar 26 13:00:55 2010 +0200 +++ b/contentstorage/caclient/s60/src/caqtsfhandlerloader.cpp Fri Apr 16 14:45:49 2010 +0300 @@ -15,6 +15,8 @@ * */ +#include +#include #include #include #include @@ -25,16 +27,12 @@ #include "cahandler.h" #include "caqtsfhandlerloader.h" #include "caclient_defines.h" -#include "caapphandler.h" -#include "caurlhandler.h" -#include "catapphandler.h" -#include "cas60handleradapter.h" QTM_USE_NAMESPACE /*! \class CaQtSfHandlerLoader - \ingroup + \ingroup \brief Loads handlers implementation The purpose of the class is to find Qt SF plugins implementing command handlers. @@ -44,10 +42,44 @@ */ /*! - Loads handler implementations appropriate for the requested entry type name and command. + Constructor. +*/ +CaQtSfHandlerLoader::CaQtSfHandlerLoader() +{ + registerPlugins(); +} + +/*! + Load plugins for command handling. +*/ +void CaQtSfHandlerLoader::registerPlugins() const +{ + const QString pluginPath("hsresources/plugins/commandhandler"); + const QFileInfoList drives = QDir::drives(); + foreach(QFileInfo drive, drives) { + const QString driveLetter = drive.absolutePath(); + const QString pluginAbsolutePath = driveLetter + pluginPath; + const QDir pluginDir(pluginAbsolutePath); + if(QDir(pluginDir).exists()) { + const QFileInfoList fileInfos = + pluginDir.entryInfoList(QStringList("*.xml")); + + QApplication::addLibraryPath(pluginAbsolutePath); + + QServiceManager serviceManager; + foreach(QFileInfo fileInfo, fileInfos) { + serviceManager.addService(fileInfo.absoluteFilePath()); + } + } + } +} + +/*! + Loads handler implementations appropriate for the requested entry type name and command. + The caller takes ownership of the returned pointer. - + \param entryTypeName Entry type name. \param commandName Name of the command to be handled. \return A pointer to handler serving the entry type and command if found, NULL otherwise. @@ -57,18 +89,26 @@ { Q_UNUSED(commandName); - CaHandler *implementation(0); - - if (entryTypeName == APPLICATION_ENTRY_TYPE_NAME - || entryTypeName == WIDGET_ENTRY_TYPE_NAME) { - implementation = new CaS60HandlerAdapter; - } else if (entryTypeName == URL_ENTRY_TYPE_NAME) { - implementation = new CaS60HandlerAdapter; - } else if (entryTypeName == TEMPLATED_APPLICATION_ENTRY_TYPE_NAME) { - implementation = new CaTappHandler; + QString typeName(entryTypeName); + if (entryTypeName == WIDGET_ENTRY_TYPE_NAME + || entryTypeName == PACKAGE_ENTRY_TYPE_NAME) { + typeName = QString(APPLICATION_ENTRY_TYPE_NAME); } - return implementation; + QServiceManager serviceManager; + QServiceFilter serviceFilter("com.nokia.homescreen.ICommandHandler"); + serviceFilter.setCustomAttribute("entryTypeName", typeName); + QList serviceInterfaceDescriptorList = + serviceManager.findInterfaces(serviceFilter); + CaHandler *interfaceHandler = NULL; + if (!serviceInterfaceDescriptorList.isEmpty()) { + QServiceInterfaceDescriptor serviceInterfaceDescriptor = + serviceInterfaceDescriptorList[0]; + QObject *handler = + serviceManager.loadInterface(serviceInterfaceDescriptor); + interfaceHandler = qobject_cast(handler); + } + return interfaceHandler; } diff -r a6d55a2e75be -r 782e3408c2ab contentstorage/caclient/src/caentry.cpp --- a/contentstorage/caclient/src/caentry.cpp Fri Mar 26 13:00:55 2010 +0200 +++ b/contentstorage/caclient/src/caentry.cpp Fri Apr 16 14:45:49 2010 +0300 @@ -24,6 +24,7 @@ #include "caobjectadapter.h" #include "caiconcache.h" #include "caclienttest_global.h" +#include "camenuiconutility.h" // ======== MEMBER FUNCTIONS ======== @@ -473,7 +474,7 @@ CaEntryPrivate::CaEntryPrivate(CaEntry *entryPublic) : m_q(entryPublic), mId(0), mText(), mDescription(), mIconDescription(), mFlags(RemovableEntryFlag|VisibleEntryFlag),mEntryTypeName(), - mAttributes() + mAttributes(), mEntryRole(ItemEntryRole) { } /*! @@ -629,7 +630,7 @@ */ HbIcon CaEntryPrivate::makeIcon(const QSize &size) const { - return CaObjectAdapter::makeIcon(*m_q, size); + return CaMenuIconUtility::getEntryIcon(*m_q, size); } /*! diff -r a6d55a2e75be -r 782e3408c2ab contentstorage/caclient/src/caitemmodel.cpp --- a/contentstorage/caclient/src/caitemmodel.cpp Fri Mar 26 13:00:55 2010 +0200 +++ b/contentstorage/caclient/src/caitemmodel.cpp Fri Apr 16 14:45:49 2010 +0300 @@ -382,7 +382,7 @@ \endcode */ -CaEntry *CaItemModel::entry(const QModelIndex &index) const +QSharedPointer CaItemModel::entry(const QModelIndex &index) const { return m_d->entry(index); } @@ -394,7 +394,7 @@ */ CaItemModelPrivate::CaItemModelPrivate(const CaQuery &query, CaItemModel *itemModelPublic) : - QObject(), m_q(itemModelPublic), mParentEntry(0), mQuery(query), + QObject(), m_q(itemModelPublic), mParentEntry(), mQuery(query), mService(CaService::instance()), mEntries(mService), mNotifier(NULL), mSize(defaultIconSize), mSecondLineVisibility(true) { @@ -408,7 +408,6 @@ CaItemModelPrivate::~CaItemModelPrivate() { mEntries.clear(); - delete mParentEntry; delete mNotifier; } @@ -466,6 +465,10 @@ case CaItemModel::TextRole: variant = QVariant(entry(modelIndex)->text()); break; + case CaItemModel::FullTextRole: + variant = QVariant(entry(modelIndex)->text() + QString(" ") + + entry(modelIndex)->description()); + break; default: variant = QVariant(QVariant::Invalid); } @@ -550,7 +553,7 @@ \param modelIndex index of entry in model \retval pointer to an entry */ -CaEntry *CaItemModelPrivate::entry(const QModelIndex &modelIndex) const +QSharedPointer CaItemModelPrivate::entry(const QModelIndex &modelIndex) const { if (modelIndex.column() == 1) { return mParentEntry; @@ -687,7 +690,6 @@ CACLIENTTEST_FUNC_ENTRY("CaItemModelPrivate::updateParentEntry"); if (mQuery.parentId()) { - delete mParentEntry; mParentEntry = mService->getEntry(mQuery.parentId()); } @@ -706,14 +708,14 @@ mEntries.updateEntry(id); QList ids = mService->getEntryIds(mQuery); - if (mEntries.indexOf(id) >= 0 + if (mEntries.indexOf(id) >= 0 && ids.indexOf(id) == mEntries.indexOf(id)) { emit m_q->dataChanged(index(mEntries.indexOf(id)), index( mEntries.indexOf(id))); } else if (ids.indexOf(id) < 0){ removeItem(id); } else if (mEntries.indexOf(id) < 0){ - addItem(id); + addItem(id); } else if (mParentEntry && id == mParentEntry->id()) { updateParentEntry(); m_q->reset(); @@ -743,63 +745,63 @@ } /*! + Adds new item block to model + Use in cases when inserting / appending an adjacent block of items + \param itemsList list of adjacent items + */ +void CaItemModelPrivate::addItemBlock(const QList &itemsList) +{ + CACLIENTTEST_FUNC_ENTRY("CaItemModelPrivate::addItemBlock"); + if (!itemsList.isEmpty()) { + int firstRow = itemRow(itemsList.first()); + int lastRow = itemRow(itemsList.last()); + m_q->beginInsertRows(QModelIndex(), firstRow, lastRow); + for (int i = 0; i < itemsList.count(); ++i) { + mEntries.insert(firstRow + i, itemsList.at(i)); + } + m_q->endInsertRows(); + emit m_q->scrollTo(firstRow, QAbstractItemView::PositionAtTop); + } + CACLIENTTEST_FUNC_EXIT("CaItemModelPrivate::addItemBlock"); +} + +/*! Adds new items to model \param itemsList current items list */ -void CaItemModelPrivate::handleAddItems(QList &itemsList) +void CaItemModelPrivate::handleAddItems(const QList &itemsList) { CACLIENTTEST_FUNC_ENTRY("CaItemModelPrivate::handleAddItems"); - - int entriesCount = mEntries.count(); - if (entriesCount) { - int lastRow = itemsList.indexOf(mEntries[entriesCount - 1]); - if (itemsList.count() == entriesCount) { - //count is same and last item is in same position - //so we update whole model - bool orderChanged(false); - while (entriesCount) { - if (itemsList.indexOf(mEntries[entriesCount - 1]) - != (entriesCount - 1)) { - orderChanged = true; - break; - } - entriesCount--; - } - if (orderChanged) { + const int oldItemCount(mEntries.count()); + if (oldItemCount) { + const int newItemCount(itemsList.count()); + if (newItemCount == oldItemCount) { + // count is the same - check if item order changed + if (itemsList == mEntries.orderedIdList()) { + // assume that if the order has not changed + // it had to be the secondary lines + updateModel(); + } else { updateLayout(); } - else { - updateModel(); - } - - } else if ((itemsList.count() - entriesCount) == 1 && lastRow - == entriesCount) { - //just one item added - collection + } else { int i = 0; - for (i = 0; i < entriesCount; i++) { - if (itemsList[i] != mEntries[i]) { - addItem(itemsList[i]); - updateLayout(); - emit m_q->scrollTo(i, - QAbstractItemView::PositionAtTop); + QList oldList = mEntries.orderedIdList(); + //we loop through items to find first added + while (i < oldList.count()) { + if (oldList[i] != itemsList[i]) { + oldList.takeAt(i); + } else { + ++i; } } - while (i < itemsList.count()) { - addItem(itemsList[i]); - i++; - } - } else { - //some items were inserted - //so we update model and emit signal with row number - //of first moved/added item - //signal is needed to scroll a view to proper position after - //some items were added updateModel(); - emit m_q->scrollTo(lastRow + 1, - QAbstractItemView::PositionAtTop); - } + //i is the index of first added item + emit m_q->scrollTo(i, QAbstractItemView::PositionAtTop); + } } else { - updateModel(); + // items added to an empty list - add all as a single block + addItemBlock(itemsList); } CACLIENTTEST_FUNC_EXIT("CaItemModelPrivate::handleAddItems"); } @@ -890,12 +892,10 @@ foreach (index, oldPersistentIndexList) { newPersistentIndexList << m_q->createIndex( - newPositionsList.at(index.row()), - 0, - index.internalPointer()); + newPositionsList.at(index.row()), 0, index.internalPointer()); } - - m_q->changePersistentIndexList(oldPersistentIndexList, newPersistentIndexList); + m_q->changePersistentIndexList( + oldPersistentIndexList, newPersistentIndexList); m_q->layoutChanged(); CACLIENTTEST_FUNC_EXIT("CaItemModelPrivate::updateLayout"); diff -r a6d55a2e75be -r 782e3408c2ab contentstorage/caclient/src/caitemmodellist.cpp --- a/contentstorage/caclient/src/caitemmodellist.cpp Fri Mar 26 13:00:55 2010 +0200 +++ b/contentstorage/caclient/src/caitemmodellist.cpp Fri Apr 16 14:45:49 2010 +0300 @@ -49,7 +49,6 @@ { CACLIENTTEST_FUNC_ENTRY("CaItemModelList::clear"); mOrderedList.clear(); - qDeleteAll(mEntriesHash); mEntriesHash.clear(); CACLIENTTEST_FUNC_EXIT("CaItemModelList::clear"); } @@ -68,7 +67,7 @@ \param row of model list \retval entry at row */ -CaEntry *CaItemModelList::at(int row) const +QSharedPointer CaItemModelList::at(int row) const { int id = mOrderedList[row]; return mEntriesHash.value(id); @@ -83,7 +82,7 @@ CACLIENTTEST_FUNC_ENTRY("CaItemModelList::reloadEntries"); clear(); int id=0; - QList eList = mService->getEntries(query); + QList< QSharedPointer > eList = mService->getEntries(query); for (int i = 0; i < eList.count(); i++) { id = eList[i]->id(); mOrderedList << id; @@ -100,7 +99,6 @@ { CACLIENTTEST_FUNC_ENTRY("CaItemModelList::updateEntry"); if (mEntriesHash.contains(id)) { - delete mEntriesHash.take(id); mEntriesHash.insert(id, mService->getEntry(id)); } CACLIENTTEST_FUNC_EXIT("CaItemModelList::updateEntry"); @@ -155,7 +153,7 @@ { CACLIENTTEST_FUNC_ENTRY("CaItemModelList::remove"); if (mEntriesHash.contains(id)) { - delete mEntriesHash.take(id); + mEntriesHash.remove(id); } mOrderedList.removeOne(id); CACLIENTTEST_FUNC_EXIT("CaItemModelList::remove"); diff -r a6d55a2e75be -r 782e3408c2ab contentstorage/caclient/src/caservice.cpp --- a/contentstorage/caclient/src/caservice.cpp Fri Mar 26 13:00:55 2010 +0200 +++ b/contentstorage/caclient/src/caservice.cpp Fri Apr 16 14:45:49 2010 +0300 @@ -103,15 +103,15 @@ \endcode */ -CaEntry *CaService::getEntry(int entryId) const +QSharedPointer CaService::getEntry(int entryId) const { - QList entries = getEntries(QList () << entryId); + QList< QSharedPointer > entries = getEntries(QList () << entryId); if (entries.count()) { // there should be exactly one entry with specified ID if present Q_ASSERT(entries.count() == 1); return entries[0]; } else { - return NULL; + return QSharedPointer(); } } @@ -135,7 +135,7 @@ \endcode */ -QList CaService::getEntries(const QList &entryIdList) const +QList< QSharedPointer > CaService::getEntries(const QList &entryIdList) const { return m_d->getEntries(entryIdList); } @@ -162,7 +162,7 @@ \endcode */ -QList CaService::getEntries(const CaQuery &query) const +QList< QSharedPointer > CaService::getEntries(const CaQuery &query) const { return m_d->getEntries(query); } @@ -216,7 +216,7 @@ ... \endcode */ -CaEntry *CaService::createEntry(const CaEntry &entry) const +QSharedPointer CaService::createEntry(const CaEntry &entry) const { return m_d->createEntry(entry); } @@ -284,15 +284,15 @@ \example \code ... - bool result = service->removeEntries( QList() << newItem ); + bool result = service->removeEntries( QList< QSharedPointer >() << newItem ); \b Output: result == true \endcode */ -bool CaService::removeEntries(const QList &entryList) const +bool CaService::removeEntries(const QList< QSharedPointer > &entryList) const { QList idList; - CaEntry *entry(NULL); + QSharedPointer entry; foreach(entry, entryList) { idList << entry->id(); } @@ -449,10 +449,10 @@ \endcode */ bool CaService::insertEntriesIntoGroup(const CaEntry &group, - const QList &entryList, int beforeEntryId) const + const QList< QSharedPointer > &entryList, int beforeEntryId) const { QList idList; - CaEntry *entry(NULL); + QSharedPointer entry; foreach(entry, entryList) { idList << entry->id(); } @@ -563,10 +563,10 @@ \endcode */ bool CaService::removeEntriesFromGroup(const CaEntry &group, - const QList &entryList) const + const QList< QSharedPointer > &entryList) const { QList idList; - CaEntry *entry(NULL); + QSharedPointer entry; foreach(entry, entryList) { idList << entry->id(); } @@ -681,17 +681,17 @@ itemToAppend.setTypeName( "TypeNameAppend" ); CaEntry * entryToAppend = service->createEntry( itemToAppend ); bool result = service->appendEntriesToGroup( - *newGroup, QList() << entryToAppend ); + *newGroup, QList< QSharedPointer >() << entryToAppend ); ... \b Output: result == true \endcode */ bool CaService::appendEntriesToGroup(const CaEntry &group, - const QList &entryList) const + const QList< QSharedPointer > &entryList) const { QList idList; - CaEntry *entry(NULL); + QSharedPointer entry; foreach(entry, entryList) { idList << entry->id(); } @@ -797,10 +797,10 @@ \endcode */ bool CaService::prependEntriesToGroup(const CaEntry &group, - const QList &entryList) const + const QList< QSharedPointer > &entryList) const { QList idList; - CaEntry *entry(NULL); + QSharedPointer entry; foreach(entry, entryList) { idList << entry->id(); } @@ -831,11 +831,10 @@ { bool result = false; - CaEntry *const temporaryEntry = getEntry(entryId); + const QSharedPointer temporaryEntry = getEntry(entryId); - if (temporaryEntry != NULL) { + if (!temporaryEntry.isNull()) { result = executeCommand(*temporaryEntry, command); - delete temporaryEntry; } return result; } @@ -957,14 +956,14 @@ \param entryIdList list of entry ids \retval list of entries (pointers) */ -QList CaServicePrivate::getEntries(const QList &entryIdList) const +QList< QSharedPointer > CaServicePrivate::getEntries(const QList &entryIdList) const { qDebug() << "CaServicePrivate::getEntries" << "entryIdList:" << entryIdList; CACLIENTTEST_FUNC_ENTRY("CaServicePrivate::getEntries"); - QList resultList; + QList< QSharedPointer > resultList; mErrorCode = mProxy->getData(entryIdList, resultList); @@ -987,9 +986,9 @@ \param query the query information to select specific entries. \param placeholder list of entries for a specific select. */ -QList CaServicePrivate::getEntries(const CaQuery &query) const +QList< QSharedPointer > CaServicePrivate::getEntries(const CaQuery &query) const { - QList resultList; + QList< QSharedPointer > resultList; mErrorCode = mProxy->getData(query, resultList); @@ -1019,36 +1018,29 @@ \param query const reference to entry to copy \retval pointer to newely created copy */ -CaEntry *CaServicePrivate::createEntry(const CaEntry &entry) +QSharedPointer CaServicePrivate::createEntry(const CaEntry &entry) { qDebug() << "CaServicePrivate::createEntry" << "entry id:" << entry.id(); CACLIENTTEST_FUNC_ENTRY("CaServicePrivate::createEntry"); - CaEntry *newEntry = NULL; ErrorCode addDataResult = NoErrorCode; - try { - newEntry = new CaEntry(entry.role()); + QSharedPointer newEntry (new CaEntry(entry.role())); - QScopedPointer entryClone(new CaEntry(entry)); - - const int nonExistingObjectId = 0; - - CaObjectAdapter::setId(*entryClone, nonExistingObjectId); + QScopedPointer entryClone(new CaEntry(entry)); + const int nonExistingObjectId = 0; + CaObjectAdapter::setId(*entryClone, nonExistingObjectId); - addDataResult = - mProxy->addData(*entryClone, *newEntry); - } catch (const std::bad_alloc &) { - addDataResult = OutOfMemoryErrorCode; - } + addDataResult = + mProxy->addData(*entryClone, *newEntry); + // return empty pointer if nothing was added if (addDataResult != NoErrorCode) { - delete newEntry; - newEntry = NULL; + newEntry.clear(); } - + mErrorCode = addDataResult; qDebug() << "CaServicePrivate::createEntry mErrorCode:" << mErrorCode; diff -r a6d55a2e75be -r 782e3408c2ab contentstorage/caclient/stub/inc/caclientproxy.h --- a/contentstorage/caclient/stub/inc/caclientproxy.h Fri Mar 26 13:00:55 2010 +0200 +++ b/contentstorage/caclient/stub/inc/caclientproxy.h Fri Apr 16 14:45:49 2010 +0300 @@ -109,7 +109,7 @@ * @param sourceList List of results. * @return error code */ - ErrorCode getData(const QList& entryIdList, QList& sourceList); + ErrorCode getData(const QList& entryIdList, QList< QSharedPointer >& sourceList); /** * Method for fetching entries. @@ -118,7 +118,7 @@ * @param sourceList List of results. * @return error code */ - ErrorCode getData(const CaQuery &query, QList& sourceList); + ErrorCode getData(const CaQuery &query, QList< QSharedPointer >& sourceList); /** * Method for fetching entries. @@ -178,6 +178,7 @@ const QList &entryIds, const QList &parentIds, QString &query); + int getEntryIdByUid(const CaEntry &entry, const int uid); private: QString mWidgetRegistryPath; diff -r a6d55a2e75be -r 782e3408c2ab contentstorage/caclient/stub/inc/canotifiers.h --- a/contentstorage/caclient/stub/inc/canotifiers.h Fri Mar 26 13:00:55 2010 +0200 +++ b/contentstorage/caclient/stub/inc/canotifiers.h Fri Apr 16 14:45:49 2010 +0300 @@ -38,6 +38,8 @@ static void Notify(int groupId); + static void NotifyTouched(int id); + static void Notify(const CaEntry &targetEntry, ChangeType changeType, QList &parentIds); @@ -58,4 +60,4 @@ }; -#endif // CANOTIFIERS_H \ No newline at end of file +#endif // CANOTIFIERS_H diff -r a6d55a2e75be -r 782e3408c2ab contentstorage/caclient/stub/src/caclientproxy.cpp --- a/contentstorage/caclient/stub/src/caclientproxy.cpp Fri Mar 26 13:00:55 2010 +0200 +++ b/contentstorage/caclient/stub/src/caclientproxy.cpp Fri Apr 16 14:45:49 2010 +0300 @@ -32,6 +32,7 @@ #include "canotifier_p.h" #include "canotifiers.h" +#include "caclient_defines.h" #include "hswidgetregistryservice.h" const char *DATABASE_CONNECTION_NAME = "CaService"; @@ -47,7 +48,7 @@ // //---------------------------------------------------------------------------- CaClientProxy::CaClientProxy() : - mWidgetRegistryPath("hsresources/import/widgetregistry") + mWidgetRegistryPath("private/20022F35/import/widgetregistry") { } @@ -278,10 +279,10 @@ qDebug() << "CaClientProxy::removeData" << "entryIdList: " << entryIdList; - QList entryList; + QList< QSharedPointer > entryList; getData(entryIdList, entryList); QList > parentsIds; - foreach(CaEntry *entry, entryList) { + foreach(QSharedPointer entry, entryList) { QList parentIds; GetParentsIds(QList() << entry->id(), parentIds); parentsIds.append(parentIds); @@ -486,7 +487,7 @@ // //---------------------------------------------------------------------------- ErrorCode CaClientProxy::getData(const QList &entryIdList, - QList &sourceList) + QList< QSharedPointer > &sourceList) { qDebug() << "CaClientProxy::getData" << "entryIdList: " << entryIdList; @@ -507,7 +508,7 @@ qDebug() << query.executedQuery(); int role = query.value(query.record().indexOf("EN_ROLE")).toInt(); - CaEntry *entry = new CaEntry((EntryRole) role); + QSharedPointer entry (new CaEntry((EntryRole) role)); CaObjectAdapter::setId(*entry, query.value(query.record().indexOf("ENTRY_ID")).toInt()); entry->setText(query.value( @@ -571,7 +572,7 @@ // //---------------------------------------------------------------------------- ErrorCode CaClientProxy::getData(const CaQuery &query, - QList &sourceList) + QList< QSharedPointer > &sourceList) { QList entryIdList; ErrorCode errorCode = getEntryIds(query, entryIdList); @@ -709,7 +710,12 @@ { qDebug() << "CaClientProxy::executeCommand" << "entry id: " << entry.id() << "command: " << command; - return NoErrorCode; + + ErrorCode result = NoErrorCode; + if (command != caCmdOpen && command != QString("remove")) { + result = UnknownErrorCode; + } + return result; } //---------------------------------------------------------------------------- @@ -717,7 +723,12 @@ //---------------------------------------------------------------------------- ErrorCode CaClientProxy::touch(const CaEntry &entry) { - const int id = entry.id(); + int id = entry.id(); + if (id <= 0) { + const int uid = entry.attribute( + QString(APPLICATION_UID_ATTRIBUTE_NAME)).toInt(); + id = getEntryIdByUid(entry, uid); + } qDebug() << "CaClientProxy::touch" << "id: " << id; @@ -742,11 +753,11 @@ ErrorCode error = NoErrorCode; if (success) { query.exec("commit"); - QList entryList; + QList< QSharedPointer > entryList; if (getData(QList() << id, entryList) == NoErrorCode) { QList parentIds; GetParentsIds(QList() << id, parentIds); - CaNotifiers::Notify(*entryList[0], UpdateChangeType, parentIds); + CaNotifiers::NotifyTouched(id); } } else { query.exec("rollback"); @@ -1018,3 +1029,19 @@ } return success; } + +int CaClientProxy::getEntryIdByUid(const CaEntry &entry, const int uid) +{ + int result = -1; + + QSqlQuery query(dbConnection()); + query.prepare("SELECT ENTRY_ID from CA_ENTRY where EN_UID=?"); + query.addBindValue(uid); + bool success = query.exec(); + + if (success && (query.first())) { + result = query.value(query.record().indexOf("ENTRY_ID")).toInt(); + } + + return result; +} diff -r a6d55a2e75be -r 782e3408c2ab contentstorage/caclient/stub/src/camenuiconutility.cpp --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/contentstorage/caclient/stub/src/camenuiconutility.cpp Fri Apr 16 14:45:49 2010 +0300 @@ -0,0 +1,59 @@ +/* + * 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: + * + */ + +#include +#include +#include + +#include "camenuiconutility.h" +#include "caicondescription.h" +#include "caentry.h" + +/*! + Get icon when uid is defined. + \param entry const reference to CaEntry. + \param sie const reference to icon size. + \retval icon. + */ +HbIcon CaMenuIconUtility::getApplicationIcon(int uid, + const QSize &size) +{ + HbIcon icon; + return icon; +} + +/*! + Get icon. + \param entry const reference to CaEntry. + \param sie const reference to icon size. + \retval icon. + */ +HbIcon CaMenuIconUtility::getEntryIcon(const CaEntry& entry, + const QSize &size) +{ + HbIcon icon; + QString filename(entry.iconDescription().filename()); + if (!filename.isEmpty()) { + icon = HbIcon(filename); + } + if (icon.isNull() || !(icon.size().isValid())) { + icon = HbIcon(QDir(".").absoluteFilePath("resource/application.png")); + } + return icon; +} + + diff -r a6d55a2e75be -r 782e3408c2ab contentstorage/caclient/stub/src/canotifiers.cpp --- a/contentstorage/caclient/stub/src/canotifiers.cpp Fri Mar 26 13:00:55 2010 +0200 +++ b/contentstorage/caclient/stub/src/canotifiers.cpp Fri Apr 16 14:45:49 2010 +0300 @@ -55,6 +55,20 @@ } } +void CaNotifiers::NotifyTouched(int id) +{ + for (NotifierHash::const_iterator i = mNotifiers.constBegin(); + i != mNotifiers.constEnd(); + ++i) { + const CaNotifierFilter *filter = i.key().first; + if (filter->getIds().isEmpty() || filter->getIds().contains(id)) { + if (i.key().second == CaNotifierPrivate::EntryTouchedNotifierType) { + i.value()->entryTouched(id); + } + } + } +} + void CaNotifiers::Notify(const CaEntry &targetEntry, ChangeType changeType, QList &parentIds) diff -r a6d55a2e75be -r 782e3408c2ab contentstorage/caclient/stub/src/caobjectadapter.cpp --- a/contentstorage/caclient/stub/src/caobjectadapter.cpp Fri Mar 26 13:00:55 2010 +0200 +++ b/contentstorage/caclient/stub/src/caobjectadapter.cpp Fri Apr 16 14:45:49 2010 +0300 @@ -33,9 +33,10 @@ QString filename(entry.iconDescription().filename()); if (!filename.isEmpty()) { icon = HbIcon(filename); + //icon.addBadge( Qt::AlignTop | Qt::AlignRight, HbIcon("qtg_small_hs_widget")); } if (icon.isNull() || !(icon.size().isValid())) { - icon = HbIcon(QDir(".").absoluteFilePath("resource/application.png")); + icon = HbIcon("qtg_large_application"); } return icon; } diff -r a6d55a2e75be -r 782e3408c2ab contentstorage/caclient/stub/src/hswidgetregistryservice.cpp --- a/contentstorage/caclient/stub/src/hswidgetregistryservice.cpp Fri Mar 26 13:00:55 2010 +0200 +++ b/contentstorage/caclient/stub/src/hswidgetregistryservice.cpp Fri Apr 16 14:45:49 2010 +0300 @@ -22,7 +22,6 @@ #include "hswidgetregistryservice.h" #include "hswidgetregistryservice_p.h" #include "hswidgetprovidermanifest.h" -#include "servicefinder.h" const char POSTERURI[] = "homescreen.nokia.com/widget/poster/"; const char POSTERWIDGETNAME[] = "name"; diff -r a6d55a2e75be -r 782e3408c2ab contentstorage/cahandler/app/app.pri --- a/contentstorage/cahandler/app/app.pri Fri Mar 26 13:00:55 2010 +0200 +++ b/contentstorage/cahandler/app/app.pri Fri Apr 16 14:45:49 2010 +0300 @@ -8,5 +8,6 @@ # Nokia Corporation - initial contribution. # Contributors: # Description: -HEADERS += ./inc/*.h ../inc/*.h + +HEADERS += ./inc/*.h SOURCES += ./src/*.cpp diff -r a6d55a2e75be -r 782e3408c2ab contentstorage/cahandler/app/app.pro --- a/contentstorage/cahandler/app/app.pro Fri Mar 26 13:00:55 2010 +0200 +++ b/contentstorage/cahandler/app/app.pro Fri Apr 16 14:45:49 2010 +0300 @@ -39,7 +39,6 @@ -lecom \ -lswinstcli \ -lcautils \ - -lcaclient \ -lapgrfx \ -lws32 \ -lapparc \ @@ -47,8 +46,9 @@ -leikcore \ -lcone \ -lefsrv \ + -lsif \ + -lscrclient \ -lxqutils - exists($${EPOCROOT}epoc32/include/mw/XQSettingsManager):LIBS += -lxqsettingsmanager } diff -r a6d55a2e75be -r 782e3408c2ab contentstorage/cahandler/app/inc/caapphandler.h --- a/contentstorage/cahandler/app/inc/caapphandler.h Fri Mar 26 13:00:55 2010 +0200 +++ b/contentstorage/cahandler/app/inc/caapphandler.h Fri Apr 16 14:45:49 2010 +0300 @@ -24,13 +24,14 @@ class CEikonEnv; class CCaInnerEntry; class CCaUninstallOperation; +class CCaUsifUninstallOperation; /** * Command handler for application entries. * * @lib caclient.lib */ -NONSHARABLE_CLASS( CCaAppHandler ) +NONSHARABLE_CLASS( CCaAppHandler ): public CBase { public: @@ -72,18 +73,48 @@ */ void LaunchApplicationL( const TUid aUid, const TDesC8 &aParam, TInt aViewId ); - + /** * Closes application * @param aEntry the entry represeting application to close */ void CloseApplicationL( CCaInnerEntry& aEntry ); + /** + * Uninstall application + * @param aEntry the entry represeting application to uninstall + */ + void HandleRemoveL( CCaInnerEntry &aEntry ); + + /** + * Gets component id + * @param aEntry the entry + * @param aSoftwareType indicates software type + * @return component id + */ + TInt GetComponentIdL( const CCaInnerEntry &aEntry, + const TDesC& aSoftwareType ); + + /** + * Start uninstall operation via usif + * @param aComponentId component id + */ + void StartUsifUninstallL( TInt aComponentId ); + + + /** + * Start uninstall operation via swi + * @param aEntry the entry + */ + void StartSwiUninstallL(CCaInnerEntry &aEntry ); + + private: // data CEikonEnv* iEikEnv; CCaUninstallOperation* iUninstallOperation; + CCaUsifUninstallOperation* iUsifUninstallOperation; }; #endif // C_CAAPPHANDLER_H diff -r a6d55a2e75be -r 782e3408c2ab contentstorage/cahandler/app/inc/cas60apphandleradapter.h --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/contentstorage/cahandler/app/inc/cas60apphandleradapter.h Fri Apr 16 14:45:49 2010 +0300 @@ -0,0 +1,38 @@ +/* + * 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: + * + */ + +#ifndef CA_S60_APP_HANDLER_ADAPTER_H +#define CA_S60_APP_HANDLER_ADAPTER_H + +#include +#include + +#include "cahandler.h" + +class CCaInnerEntry; + +class CaS60AppHandlerAdapter: public QObject, public CaHandler +{ + Q_OBJECT + Q_INTERFACES(CaHandler) + +public: + int execute(CCaInnerEntry &innerEntry, const QString &commandName); + +}; + +#endif // CA_S60_APP_HANDLER_ADAPTER_H diff -r a6d55a2e75be -r 782e3408c2ab contentstorage/cahandler/app/inc/causifuninstalloperation.h --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/contentstorage/cahandler/app/inc/causifuninstalloperation.h Fri Apr 16 14:45:49 2010 +0300 @@ -0,0 +1,86 @@ +/* + * Copyright (c) 2008 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: ?Description + * + */ + +#ifndef C_CAUSIFUNINSTALLOPERATION_H +#define C_CAUSIFUNINSTALLOPERATION_H + +#include +#include + +using namespace Usif; + +/** + * Uninstall Operation + * Encapsulates the functionality of uninstalling an application. + * + * @lib caclient.lib + */ +NONSHARABLE_CLASS(CCaUsifUninstallOperation): public CActive { + +public: + /** + * Destructor + */ + virtual ~CCaUsifUninstallOperation(); + + /** + * Two-phased constructor. Leaves on failure. + * Allocates memory for and constructs an uninstaller object. After that + * starts asynchronous uninnstallation of the requested entry + * @param aEntry entry to be uninstalled + * @param aPriority priority of the active scheduler responsible for handling + * asynchronous installation operation + * @return The constructed object. + */ + static CCaUsifUninstallOperation *NewL(TComponentId, TInt aPriority = + CActive::EPriorityStandard); + +private: + // construction + /** + * Constructor. + * Starts active scheduler. + * @param aEntry entry to be uninstalle + * @param aPriority priority of the active scheduler responsible for handling + * asynchronous installation operation + */ + CCaUsifUninstallOperation(TInt aPriority); + + /** + * Initializes the object and starts asynchronous uninstallation process. + * @param aEntry entry to be uninstalle + * asynchronous installation operation + */ + void ConstructL(TComponentId aComponentId); + + + +private: + // from CActive + + void RunL(); + void DoCancel(); + TInt RunError(TInt aError); + +private: + COpaqueNamedParams* iArguments; + COpaqueNamedParams* iResults; + + RSoftwareInstall iUninstaller; +}; + +#endif // C_CAUSIFUNINSTALLOPERATION_H diff -r a6d55a2e75be -r 782e3408c2ab contentstorage/cahandler/app/resource/caapphandlerplugin.s60xml --- a/contentstorage/cahandler/app/resource/caapphandlerplugin.s60xml Fri Mar 26 13:00:55 2010 +0200 +++ /dev/null Thu Jan 01 00:00:00 1970 +0000 @@ -1,13 +0,0 @@ - - - caapphandlerplugin - z:/hsresources/plugins/commandhandler/caapphandlerplugin.qtplugin - - - com.nokia.homescreen.ICommandHandler - 1.0 - - - application - - diff -r a6d55a2e75be -r 782e3408c2ab contentstorage/cahandler/app/src/caapphandler.cpp --- a/contentstorage/cahandler/app/src/caapphandler.cpp Fri Mar 26 13:00:55 2010 +0200 +++ b/contentstorage/cahandler/app/src/caapphandler.cpp Fri Apr 16 14:45:49 2010 +0300 @@ -24,15 +24,20 @@ #include #include +#include +#include + #include "caapphandler.h" #include "cainnerentry.h" #include "cauninstalloperation.h" -#include"catasklist.h" +#include "causifuninstalloperation.h" +#include "catasklist.h" #include "cautils.h" #include "cadef.h" // ======== MEMBER FUNCTIONS ======== +using namespace Usif; // --------------------------------------------------------------------------- // @@ -41,6 +46,7 @@ CCaAppHandler::~CCaAppHandler() { delete iUninstallOperation; + delete iUsifUninstallOperation; } // --------------------------------------------------------------------------- @@ -64,6 +70,7 @@ { iEikEnv = CEikonEnv::Static(); iUninstallOperation = NULL; + iUsifUninstallOperation = NULL; } // --------------------------------------------------------------------------- @@ -81,11 +88,12 @@ void CCaAppHandler::HandleCommandL( CCaInnerEntry &aEntry, const TDesC8 &aCommand ) { + if( aCommand == KCaCmdOpen() && aEntry.GetEntryTypeName() == KCaTypeApp() ) { TInt viewId(-1); - TBuf viewIdValue; + TPtrC viewIdValue; if( aEntry.FindAttribute( KCaAttrView(), viewIdValue ) ) { if( MenuUtils::GetTUint( viewIdValue, (TUint &) viewId ) @@ -102,17 +110,9 @@ { CloseApplicationL( aEntry ); } - else if ( aCommand == KCaCmdRemove() - && ( aEntry.GetEntryTypeName() == KCaTypeApp() - || aEntry.GetEntryTypeName() == KCaTypeWidget() ) ) + else if ( aCommand == KCaCmdRemove() ) { - if ( iUninstallOperation && iUninstallOperation->IsActive() ) - { - User::Leave( KErrInUse ); - } - delete iUninstallOperation; - iUninstallOperation = NULL; - iUninstallOperation = CCaUninstallOperation::NewL( aEntry ); + HandleRemoveL(aEntry); } else { @@ -149,20 +149,22 @@ } else { - TApaAppInfo appInfo; + // TApaAppInfo size is greater then 1024 bytes + // so its instances should not be created on the stack. + TApaAppInfo* appInfo = new( ELeave ) TApaAppInfo; + CleanupStack::PushL( appInfo ); TApaAppCapabilityBuf capabilityBuf; RApaLsSession appArcSession; User::LeaveIfError( appArcSession.Connect() ); CleanupClosePushL( appArcSession ); - User::LeaveIfError( appArcSession.GetAppInfo( appInfo, aUid ) ); + User::LeaveIfError( appArcSession.GetAppInfo( *appInfo, aUid ) ); User::LeaveIfError( appArcSession.GetAppCapability( capabilityBuf, aUid ) ); TApaAppCapability &caps = capabilityBuf(); - TFileName appName = appInfo.iFullName; CApaCommandLine *cmdLine = CApaCommandLine::NewLC(); - cmdLine->SetExecutableNameL( appName ); + cmdLine->SetExecutableNameL( appInfo->iFullName ); if( caps.iLaunchInBackground ) { @@ -179,6 +181,7 @@ CleanupStack::PopAndDestroy( cmdLine ); CleanupStack::PopAndDestroy( &appArcSession ); + CleanupStack::PopAndDestroy( appInfo ); } CleanupStack::PopAndDestroy( &wsSession ); } @@ -218,3 +221,103 @@ CleanupStack::PopAndDestroy( &wsSession ); } +// --------------------------------------------------------------------------- +// +// --------------------------------------------------------------------------- +// +void CCaAppHandler::HandleRemoveL( CCaInnerEntry &aEntry ) +{ + if (!( aEntry.GetFlags() & ERemovable ) ) + { + User::Leave( KErrAccessDenied ); + } + if ( aEntry.GetEntryTypeName() == KCaTypeApp() ) + { + TComponentId componentId( GetComponentIdL( aEntry,KSoftwareTypeJava ) ); + if ( componentId != KErrNotFound ) + { + StartUsifUninstallL( componentId ); + } + else + { + StartSwiUninstallL( aEntry ); + } + } + else if ( aEntry.GetEntryTypeName() == KCaTypeWidget() ) + { + StartSwiUninstallL( aEntry ); + } + else if( aEntry.GetEntryTypeName() == KCaTypePackage() ) + { + TPtrC componentId; + if ( aEntry.FindAttribute( KCaAttrComponentId, componentId ) ) + { + TInt32 id ; + TLex idDesc; + idDesc.Assign( componentId ); + User::LeaveIfError( idDesc.Val( id ) ); + StartUsifUninstallL( id ); + } + } + else + { + User::Leave( KErrNotSupported ); + } +} + +// --------------------------------------------------------------------------- +// +// --------------------------------------------------------------------------- +// +TInt CCaAppHandler::GetComponentIdL( const CCaInnerEntry &aEntry, + const TDesC& aSoftwareType ) +{ + TInt id(KErrNotFound); + RSoftwareComponentRegistry scr; + CleanupClosePushL(scr); + User::LeaveIfError(scr.Connect()); + CComponentFilter* compFilter = CComponentFilter::NewLC(); + compFilter->AddPropertyL(_L("Uid"), aEntry.GetUid()); + compFilter->SetSoftwareTypeL(aSoftwareType); + RArray componentIdList; + CleanupClosePushL(componentIdList); + scr.GetComponentIdsL(componentIdList, compFilter); + if (componentIdList.Count() > 0) + { + id = componentIdList[0]; + } + CleanupStack::PopAndDestroy(&componentIdList); + CleanupStack::PopAndDestroy(compFilter); + CleanupStack::PopAndDestroy(&scr); + return id; +} + +// --------------------------------------------------------------------------- +// +// --------------------------------------------------------------------------- +// +void CCaAppHandler::StartUsifUninstallL( TInt aComponentId ) +{ + if ( iUsifUninstallOperation && iUsifUninstallOperation->IsActive() ) + { + User::Leave( KErrInUse ); + } + delete iUsifUninstallOperation; + iUsifUninstallOperation = NULL; + iUsifUninstallOperation = CCaUsifUninstallOperation::NewL( aComponentId ); +} + +// --------------------------------------------------------------------------- +// +// --------------------------------------------------------------------------- +// +void CCaAppHandler::StartSwiUninstallL(CCaInnerEntry &aEntry ) +{ + if ( iUninstallOperation && iUninstallOperation->IsActive() ) + { + User::Leave( KErrInUse ); + } + delete iUninstallOperation; + iUninstallOperation = NULL; + iUninstallOperation = CCaUninstallOperation::NewL( aEntry ); +} diff -r a6d55a2e75be -r 782e3408c2ab contentstorage/cahandler/app/src/caapphandlerplugin.cpp --- a/contentstorage/cahandler/app/src/caapphandlerplugin.cpp Fri Mar 26 13:00:55 2010 +0200 +++ b/contentstorage/cahandler/app/src/caapphandlerplugin.cpp Fri Apr 16 14:45:49 2010 +0300 @@ -19,11 +19,11 @@ #include #include #include + #include "cahandlerloader.h" - #include "caapphandler.h" #include "caapphandlerplugin.h" -#include "cas60handleradapter.h" +#include "cas60apphandleradapter.h" /*! \class CaAppHandlerPlugin @@ -47,13 +47,12 @@ if (descriptor.interfaceName() == "com.nokia.homescreen.ICommandHandler") { - return new CaS60HandlerAdapter; + return new CaS60AppHandlerAdapter(); } else { return 0; } } -// TODO: uncomment when it will be used in plugin -//Q_EXPORT_PLUGIN2(caapphandlerplugin, CaAppHandlerPlugin) +Q_EXPORT_PLUGIN2(caapphandlerplugin, CaAppHandlerPlugin) /*! @@ -81,7 +80,7 @@ */ /*! - \fn int CaS60HandlerAdapter::execute(const CaEntry &entry, const QString &commandName) + \fn int CaS60HandlerAdapter::execute(const CaEntry &entry, const QString &commandName) \param entry Subject of the command. \param commandName The name of the command to execute. \return 0 on success, error code otherwise. diff -r a6d55a2e75be -r 782e3408c2ab contentstorage/cahandler/app/src/cas60apphandleradapter.cpp --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/contentstorage/cahandler/app/src/cas60apphandleradapter.cpp Fri Apr 16 14:45:49 2010 +0300 @@ -0,0 +1,34 @@ +/* + * Copyright (c) 2008 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: ?Description + * + */ + +#include +#include +#include + +#include "cas60apphandleradapter.h" +#include "caapphandler.h" +#include "cainnerentry.h" + +int CaS60AppHandlerAdapter::execute(CCaInnerEntry &innerEntry, const QString &commandName) +{ + QScopedPointer commandNameDesc8(XQConversions::qStringToS60Desc8(commandName)); + TRAPD(result, + static QScopedPointer plugin(CCaAppHandler::NewL()); + plugin->HandleCommandL(innerEntry, commandNameDesc8->Des()); + ); + return result; +} diff -r a6d55a2e75be -r 782e3408c2ab contentstorage/cahandler/app/src/cauninstalloperation.cpp --- a/contentstorage/cahandler/app/src/cauninstalloperation.cpp Fri Mar 26 13:00:55 2010 +0200 +++ b/contentstorage/cahandler/app/src/cauninstalloperation.cpp Fri Apr 16 14:45:49 2010 +0300 @@ -18,6 +18,7 @@ #include #include #include + #include "cautils.h" #include "cadef.h" #include "cainnerentry.h" @@ -69,7 +70,6 @@ // void CCaUninstallOperation::ConstructL(CCaInnerEntry &aEntry) { - TBuf uidAttr; TUint uid = aEntry.GetUid(); TUid packageUid = KNullUid; @@ -112,11 +112,15 @@ CleanupClosePushL(apaLsSession); User::LeaveIfError(apaLsSession.GetAllApps()); - TApaAppInfo appInfo; - User::LeaveIfError(apaLsSession.GetAppInfo(appInfo, aAppUid)); - if (!GetInstallPkgUidL(appInfo.iFullName, aPackageUid)) { + // TApaAppInfo size is greater then 1024 bytes + // so its instances should not be created on the stack. + TApaAppInfo* appInfo = new(ELeave) TApaAppInfo(); + CleanupStack::PushL(appInfo); + User::LeaveIfError(apaLsSession.GetAppInfo(*appInfo, aAppUid)); + if (!GetInstallPkgUidL(appInfo->iFullName, aPackageUid)) { aPackageUid = aAppUid; } + CleanupStack::PopAndDestroy(appInfo); aMimeType.Set(KAppMimeType); CleanupStack::PopAndDestroy(&apaLsSession); diff -r a6d55a2e75be -r 782e3408c2ab contentstorage/cahandler/app/src/causifuninstalloperation.cpp --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/contentstorage/cahandler/app/src/causifuninstalloperation.cpp Fri Apr 16 14:45:49 2010 +0300 @@ -0,0 +1,103 @@ +/* + * Copyright (c) 2008 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: ?Description + * + */ + +#include +#include "cautils.h" +#include "cadef.h" +#include "cainnerentry.h" +#include "causifuninstalloperation.h" + +// ================= MEMBER FUNCTIONS ======================= + +// --------------------------------------------------------------------------- +// CCaUsifUninstallOperation::~CCaUsifUninstallOperation +// --------------------------------------------------------------------------- +// +CCaUsifUninstallOperation::~CCaUsifUninstallOperation() + { + Cancel(); + delete iArguments; + delete iResults; + iUninstaller.Close(); + } + +// --------------------------------------------------------------------------- +// CCaUsifUninstallOperation::NewL +// --------------------------------------------------------------------------- +// +CCaUsifUninstallOperation *CCaUsifUninstallOperation::NewL( + TComponentId aComponentId, TInt aPriority) + { + CCaUsifUninstallOperation *self = new (ELeave) CCaUsifUninstallOperation( + aPriority); + CleanupStack::PushL(self); + self->ConstructL(aComponentId); + CleanupStack::Pop(self); + return self; + } + +// --------------------------------------------------------------------------- +// CCaUsifUninstallOperation::CCaUsifUninstallOperation +// --------------------------------------------------------------------------- +// +CCaUsifUninstallOperation::CCaUsifUninstallOperation( TInt aPriority ) : + CActive(aPriority), iUninstaller() + { + CActiveScheduler::Add(this); + } + +// --------------------------------------------------------------------------- +// CCaUsifUninstallOperation::ConstructL +// --------------------------------------------------------------------------- +// +void CCaUsifUninstallOperation::ConstructL(TComponentId aComponentId) + { + // Silent uninstallation request + User::LeaveIfError(iUninstaller.Connect()); + iArguments = COpaqueNamedParams::NewL(); + iResults = COpaqueNamedParams::NewL(); + iArguments->AddIntL(KSifInParam_InstallSilently, 1); + iUninstaller.Uninstall(aComponentId, *iArguments, *iResults, iStatus); + SetActive(); + } + +// --------------------------------------------------------------------------- +// CCaUsifUninstallOperation::RunL +// --------------------------------------------------------------------------- +// +void CCaUsifUninstallOperation::RunL() + { + iUninstaller.Close(); + } + +// --------------------------------------------------------------------------- +// CCaUsifUninstallOperation::DoCancel +// --------------------------------------------------------------------------- +// +void CCaUsifUninstallOperation::DoCancel() + { + iUninstaller.CancelOperation(); + } + +// --------------------------------------------------------------------------- +// CCaUsifUninstallOperation::RunError +// --------------------------------------------------------------------------- +// +TInt CCaUsifUninstallOperation::RunError(TInt /* aError */) + { + return KErrNone; + } diff -r a6d55a2e75be -r 782e3408c2ab contentstorage/cahandler/inc/cas60handleradapter.h --- a/contentstorage/cahandler/inc/cas60handleradapter.h Fri Mar 26 13:00:55 2010 +0200 +++ /dev/null Thu Jan 01 00:00:00 1970 +0000 @@ -1,55 +0,0 @@ -/* - * 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: - * - */ - -#ifndef CA_S60_HANDLER_ADAPTER_H -#define CA_S60_HANDLER_ADAPTER_H - -#include -#include -#include -#include -#include -#include -#include - -#include "cainnerentry.h" -#include "cahandler.h" -#include "caobjectadapter.h" - -template -class CaS60HandlerAdapter: public CaHandler -{ -public: - int execute(const CaEntry &entry, const QString &commandName) { - - QScopedPointer commandNameDesc8(XQConversions::qStringToS60Desc8(commandName)); - QScopedPointer innerEntry(NULL); - - TRAPD(result, - innerEntry.reset(CCaInnerEntry::NewL()); - CaObjectAdapter::convertL(entry, *innerEntry); - - static QScopedPointer plugin(Plugin::NewL()); - plugin->HandleCommandL(*innerEntry, commandNameDesc8->Des()); - ); - - return result; - } -}; - - -#endif diff -r a6d55a2e75be -r 782e3408c2ab contentstorage/cahandler/tapp/catapphandler.pro --- a/contentstorage/cahandler/tapp/catapphandler.pro Fri Mar 26 13:00:55 2010 +0200 +++ /dev/null Thu Jan 01 00:00:00 1970 +0000 @@ -1,47 +0,0 @@ -# -# 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: -# - -TEMPLATE = lib -TARGET = catapphandlerplugin -CONFIG += plugin mobility -MOBILITY = serviceframework - -PLUGIN_SUBDIR = /hsresources/plugins/commandhandler - - -include (../../../common.pri) - - -DEPENDPATH += ./inc \ - ./src \ - ../../caclient/s60/inc - -INCLUDEPATH += ./inc \ - ../../caclient/s60/inc - - -symbian: { - TARGET.UID3 = 0x20028710 - - - LIBS += -lxqservice \ - -lxqutils -# -lhsutils - -} - - -include(catapphandler.pri) diff -r a6d55a2e75be -r 782e3408c2ab contentstorage/cahandler/tapp/catapphandlerplugin.pri --- a/contentstorage/cahandler/tapp/catapphandlerplugin.pri Fri Mar 26 13:00:55 2010 +0200 +++ /dev/null Thu Jan 01 00:00:00 1970 +0000 @@ -1,20 +0,0 @@ -# -# 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: -# - -HEADERS += ./inc/*.h ../inc/*.h -SOURCES += ./src/*.cpp - - diff -r a6d55a2e75be -r 782e3408c2ab contentstorage/cahandler/tapp/inc/catapphandler.h --- a/contentstorage/cahandler/tapp/inc/catapphandler.h Fri Mar 26 13:00:55 2010 +0200 +++ b/contentstorage/cahandler/tapp/inc/catapphandler.h Fri Apr 16 14:45:49 2010 +0300 @@ -19,25 +19,23 @@ #define CATAPPHANDLER_H #include + #include "cahandler.h" -#include "cadefs.h" -class CaEntry; +class CCaInnerEntry; class XQApplicationManager; -const QString hsitemLaunchUri("item:launchuri"); - -class CaTappHandler: public CaHandler +class CaTappHandler: public QObject, public CaHandler { -Q_OBJECT + Q_OBJECT + Q_INTERFACES(CaHandler) public: - -explicit CaTappHandler(QObject *parent = 0); + explicit CaTappHandler(QObject *parent = 0); ~CaTappHandler(); Q_INVOKABLE - int execute(const CaEntry& entry, const QString& command); + int execute(CCaInnerEntry& innerEntry, const QString& command); private: XQApplicationManager* mAiwMgr; diff -r a6d55a2e75be -r 782e3408c2ab contentstorage/cahandler/tapp/inc/catapphandlerplugin.h --- a/contentstorage/cahandler/tapp/inc/catapphandlerplugin.h Fri Mar 26 13:00:55 2010 +0200 +++ b/contentstorage/cahandler/tapp/inc/catapphandlerplugin.h Fri Apr 16 14:45:49 2010 +0300 @@ -26,8 +26,8 @@ class CaTappHandlerPlugin: public QObject, public QServicePluginInterface { -Q_OBJECT -Q_INTERFACES(QtMobility::QServicePluginInterface) + Q_OBJECT + Q_INTERFACES(QtMobility::QServicePluginInterface) public: QObject *createInstance(const QServiceInterfaceDescriptor &descriptor, diff -r a6d55a2e75be -r 782e3408c2ab contentstorage/cahandler/tapp/resource/catapphandlerplugin.s60xml --- a/contentstorage/cahandler/tapp/resource/catapphandlerplugin.s60xml Fri Mar 26 13:00:55 2010 +0200 +++ /dev/null Thu Jan 01 00:00:00 1970 +0000 @@ -1,13 +0,0 @@ - - - catapphandlerplugin - z:/hsresources/plugins/commandhandler/catapphandlerplugin.qtplugin - Content Arsenal tapp handler plugin - - com.nokia.homescreen.ICommandHandler - 1.0 - executes commands on tapps - - - - diff -r a6d55a2e75be -r 782e3408c2ab contentstorage/cahandler/tapp/resource/catapphandlerplugin.xml --- a/contentstorage/cahandler/tapp/resource/catapphandlerplugin.xml Fri Mar 26 13:00:55 2010 +0200 +++ b/contentstorage/cahandler/tapp/resource/catapphandlerplugin.xml Fri Apr 16 14:45:49 2010 +0300 @@ -1,13 +1,13 @@ catapphandlerplugin - z:/hsresources/plugins/commandhandler/catapphandlerplugin.qtplugin + catapphandlerplugin Content Arsenal tapp handler plugin com.nokia.homescreen.ICommandHandler 1.0 executes commands on tapps - application + templatedApplication diff -r a6d55a2e75be -r 782e3408c2ab contentstorage/cahandler/tapp/src/catapphandler.cpp --- a/contentstorage/cahandler/tapp/src/catapphandler.cpp Fri Mar 26 13:00:55 2010 +0200 +++ b/contentstorage/cahandler/tapp/src/catapphandler.cpp Fri Apr 16 14:45:49 2010 +0300 @@ -18,11 +18,15 @@ #include #include #include - +#include #include #include "caentry.h" #include "catapphandler.h" +#include "cainnerentry.h" +#include "caclient_defines.h" + +_LIT(hsitemLaunchUri, "item:launchuri"); QTM_USE_NAMESPACE @@ -57,11 +61,15 @@ \param command Description of the command. \return Error code described in QSERVICEMANAGER.H */ -int CaTappHandler::execute(const CaEntry& entry, const QString& command) +int CaTappHandler::execute(CCaInnerEntry& innerEntry, const QString& command) { int error = 0; // this returns Error enum from QSERVICEMANAGER.H if (command == caCmdOpen) { - QUrl url(entry.attribute(hsitemLaunchUri)); // f.e. QUrl url ("application://101F7AE7?"); + TPtrC attribute; + innerEntry.FindAttribute(hsitemLaunchUri, attribute); + + // e.g. QUrl url ("application://101F7AE7?"); + QUrl url(QString::fromUtf16(attribute.Ptr(), attribute.Length())); QScopedPointer request(mAiwMgr->create(url, true)); if (!request.isNull()) { bool res = request->send(); diff -r a6d55a2e75be -r 782e3408c2ab contentstorage/cahandler/tapp/src/catapphandlerplugin.cpp --- a/contentstorage/cahandler/tapp/src/catapphandlerplugin.cpp Fri Mar 26 13:00:55 2010 +0200 +++ b/contentstorage/cahandler/tapp/src/catapphandlerplugin.cpp Fri Apr 16 14:45:49 2010 +0300 @@ -15,16 +15,9 @@ * */ -/*#include - #include - #include - */ - #include "catapphandlerplugin.h" #include "catapphandler.h" -#include - #ifdef COVERAGE_MEASUREMENT #pragma CTC SKIP #endif //COVERAGE_MEASUREMENT diff -r a6d55a2e75be -r 782e3408c2ab contentstorage/cahandler/tapp/tapp.pri --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/contentstorage/cahandler/tapp/tapp.pri Fri Apr 16 14:45:49 2010 +0300 @@ -0,0 +1,20 @@ +# +# 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: +# + +HEADERS += ./inc/*.h +SOURCES += ./src/*.cpp + + diff -r a6d55a2e75be -r 782e3408c2ab contentstorage/cahandler/tapp/tapp.pro --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/contentstorage/cahandler/tapp/tapp.pro Fri Apr 16 14:45:49 2010 +0300 @@ -0,0 +1,49 @@ +# +# 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: +# + +TEMPLATE = lib +TARGET = catapphandlerplugin +CONFIG += plugin mobility +MOBILITY = serviceframework + +PLUGIN_SUBDIR = /hsresources/plugins/commandhandler + + +include (../../../common.pri) + + +DEPENDPATH += ./inc \ + ./src + +INCLUDEPATH += ./inc \ + ../../caclient/inc \ + ../../caclient/s60/inc \ + ../../cautils/inc + + +symbian: { + TARGET.UID3 = 0x20028710 + + + LIBS += -lxqservice \ + -lxqutils \ + -lcautils +# -lhsutils + +} + + +include(tapp.pri) diff -r a6d55a2e75be -r 782e3408c2ab contentstorage/cahandler/url/inc/cas60urlhandleradapter.h --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/contentstorage/cahandler/url/inc/cas60urlhandleradapter.h Fri Apr 16 14:45:49 2010 +0300 @@ -0,0 +1,37 @@ +/* + * 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: + * + */ + +#ifndef CA_S60_URL_HANDLER_ADAPTER_H +#define CA_S60_URL_HANDLER_ADAPTER_H + +#include + +#include "cahandler.h" + +class CCaInnerEntry; + +class CaS60UrlHandlerAdapter: public QObject, public CaHandler +{ + Q_OBJECT + Q_INTERFACES(CaHandler) + +public: + int execute(CCaInnerEntry &innerEntry, const QString &commandName); + +}; + +#endif //CA_S60_URL_HANDLER_ADAPTER_H diff -r a6d55a2e75be -r 782e3408c2ab contentstorage/cahandler/url/inc/caurlhandler.h --- a/contentstorage/cahandler/url/inc/caurlhandler.h Fri Mar 26 13:00:55 2010 +0200 +++ b/contentstorage/cahandler/url/inc/caurlhandler.h Fri Apr 16 14:45:49 2010 +0300 @@ -34,7 +34,7 @@ * * @lib caclient.lib */ -NONSHARABLE_CLASS( CCaUrlHandler ) +NONSHARABLE_CLASS( CCaUrlHandler ): public CBase { public: diff -r a6d55a2e75be -r 782e3408c2ab contentstorage/cahandler/url/resource/caurlhandlerplugin.s60xml --- a/contentstorage/cahandler/url/resource/caurlhandlerplugin.s60xml Fri Mar 26 13:00:55 2010 +0200 +++ /dev/null Thu Jan 01 00:00:00 1970 +0000 @@ -1,13 +0,0 @@ - - - caurlhandlerplugin - z:/hsresources/plugins/commandhandler/caurlhandlerplugin.qtplugin - - - com.nokia.homescreen.ICommandHandler - 1.0 - - - url - - diff -r a6d55a2e75be -r 782e3408c2ab contentstorage/cahandler/url/src/cas60urlhandleradapter.cpp --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/contentstorage/cahandler/url/src/cas60urlhandleradapter.cpp Fri Apr 16 14:45:49 2010 +0300 @@ -0,0 +1,34 @@ +/* + * Copyright (c) 2008 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: ?Description + * + */ + +#include +#include +#include + +#include "cas60urlhandleradapter.h" +#include "caurlhandler.h" +#include "cainnerentry.h" + +int CaS60UrlHandlerAdapter::execute(CCaInnerEntry &innerEntry, const QString &commandName) +{ + QScopedPointer commandNameDesc8(XQConversions::qStringToS60Desc8(commandName)); + TRAPD(result, + static QScopedPointer plugin(CCaUrlHandler::NewL()); + plugin->HandleCommandL(innerEntry, commandNameDesc8->Des()); + ); + return result; +} diff -r a6d55a2e75be -r 782e3408c2ab contentstorage/cahandler/url/src/caurlhandlerplugin.cpp --- a/contentstorage/cahandler/url/src/caurlhandlerplugin.cpp Fri Mar 26 13:00:55 2010 +0200 +++ b/contentstorage/cahandler/url/src/caurlhandlerplugin.cpp Fri Apr 16 14:45:49 2010 +0300 @@ -22,7 +22,7 @@ #include "cahandlerloader.h" #include "caurlhandlerplugin.h" -#include "cas60handleradapter.h" +#include "cas60urlhandleradapter.h" #include "caurlhandler.h" /*! @@ -35,7 +35,7 @@ \param descriptor Service descriptor. \param context Ignored. \param session Ignored. - \return An instance of the CaS60HandlerAdapter when descriptor interface name + \return An instance of the CaS60UrlHandlerAdapter when descriptor interface name is "com.nokia.homescreen.ICommandHandler", NULL otherwise. */ QObject *CaUrlHandlerPlugin::createInstance(const QServiceInterfaceDescriptor &descriptor, @@ -47,10 +47,9 @@ if (descriptor.interfaceName() == "com.nokia.homescreen.ICommandHandler") { - return new CaS60HandlerAdapter; + return new CaS60UrlHandlerAdapter(); } else { return 0; } } -// TODO: uncomment when it will be a plugin -//Q_EXPORT_PLUGIN2(caurlhandlerplugin, CaUrlHandlerPlugin) +Q_EXPORT_PLUGIN2(caurlhandlerplugin, CaUrlHandlerPlugin) diff -r a6d55a2e75be -r 782e3408c2ab contentstorage/cahandler/url/url.pri --- a/contentstorage/cahandler/url/url.pri Fri Mar 26 13:00:55 2010 +0200 +++ b/contentstorage/cahandler/url/url.pri Fri Apr 16 14:45:49 2010 +0300 @@ -9,5 +9,5 @@ # Contributors: # Description: -HEADERS += ./inc/*.h ../inc/*.h +HEADERS += ./inc/*.h SOURCES += ./src/*.cpp diff -r a6d55a2e75be -r 782e3408c2ab contentstorage/cahandler/url/url.pro --- a/contentstorage/cahandler/url/url.pro Fri Mar 26 13:00:55 2010 +0200 +++ b/contentstorage/cahandler/url/url.pro Fri Apr 16 14:45:49 2010 +0300 @@ -39,7 +39,6 @@ -lecom \ -lswinstcli \ -lcautils \ - -lcaclient \ -lapgrfx \ -lws32 \ -lapparc \ diff -r a6d55a2e75be -r 782e3408c2ab contentstorage/casrv/caappscanner/group/caappscanner.mmp --- a/contentstorage/casrv/caappscanner/group/caappscanner.mmp Fri Mar 26 13:00:55 2010 +0200 +++ b/contentstorage/casrv/caappscanner/group/caappscanner.mmp Fri Apr 16 14:45:49 2010 +0300 @@ -57,3 +57,5 @@ LIBRARY efsrv.lib LIBRARY sisregistryclient.lib LIBRARY platformenv.lib +// temporary till cWRT will be in SCR +LIBRARY WidgetRegistryClient.lib diff -r a6d55a2e75be -r 782e3408c2ab contentstorage/casrv/caappscanner/inc/casrvappscanner.h --- a/contentstorage/casrv/caappscanner/inc/casrvappscanner.h Fri Mar 26 13:00:55 2010 +0200 +++ b/contentstorage/casrv/caappscanner/inc/casrvappscanner.h Fri Apr 16 14:45:49 2010 +0300 @@ -100,7 +100,7 @@ /** * Handle Install Event. * @since S60 v5.0 - * @param aUid installed uid. + * @param aUid installed/uninstalled app uid. */ void HandleInstallNotifyL( TInt aUid ); @@ -157,12 +157,39 @@ * @result id of download collection */ TInt GetCollectionDownloadIdL(); + + /** + * Gets collectionId of all collection + * @result id of all collection + */ + TInt GetAllCollectionIdL(); /** * Adds application entry to downloaded collection * @param aEntryId application entry id. */ void AddEntryToDownloadedCollectionL( TInt aEntryId ); + + /** + * Add application entry to predefined collection + * @param aEntry application entry. + * @param aUpdate is entry updated by a client + */ + void AddEntryToPredefinedCollectionL( CCaInnerEntry* aEntry, + TBool aUpdate = EFalse ); + + /** + * Create predefined collection + * @param aGroupName group name. + * @result id of new created collection + */ + TInt CreatePredefinedCollectionL( const TDesC& aGroupName ); + + /** + * Add collection to all collection. + * @param aCollectionId collection id to add. + */ + void AddCollectionToAllCollectionL( TInt aCollectionId ); /** * Removes application entry from downloaded collection @@ -210,7 +237,7 @@ * @param aUid uid applications * @return ETrue if app is in rom */ - TBool IsInRom( TInt aUid ); + TBool IsInRomL( TInt aUid ); /** * Get applications from AppArc @@ -238,9 +265,9 @@ * contains applications */ void RemoveSatAppL( RPointerArray& aArray ); - + /** - * Ensure that HsApplicaiton is not visible: Add HsApplication + * Ensure that HsApplicaiton is not visible: Add HsApplication * as hidden to CaStorage or remove HsApplication entry * from array (found in CaStorage). * @param aArray RPointerArray with CCaInnerEntries @@ -298,7 +325,7 @@ * Removes app from storage. * @param aAppEntry app to remove. */ - void CCaSrvAppScanner::RemoveAppL( CCaInnerEntry* aAppEntry ); + void RemoveAppL( CCaInnerEntry* aAppEntry ); /** * Adds flag objects(only one flag at time). @@ -333,7 +360,7 @@ * @param aDefaultDrive drive type. * @return ETrue if app is installed on given drive type. */ - TBool IsAppInDrive( const TUid aUid, + TBool IsAppInDriveL( const TUid aUid, const DriveInfo::TDefaultDrives& aDefaultDrive ) const; /** @@ -341,14 +368,14 @@ * @param aUid app uid. * @return ETrue if app is installed on MMC. */ - TBool IsInMmc( const TUid aUid ) const; + TBool IsInMmcL( const TUid aUid ) const; /** * Check if application is installed on mass storage. * @param aUid app uid. * @return ETrue if app is installed on mass storage. */ - TBool IsInMassStorage( const TUid aUid ) const; + TBool IsInMassStorageL( const TUid aUid ) const; /** * Check if drive's status is EDriveInUse. @@ -383,6 +410,17 @@ * Notifys storage abaut updated apps */ void InstallationNotifyL(); + + /** + * Make not empty collections with not hidden apps visible. + */ + void MakeNotEmptyCollectionsVisibleL(); + + /** + * Make collection visible if has visible entry. + * @param aEntry application entry + */ + void MakeCollectionVisibleIfHasVisibleEntryL( CCaInnerEntry* aEntry ); private: // data @@ -398,6 +436,7 @@ RArray iInstalledPackages; TInt iCollectionDownloadId; + TInt iAllCollectionId; CA_STORAGE_TEST_FRIEND_CLASS (T_casrvAppScaner) }; diff -r a6d55a2e75be -r 782e3408c2ab contentstorage/casrv/caappscanner/src/casrvappscanner.cpp --- a/contentstorage/casrv/caappscanner/src/casrvappscanner.cpp Fri Mar 26 13:00:55 2010 +0200 +++ b/contentstorage/casrv/caappscanner/src/casrvappscanner.cpp Fri Apr 16 14:45:49 2010 +0300 @@ -20,6 +20,7 @@ #include #include #include +#include #include "cadef.h" #include "casrvappscanner.h" @@ -32,6 +33,8 @@ #include "caarraycleanup.inl" #include "castorageproxy.h" + + // ==================== LOCAL FUNCTIONS ==================== /** @@ -135,6 +138,7 @@ User::LeaveIfError( iApaLsSession.GetAllApps() ); // This is async. iApaLsSession.RegisterListPopulationCompleteObserver( iStatus ); iCollectionDownloadId = 0; + iAllCollectionId = 0; SetActive(); } @@ -148,6 +152,7 @@ // AppArc app scan complete, we have the app list. UpdateApplicationEntriesL(); InstallationNotifyL(); + MakeNotEmptyCollectionsVisibleL(); } // --------------------------------------------------------- @@ -221,7 +226,7 @@ toUpdate = HandleMissingFlagUpdate( aEntry ) || toUpdate; toUpdate = HandleLockDeleteFlagUpdateL( aEntry ) || toUpdate; toUpdate = SetApaAppInfoL( aEntry ) || toUpdate; - + if( iInstalledPackages.Find( aEntry->GetUid() ) != KErrNotFound ) { AddEntryToDownloadedCollectionL( aEntry->GetId() ); @@ -232,6 +237,7 @@ //update app in storage iCaStorageProxy.AddL( aEntry ); RemoveFromInstalledPackages( aEntry->GetUid() ); + AddEntryToPredefinedCollectionL( aEntry, ETrue ); } } // --------------------------------------------------------- @@ -275,14 +281,14 @@ CCaInnerEntry* aItem, TUint aMmcId ) { TBool toUpdate( ETrue ); - if( IsInMmc( TUid::Uid( aItem->GetUid() ) ) ) + if( IsInMmcL( TUid::Uid( aItem->GetUid() ) ) ) { //app is instaled on mmc - KCaAttrMmcId attribute update TBuf uidString; uidString.Format( KHexFormat, aMmcId ); aItem->AddAttributeL( KCaAttrMmcId, uidString ); } - else if ( IsInMassStorage( TUid::Uid( aItem->GetUid() ) ) ) + else if ( IsInMassStorageL( TUid::Uid( aItem->GetUid() ) ) ) { //its app installed on mass storage, we need to leave it //in case of connecting usb in mass storage mode @@ -362,7 +368,7 @@ { TBool toChange( EFalse ); TBool isVisible = ( ( aItem->GetFlags() & EVisible ) != 0 ); - if( isVisible && IsInRom( aItem->GetUid() ) ) + if( isVisible && IsInRomL( aItem->GetUid() ) ) { if( ( aItem->GetFlags() & ERemovable ) != 0 ) { @@ -441,21 +447,21 @@ appEntry->SetUid( KHsAppUid.iUid ); TInt index = aArray.Find( appEntry, TIdentityRelation( UidMatch ) ); - + if ( index != KErrNotFound ) { // hs app already in storage - ensure it is hidden and remove from resultArray if ( ( aArray[index]->GetFlags() & EVisible ) != 0 ) { aArray[index]->SetFlags( aArray[index]->GetFlags() & ~EVisible); iCaStorageProxy.AddL( aArray[index] ); - } + } delete aArray[index]; - aArray.Remove( index ); + aArray.Remove( index ); } else { // if not found add as not visible to the storage appEntry->SetEntryTypeNameL( KCaTypeApp ); - appEntry->SetFlags( 0 ); + appEntry->SetFlags( 0 ); appEntry->SetRole( EItemEntryRole ); SetApaAppInfoL( appEntry ); iCaStorageProxy.AddL( appEntry ); @@ -470,23 +476,25 @@ // void CCaSrvAppScanner::GetApaItemsL( RArray& aArray ) { - TApaAppInfo appInfo; + TApaAppInfo* appInfo = new(ELeave) TApaAppInfo(); + CleanupStack::PushL(appInfo); TApaAppCapabilityBuf appCap; User::LeaveIfError( iApaLsSession.GetAllApps( 0 ) ); // for every application get uid, hidden and missing attribute // and add to aArray. - while( KErrNone == iApaLsSession.GetNextApp( appInfo ) ) + while( KErrNone == iApaLsSession.GetNextApp( *appInfo ) ) { User::LeaveIfError( iApaLsSession.GetAppCapability( - appCap, appInfo.iUid ) ); + appCap, appInfo->iUid ) ); // "Hidden" status according to AppArc. if( !appCap().iAppIsHidden ) { - TCaAppAtributes appAtributes( appInfo.iUid.iUid ); + TCaAppAtributes appAtributes( appInfo->iUid.iUid ); aArray.AppendL( appAtributes ); } } + CleanupStack::PopAndDestroy(appInfo); } // --------------------------------------------------------- @@ -534,6 +542,36 @@ } // --------------------------------------------------------- +// CCaSrvAppScanner::GetAllCollectionIdL +// --------------------------------------------------------- +// +TInt CCaSrvAppScanner::GetAllCollectionIdL() + { + if( iAllCollectionId == 0 ) + { + CCaInnerQuery *getAllCollectionIdQuery = CCaInnerQuery::NewLC(); + CDesC16ArrayFlat *typenameArray = new(ELeave) CDesC16ArrayFlat( + KDefaultGranularity ); + CleanupStack::PushL( typenameArray ); + typenameArray->AppendL( KCaTypeMenuCollections ); + getAllCollectionIdQuery->SetEntryTypeNames( typenameArray ); + CleanupStack::Pop( typenameArray ); + + RArray idArray; + CleanupClosePushL( idArray ); + iCaStorageProxy.GetEntriesIdsL( getAllCollectionIdQuery, + idArray ); + if( idArray.Count() ) + { + iAllCollectionId = idArray[0]; + } + CleanupStack::PopAndDestroy( &idArray ); + CleanupStack::PopAndDestroy( getAllCollectionIdQuery ); + } + return iAllCollectionId; + } + +// --------------------------------------------------------- // CCaSrvAppScanner::GetMcsItemsL // --------------------------------------------------------- // @@ -652,7 +690,7 @@ void CCaSrvAppScanner::AddEntryToDownloadedCollectionL( TInt aEntryId ) { TCaOperationParams params = { TCaOperationParams::EPrepend, GetCollectionDownloadIdL(), 0 // not used - }; + }; RArray entryIds; CleanupClosePushL( entryIds ); @@ -663,13 +701,124 @@ } // --------------------------------------------------------- +// CCaSrvAppScanner::AddEntryToPredefinedCollectionL +// --------------------------------------------------------- +// +void CCaSrvAppScanner::AddEntryToPredefinedCollectionL( + CCaInnerEntry* aEntry, TBool aUpdate ) + { + TApaAppCapabilityBuf capability; + User::LeaveIfError( iApaLsSession.GetAppCapability( capability, + TUid::Uid( aEntry->GetUid() ) ) ); + + if( capability().iGroupName.Length() ) + { + // appgroup_name is defined for this app. Find or create folder. + CCaInnerQuery *innerQuery = CCaInnerQuery::NewLC(); + innerQuery->SetRole( CCaInnerQuery::Group ); + innerQuery->AddAttributeL( KCaAppGroupName, + capability().iGroupName ); + + // get entries by attributes + RPointerArray resultArrayItems; + CleanupResetAndDestroyPushL( resultArrayItems ); + iCaStorageProxy.GetEntriesL( innerQuery, resultArrayItems ); + + RArray entryIds; + CleanupClosePushL( entryIds ); + TInt entryId = aEntry->GetId(); + entryIds.AppendL( entryId ); + TCaOperationParams organizeParams; + organizeParams.iBeforeEntryId = 0; + + if( resultArrayItems.Count() ) + { + // collection with appgroup_name exist - add entry + // to this collection + organizeParams.iGroupId = resultArrayItems[0]->GetId(); + } + else + { + // create new collection + TInt predefinedCollectionId = CreatePredefinedCollectionL( + capability().iGroupName ); + + organizeParams.iGroupId = predefinedCollectionId; + + // add new collection to all collection + AddCollectionToAllCollectionL( predefinedCollectionId ); + + if( aUpdate ) + { + organizeParams.iOperationType = TCaOperationParams::EAppend; + iCaStorageProxy.OrganizeL( entryIds, organizeParams ); + } + } + + if( !aUpdate ) + { + organizeParams.iOperationType = TCaOperationParams::EAppend; + iCaStorageProxy.OrganizeL( entryIds, organizeParams ); + } + + CleanupStack::PopAndDestroy( &entryIds ); + CleanupStack::PopAndDestroy( &resultArrayItems ); + CleanupStack::PopAndDestroy( innerQuery ); + } + } + +// --------------------------------------------------------- +// CCaSrvAppScanner::CreatePredefinedCollectionL +// --------------------------------------------------------- +// +TInt CCaSrvAppScanner::CreatePredefinedCollectionL( const TDesC& aGroupName ) + { + CCaInnerEntry *innerEntry = CCaInnerEntry::NewLC(); + innerEntry->SetTextL( aGroupName ); + innerEntry->SetEntryTypeNameL( KCaTypeCollection ); + innerEntry->SetRole( CCaInnerQuery::Group ); + innerEntry->AddAttributeL( KCaAppGroupName, aGroupName ); + innerEntry->SetFlags( EVisible ); + innerEntry->SetFlags( innerEntry->GetFlags() | ERemovable ); + _LIT( KCollectionIconFileName, "qtg_large_applications_user"); + innerEntry->SetIconDataL( KCollectionIconFileName, + KNullDesC, KNullDesC ); + iCaStorageProxy.AddL( innerEntry ); + // Get new collection Id + TInt newCollectionId = innerEntry->GetId(); + CleanupStack::PopAndDestroy( innerEntry ); + + return newCollectionId; + } + +// --------------------------------------------------------- +// CCaSrvAppScanner::AddCollectionToAllCollectionL +// --------------------------------------------------------- +// +void CCaSrvAppScanner::AddCollectionToAllCollectionL( TInt aCollectionId ) + { + RArray entryIds; + CleanupClosePushL( entryIds ); + entryIds.AppendL( aCollectionId ); + + TCaOperationParams organizeParams; + organizeParams.iBeforeEntryId = 0; + organizeParams.iOperationType = TCaOperationParams::EAppend; + organizeParams.iGroupId = GetAllCollectionIdL(); + iCaStorageProxy.OrganizeL( entryIds, organizeParams ); + CleanupStack::PopAndDestroy( &entryIds ); + } + + + +// --------------------------------------------------------- // CCaSrvAppScanner::RemoveToDownloadedCollectionL // --------------------------------------------------------- // void CCaSrvAppScanner::RemoveEntryFromDownloadedL( TInt aEntryId ) { TCaOperationParams params = { TCaOperationParams::ERemove, GetCollectionDownloadIdL(), 0 // not used - }; + }; RArray entryIds; CleanupClosePushL( entryIds ); @@ -713,6 +862,9 @@ HandleMmcAttrUpdateL( appEntry, aCurrentMmcId ); iCaStorageProxy.AddL( appEntry ); + + AddEntryToPredefinedCollectionL( appEntry ); + if( iInstalledPackages.Find( aUid ) != KErrNotFound ) { AddEntryToDownloadedCollectionL( appEntry->GetId() ); @@ -759,6 +911,29 @@ changed = ETrue; } CleanupStack::PopAndDestroy( &attrVal ); + // check if its java app and add attr for entrys + TUid appTypeUid; + if( KErrNone == iApaLsSession.GetAppType( appTypeUid, info.iUid ) ) + { + if( appTypeUid == KMidletApplicationTypeUid ) + { + aEntry->AddAttributeL( KCaAttrAppType, KCaAttrAppTypeValueJava ); + aEntry->AddAttributeL( KCaAttrAppSettingsPlugin, KCaAttrJavaAppSettingsPluginValue ); + } + else if (appTypeUid == KCWRTApplicationTypeUid) + { + aEntry->AddAttributeL( KCaAttrAppType, KCaAttrAppTypeValueCWRT ); + aEntry->AddAttributeL( KCaAttrAppWidgetUri, KCaAttrAppWidgetUriCWRTValue ); + // web id should be taken from SCR when supported + RWidgetRegistryClientSession wrtSession; + CleanupClosePushL(wrtSession); + User::LeaveIfError( wrtSession.Connect()); + TFileName bundleId; + wrtSession.GetWidgetBundleId(info.iUid, bundleId); + aEntry->AddAttributeL( KCaAttrAppWidgetParamWebAppId, bundleId ); + CleanupStack::PopAndDestroy(&wrtSession); + } + } } return changed; } @@ -794,12 +969,13 @@ } else { - RemoveAppL( aCaEntries[i] ); + //RemoveAppL( aCaEntries[i] ); + AddObjectFlagL( aCaEntries[i], EMissing ); } } else { - RemoveAppL( aCaEntries[i] ); + AddObjectFlagL( aCaEntries[i], EMissing ); } CleanupStack::PopAndDestroy( &attrVal ); } @@ -898,48 +1074,49 @@ } // --------------------------------------------------------- -// CCaSrvAppScanner::IsAppInDrive +// CCaSrvAppScanner::IsAppInDriveL // --------------------------------------------------------- // -TBool CCaSrvAppScanner::IsAppInDrive( +TBool CCaSrvAppScanner::IsAppInDriveL( const TUid aUid, const DriveInfo::TDefaultDrives& aDefaultDrive ) const { TBool ret( EFalse ); - TApaAppInfo info; - TInt err = iApaLsSession.GetAppInfo( info, aUid ); - if( !err && IsFileInDrive( info.iFullName, aDefaultDrive ) ) + TApaAppInfo* appInfo = new( ELeave ) TApaAppInfo(); + TInt err = iApaLsSession.GetAppInfo( *appInfo, aUid ); + if( !err && IsFileInDrive( appInfo->iFullName, aDefaultDrive ) ) { ret = ETrue; } + delete appInfo; return ret; } // --------------------------------------------------------- -// CCaSrvAppScanner::IsInMmc +// CCaSrvAppScanner::IsInMmcL // --------------------------------------------------------- // -TBool CCaSrvAppScanner::IsInMmc( const TUid aUid ) const +TBool CCaSrvAppScanner::IsInMmcL( const TUid aUid ) const { - return IsAppInDrive( aUid, DriveInfo::EDefaultRemovableMassStorage ); + return IsAppInDriveL( aUid, DriveInfo::EDefaultRemovableMassStorage ); } // --------------------------------------------------------- -// CCaSrvAppScanner::IsInMassStorage +// CCaSrvAppScanner::IsInMassStorageL // --------------------------------------------------------- // -TBool CCaSrvAppScanner::IsInMassStorage( const TUid aUid ) const +TBool CCaSrvAppScanner::IsInMassStorageL( const TUid aUid ) const { - return IsAppInDrive( aUid, DriveInfo::EDefaultMassStorage ); + return IsAppInDriveL( aUid, DriveInfo::EDefaultMassStorage ); } // --------------------------------------------------------- -// CCaSrvAppScanner::IsInRom +// CCaSrvAppScanner::IsInRomL // --------------------------------------------------------- // -TBool CCaSrvAppScanner::IsInRom( TInt aUid ) +TBool CCaSrvAppScanner::IsInRomL( TInt aUid ) { - return IsAppInDrive( TUid::Uid( aUid ), DriveInfo::EDefaultRom ); + return IsAppInDriveL( TUid::Uid( aUid ), DriveInfo::EDefaultRom ); } // --------------------------------------------------------- @@ -966,6 +1143,54 @@ return inUse; } +void CCaSrvAppScanner::MakeNotEmptyCollectionsVisibleL() + { + RPointerArray resultArray; + CleanupResetAndDestroyPushL( resultArray ); + CCaInnerQuery* hiddenCollectionsQuery = CCaInnerQuery::NewLC(); + CDesC16ArrayFlat* entryType = new ( ELeave ) CDesC16ArrayFlat( + KGranularityOne ); + CleanupStack::PushL( entryType ); + entryType->AppendL( KCaTypeCollection ); + hiddenCollectionsQuery->SetEntryTypeNames( entryType ); + hiddenCollectionsQuery->SetFlagsOff( EVisible ); + iCaStorageProxy.GetEntriesL( hiddenCollectionsQuery, resultArray ); + CleanupStack::Pop( entryType ); + CleanupStack::PopAndDestroy( hiddenCollectionsQuery ); + if( resultArray.Count() ) + { + for( TInt i=0; i resultEntriesArray; + CleanupResetAndDestroyPushL( resultEntriesArray ); + CCaInnerQuery* visibleEntriesQuery = CCaInnerQuery::NewLC(); + visibleEntriesQuery->SetParentId( aEntry->GetId() ); + visibleEntriesQuery->SetFlagsOn( EVisible ); + visibleEntriesQuery->SetFlagsOff( EMissing ); + iCaStorageProxy.GetEntriesL( visibleEntriesQuery, resultEntriesArray ); + if( resultEntriesArray.Count() ) + { + // set collection visible if hidden + if( HandleHiddenFlagUpdateL( aEntry ) ) + { + // update here this collection + iCaStorageProxy.AddL( aEntry, ETrue ); + } + } + CleanupStack::PopAndDestroy( visibleEntriesQuery ); + CleanupStack::PopAndDestroy( &resultEntriesArray ); + } + // ==================== MEMBER FUNCTIONS ==================== // --------------------------------------------------------- diff -r a6d55a2e75be -r 782e3408c2ab contentstorage/casrv/carunningappmonitor/group/carunningappmonitor.mmp --- a/contentstorage/casrv/carunningappmonitor/group/carunningappmonitor.mmp Fri Mar 26 13:00:55 2010 +0200 +++ b/contentstorage/casrv/carunningappmonitor/group/carunningappmonitor.mmp Fri Apr 16 14:45:49 2010 +0300 @@ -39,7 +39,6 @@ USERINCLUDE ../../../inc USERINCLUDE ../../../srvinc USERINCLUDE ../../../cautils/inc -USERINCLUDE ../../../domain/menu_content_service_api/inc APP_LAYER_SYSTEMINCLUDE diff -r a6d55a2e75be -r 782e3408c2ab contentstorage/casrv/causifscanner/data/causifscanner.rss --- a/contentstorage/casrv/causifscanner/data/causifscanner.rss Fri Mar 26 13:00:55 2010 +0200 +++ b/contentstorage/casrv/causifscanner/data/causifscanner.rss Fri Apr 16 14:45:49 2010 +0300 @@ -12,7 +12,7 @@ * Contributors: * * Description: caappscanner.rss -* ECOM DLL UID: 2002870A +* ECOM DLL UID: 2002870A * ECOM interface UID: (KCaSrvPluginInterfaceUid) * ECOM Implementation: 2002870B * diff -r a6d55a2e75be -r 782e3408c2ab contentstorage/casrv/causifscanner/group/causifscanner.mmp --- a/contentstorage/casrv/causifscanner/group/causifscanner.mmp Fri Mar 26 13:00:55 2010 +0200 +++ b/contentstorage/casrv/causifscanner/group/causifscanner.mmp Fri Apr 16 14:45:49 2010 +0300 @@ -52,3 +52,4 @@ LIBRARY cautils.lib LIBRARY camenu.lib LIBRARY bafl.lib +LIBRARY efsrv.lib diff -r a6d55a2e75be -r 782e3408c2ab contentstorage/casrv/causifscanner/inc/causifscanner.h --- a/contentstorage/casrv/causifscanner/inc/causifscanner.h Fri Mar 26 13:00:55 2010 +0200 +++ b/contentstorage/casrv/causifscanner/inc/causifscanner.h Fri Apr 16 14:45:49 2010 +0300 @@ -24,6 +24,8 @@ #include #include "casrvplugin.h" +#include "cainstallnotifier.h" +#include "cammcwatcher.h" class CCaStorageProxy; class CCaInnerEntry; @@ -33,45 +35,166 @@ /* An implementation of the CCaSrvPlugin interface for the Reference Installer. - The CaSrvManager loads and uses this plug-in when the MIME type of a package is 'binary/sif-refpkg'. + The CaSrvManager loads and uses this plug-in when the MIME type of a package + is 'binary/sif-refpkg'. */ -NONSHARABLE_CLASS(CCaUsifScanner): public CCaSrvPlugin +NONSHARABLE_CLASS(CCaUsifScanner): public CCaSrvPlugin, + public MCaInstallListener, public MMmcWatcherCallback { public: + + /** + * Two-phased constructor. + * @param aPLuginParam plugin param consist of storage, storage utils. + * @retval New object. + */ static CCaUsifScanner* NewL( TPluginParams* aPluginParams ); + + /** + * Destructor. + */ ~CCaUsifScanner(); - void InstallL( const TDesC& aFileName ); + /** + * Installs application. + * @param aFileName File name to be installed. + */ + // void InstallL( const TDesC& aFileName ); + +public: + // from MCaInstallListener + + /** + * Handle Install/Uninstall Event. + * @since S60 v5.0 + * @param aUid installed uid. + */ + void HandleInstallNotifyL( TInt aUid ); + + /** + * MmcChangeL is called when the MMC is removed or inserted. + */ + void MmcChangeL(); private: + + /** + * Constructor + * @param aStorageProxy Storage handler. + */ CCaUsifScanner( CCaStorageProxy& aStorageProxy ); + + /** + * Second phased constructor. + */ void ConstructL(); + + /** + * Copy constructor. + */ CCaUsifScanner( const CCaUsifScanner & ); + + /** + * Operator "=". Assigns new object. + * + */ CCaUsifScanner& operator =( const CCaUsifScanner & ); - void AddCollectionUsifL(); - TInt GetCollectionUsifIdL(); - + /** + * Creates AppLib's entry from Usif's entry + * @param aEntry Usif entry obtained from Sif database. + * @param aCaEntry AppLib entry to be filled from Usif entry. + */ void CreateCaEntryFromEntryL( const CComponentEntry* aEntry, CCaInnerEntry* aCaEntry ); - void AddNativeAppsL(); + /** + * Adds package to database. Scans Sif db and adds entries to AppLib db. + */ + void AddPackageL(); + + /** + * Updates package in the database. + */ + void UpdatePackagesL(); + + /** + * Gets entries from AppLib story. + * @param aArray Array of entries to be obtained from db. + */ + void GetCaPackageEntriesL( RPointerArray& aArray ); + + /** + * Gets entries from Usif story. + * @param aArray Array of entries to be obtained from db. + */ + void GetUsifPackageEntriesL( RPointerArray& aArray ); - void GetCaAppEntriesL( RPointerArray& aArray ); + /** + * Checks if entry exists in AppLib db. + * @param aArray Array of entries from AppLib db. + * @param aEntry Entry data to be checked if exists. + * @retval Returns array index if exists, otherwise KErrNotFound. + */ + TInt PackageExistL( RPointerArray& aArray, + const CComponentEntry* aEntry ); - TInt AppExist( RPointerArray& aArray, - CCaInnerEntry* aEntry ); + /** + * Finds deleted entries from Usif. Updates aCaArray. + * @param aCaArray Entries from AppLib db. + * @param aUsifArray Entries from Usif db. + */ + void FindDeletedEntriesL( RPointerArray& aCaArray, + const RPointerArray& aUsifArray ); + + /** + * Removes entries from db. + * @param aCaArray Entries to be removed. + */ + void RemoveEntriesFromDbL( RPointerArray& aCaArray ); + + /** + * Update usif list. + */ + void UpdateUsifListL(); private: - /* + /** * not own + * Storage proxy. */ CCaStorageProxy& iStorageProxy; - /* - * Usif Collection id. Temporary solution. + /** + * Install notifier. Own. + */ + CCaInstallNotifier *iSystemInstallNotifier; + + /** + * Uninstall notifier. Own. + */ + CCaInstallNotifier *iUsifUninstallNotifier; + + /** + * Install and uninstall notifier. Own. */ - TInt iCollectionUsifId; + CCaInstallNotifier *iJavaInstallNotifier; + + /** + * File session. Own + */ + RFs iFs; + + /** + * Mmc watcher. Own. + */ + CCaMmcWatcher* iMmcWatcher; + + /** + * Software component registry. Own. + */ + RSoftwareComponentRegistry iSoftwareRegistry; + }; #endif // CAUSIFSCANNER_H diff -r a6d55a2e75be -r 782e3408c2ab contentstorage/casrv/causifscanner/src/causifscanner.cpp --- a/contentstorage/casrv/causifscanner/src/causifscanner.cpp Fri Mar 26 13:00:55 2010 +0200 +++ b/contentstorage/casrv/causifscanner/src/causifscanner.cpp Fri Apr 16 14:45:49 2010 +0300 @@ -31,17 +31,14 @@ using namespace Usif; -_LIT( KUsifPluginCollection, "Usif collection"); -_LIT( KCaAttrComponentId, "component_id" ); - // --------------------------------------------------------------------------- // // --------------------------------------------------------------------------- // CCaUsifScanner* CCaUsifScanner::NewL( TPluginParams* aPluginParams ) { - CCaUsifScanner* self = new ( ELeave ) - CCaUsifScanner( *aPluginParams->storageProxy ); + CCaUsifScanner* self = new ( ELeave ) CCaUsifScanner( + *aPluginParams->storageProxy ); CleanupStack::PushL( self ); self->ConstructL(); CleanupStack::Pop( self ); @@ -55,7 +52,6 @@ CCaUsifScanner::CCaUsifScanner( CCaStorageProxy& aStorageProxy ) : iStorageProxy( aStorageProxy ) { - } // --------------------------------------------------------------------------- @@ -64,8 +60,21 @@ // void CCaUsifScanner::ConstructL() { - AddCollectionUsifL(); - AddNativeAppsL(); + iSystemInstallNotifier = CCaInstallNotifier::NewL( *this, + CCaInstallNotifier::ESisInstallNotification ); + + iUsifUninstallNotifier = CCaInstallNotifier::NewL( *this, + CCaInstallNotifier::EUsifUninstallNotification ); + + iJavaInstallNotifier = CCaInstallNotifier::NewL( *this, + CCaInstallNotifier::EJavaInstallNotification ); + + User::LeaveIfError( iFs.Connect() ); + iMmcWatcher = CCaMmcWatcher::NewL( iFs, this ); + + User::LeaveIfError( iSoftwareRegistry.Connect() ); + + UpdateUsifListL(); } // --------------------------------------------------------------------------- @@ -74,84 +83,65 @@ // CCaUsifScanner::~CCaUsifScanner() { - } - -// --------------------------------------------------------------------------- -// -// --------------------------------------------------------------------------- -// -void CCaUsifScanner::InstallL( const TDesC& aFileName ) - { - RSoftwareInstall sif; - CleanupClosePushL( sif ); - User::LeaveIfError( sif.Connect()); - - // Install the component - TRequestStatus status; - sif.Install( aFileName, status, EFalse ); - User::WaitForRequest( status ); - User::LeaveIfError(status.Int()); - - // Disconnect from the SIF server - CleanupStack::PopAndDestroy( &sif ); + delete iMmcWatcher; + delete iSystemInstallNotifier; + delete iUsifUninstallNotifier; + delete iJavaInstallNotifier; + iFs.Close(); + iSoftwareRegistry.Close(); } // --------------------------------------------------------------------------- // // --------------------------------------------------------------------------- // -void CCaUsifScanner::AddCollectionUsifL() +/*void CCaUsifScanner::InstallL( const TDesC& aFileName ) + { + RSoftwareInstall sif; + CleanupClosePushL( sif ); + User::LeaveIfError( sif.Connect()); + + // Install the component + TRequestStatus status; + sif.Install( aFileName, status, EFalse ); + User::WaitForRequest( status ); + User::LeaveIfError(status.Int()); + + // Disconnect from the SIF server + CleanupStack::PopAndDestroy( &sif ); + }*/ + +// --------------------------------------------------------------------------- +// +// --------------------------------------------------------------------------- +// +void CCaUsifScanner::HandleInstallNotifyL( TInt /*aUid*/) { - if( GetCollectionUsifIdL() == 0 ) - { - CCaInnerEntry *entry = CCaInnerEntry::NewLC(); - entry->SetRole( EGroupEntryRole ); - entry->SetEntryTypeNameL( KCaTypeCollection ); - entry->SetFlags( ERemovable | EVisible ); - entry->SetTextL( KUsifPluginCollection ); - iStorageProxy.AddL( entry ); - iCollectionUsifId = entry->GetId(); - CleanupStack::PopAndDestroy( entry ); - - TCaOperationParams params = - { - TCaOperationParams::EPrepend, 2, 0 - }; - RArray ids; - CleanupClosePushL( ids ); - ids.AppendL( iCollectionUsifId ); - iStorageProxy.OrganizeL( ids, params ); - CleanupStack::PopAndDestroy( &ids ); - } + UpdateUsifListL(); } // --------------------------------------------------------------------------- // // --------------------------------------------------------------------------- // -TInt CCaUsifScanner::GetCollectionUsifIdL() +#ifdef COVERAGE_MEASUREMENT +#pragma CTC SKIP +#endif //COVERAGE_MEASUREMENT +void CCaUsifScanner::MmcChangeL() { - if( iCollectionUsifId == 0 ) - { - RPointerArray resultArray; - CleanupResetAndDestroyPushL( resultArray ); - CCaInnerQuery* allAppQuery = CCaInnerQuery::NewLC(); - CDesC16ArrayFlat* appType = new ( ELeave ) CDesC16ArrayFlat( 1 ); - CleanupStack::PushL( appType ); - appType->AppendL( KCaTypeCollection ); - allAppQuery->SetEntryTypeNames( appType ); - allAppQuery->SetRole(CCaInnerQuery::Group); - CleanupStack::Pop( appType ); - iStorageProxy.GetEntriesL( allAppQuery, resultArray ); - CleanupStack::PopAndDestroy( allAppQuery ); - for(TInt i(0); i< resultArray.Count(); i++ ) - { - if(!resultArray[i]->GetText().Compare(KUsifPluginCollection)) - iCollectionUsifId = resultArray[i]->GetId(); - } - CleanupStack::PopAndDestroy( &resultArray ); - } - return iCollectionUsifId; + UpdateUsifListL(); + } +#ifdef COVERAGE_MEASUREMENT +#pragma CTC ENDSKIP +#endif //COVERAGE_MEASUREMENT +// --------------------------------------------------------------------------- +// +// --------------------------------------------------------------------------- +// +void CCaUsifScanner::UpdateUsifListL() + { + AddPackageL(); + UpdatePackagesL(); } // --------------------------------------------------------------------------- @@ -162,10 +152,19 @@ const CComponentEntry* aEntry, CCaInnerEntry* aCaEntry ) { aCaEntry->SetRole( EItemEntryRole ); - aCaEntry->SetEntryTypeNameL(KCaTypeApp); - if( aEntry->Name().Compare(KNullDesC)) + aCaEntry->SetEntryTypeNameL( KCaTypePackage ); + if( !aEntry->SoftwareType().Compare( KSoftwareTypeNative ) ) + { + aCaEntry->AddAttributeL( KCaAttrAppType, KCaAttrAppTypeValueNative ); + } + else if( !aEntry->SoftwareType().Compare( KSoftwareTypeJava ) ) { - aCaEntry->SetTextL(aEntry->Name()); + aCaEntry->AddAttributeL( KCaAttrAppType, KCaAttrAppTypeValueJava ); + } + if( aEntry->Name().Compare( KNullDesC ) ) + { + aCaEntry->SetTextL( aEntry->Name() ); + aCaEntry->AddAttributeL( KCaAttrLongName, aEntry->Name() ); } if( !aEntry->IsHidden() ) { @@ -175,92 +174,77 @@ { aCaEntry->SetFlags( aCaEntry->GetFlags() | ERemovable ); } - if( aEntry->GlobalId().Compare( KNullDesC ) ) - { - TLex lex( aEntry->GlobalId() ); - TUint uint( 0 ); - User::LeaveIfError( lex.Val( uint, EHex ) ); - aCaEntry->SetUid( uint ); - } + // entries obtained with usif should have component id. + //it's needed for uninstalling RBuf compIdDesc; - CleanupClosePushL(compIdDesc); - compIdDesc.CreateL(KCaMaxAttrValueLen); - compIdDesc.Num(aEntry->ComponentId()); + CleanupClosePushL( compIdDesc ); + compIdDesc.CreateL( KCaMaxAttrValueLen ); + compIdDesc.Num( aEntry->ComponentId() ); aCaEntry->AddAttributeL( KCaAttrComponentId, compIdDesc ); CleanupStack::PopAndDestroy( &compIdDesc ); - } // --------------------------------------------------------------------------- // // --------------------------------------------------------------------------- // -void CCaUsifScanner::AddNativeAppsL() +void CCaUsifScanner::AddPackageL() { - TLanguage locale = TLanguage(-1); - - CComponentFilter *filter = CComponentFilter::NewL(); - CleanupStack::PushL(filter); - filter->SetSoftwareTypeL( KSoftwareTypeNative ); - filter->SetRemovable(ETrue); - - // Connect to the SCR server - RSoftwareComponentRegistry *scr = new RSoftwareComponentRegistry(); - CleanupClosePushL(*scr); - User::LeaveIfError( scr->Connect() ); - - // Create an SCR view - RSoftwareComponentRegistryView *scrView = - new RSoftwareComponentRegistryView(); - CleanupClosePushL(*scrView); - scrView->OpenViewL( *scr, filter ); - - // Iterate over the matching components - CComponentEntry* entry = CComponentEntry::NewLC(); - RPointerArray entries; CleanupResetAndDestroyPushL( entries ); - GetCaAppEntriesL(entries); + GetCaPackageEntriesL( entries ); - RArray entryIds; - CleanupClosePushL(entryIds); - while( scrView->NextComponentL( *entry, locale ) ) + RPointerArray resultUsifArray; + CleanupResetAndDestroyPushL( resultUsifArray ); + GetUsifPackageEntriesL( resultUsifArray ); + + for( TInt idx(0); idx < resultUsifArray.Count(); idx++ ) { - CCaInnerEntry *caEntry = CCaInnerEntry::NewLC(); - CreateCaEntryFromEntryL( entry, caEntry ); - - if( !AppExist(entries, caEntry)) + if( PackageExistL( entries, resultUsifArray[idx] ) == KErrNotFound ) { + CCaInnerEntry *caEntry = CCaInnerEntry::NewLC(); + CreateCaEntryFromEntryL( resultUsifArray[idx], caEntry ); iStorageProxy.AddL( caEntry ); - entryIds.Append( caEntry->GetId() ); + CleanupStack::PopAndDestroy( caEntry ); } - CleanupStack::PopAndDestroy( caEntry ); } - TCaOperationParams params = - { - TCaOperationParams::EAppend, iCollectionUsifId, 0 - }; - iStorageProxy.OrganizeL( entryIds, params ); - CleanupStack::PopAndDestroy( &entryIds ); + CleanupStack::PopAndDestroy( &resultUsifArray ); CleanupStack::PopAndDestroy( &entries ); - CleanupStack::PopAndDestroy( entry ); - CleanupStack::PopAndDestroy(scrView); - CleanupStack::PopAndDestroy(scr); - CleanupStack::PopAndDestroy(filter); } // --------------------------------------------------------------------------- // // --------------------------------------------------------------------------- // -void CCaUsifScanner::GetCaAppEntriesL( +void CCaUsifScanner::UpdatePackagesL() + { + RPointerArray resultCaArray; + CleanupResetAndDestroyPushL( resultCaArray ); + GetCaPackageEntriesL( resultCaArray ); + + RPointerArray resultUsifArray; + CleanupResetAndDestroyPushL( resultUsifArray ); + GetUsifPackageEntriesL( resultUsifArray ); + + FindDeletedEntriesL( resultCaArray, resultUsifArray ); + RemoveEntriesFromDbL( resultCaArray ); + + CleanupStack::PopAndDestroy( &resultUsifArray ); + CleanupStack::PopAndDestroy( &resultCaArray ); + } + +// --------------------------------------------------------------------------- +// +// --------------------------------------------------------------------------- +// +void CCaUsifScanner::GetCaPackageEntriesL( RPointerArray& aArray ) { CCaInnerQuery* allAppQuery = CCaInnerQuery::NewLC(); CDesC16ArrayFlat* appType = new ( ELeave ) CDesC16ArrayFlat( 1 ); CleanupStack::PushL( appType ); - appType->AppendL( KCaTypeApp ); + appType->AppendL( KCaTypePackage ); allAppQuery->SetEntryTypeNames( appType ); CleanupStack::Pop( appType ); iStorageProxy.GetEntriesL( allAppQuery, aArray ); @@ -271,13 +255,108 @@ // // --------------------------------------------------------------------------- // -TInt CCaUsifScanner::AppExist( RPointerArray& aArray, - CCaInnerEntry* aEntry ) +void CCaUsifScanner::GetUsifPackageEntriesL( + RPointerArray& aArray ) { - for (TInt i(0); i < aArray.Count(); i++) + CComponentFilter *filter = CComponentFilter::NewL(); + CleanupStack::PushL( filter ); + filter->SetRemovable( ETrue ); + filter->SetHidden( EFalse ); + + // Create an SCR view + RSoftwareComponentRegistryView scrView; + CleanupClosePushL( scrView ); + scrView.OpenViewL( iSoftwareRegistry, filter ); + + // Iterate over the matching components + //The ownership is transferred to the calling client. + CComponentEntry* entry = scrView.NextComponentL(); + while( entry ) + { + CleanupStack::PushL( entry ); + if( iSoftwareRegistry.IsComponentPresentL( entry->ComponentId() ) ) + { + aArray.AppendL( entry ); + CleanupStack::Pop( entry ); + } + else + { + CleanupStack::PopAndDestroy( entry ); + } + entry = scrView.NextComponentL(); + } + CleanupStack::PopAndDestroy( &scrView ); + CleanupStack::PopAndDestroy( filter ); + } + +// --------------------------------------------------------------------------- +// +// --------------------------------------------------------------------------- +// +TInt CCaUsifScanner::PackageExistL( RPointerArray& aArray, + const CComponentEntry* aEntry ) + { + for( TInt idx( 0 ); idx < aArray.Count(); idx++ ) { - if( aArray[i]->GetUid() == aEntry->GetUid()) - return KErrAlreadyExists; + TBuf compIdDes; + if( aArray[idx]->FindAttribute( KCaAttrComponentId, compIdDes ) ) + { + TLex lex( compIdDes ); + TUint uint( 0 ); + User::LeaveIfError( lex.Val( uint ) ); + if( aEntry->ComponentId() == uint ) + { + return idx; + } + } } - return KErrNone; + return KErrNotFound; } + +// --------------------------------------------------------------------------- +// +// --------------------------------------------------------------------------- +// +void CCaUsifScanner::FindDeletedEntriesL( + RPointerArray& aCaArray, const RPointerArray< + CComponentEntry>& aUsifArray ) + { + for( TInt idx( aCaArray.Count() - 1 ); idx >= 0; idx-- ) + { + TBuf compIdDes; + if( aCaArray[idx]->FindAttribute( KCaAttrComponentId, compIdDes ) ) + { + TLex lex( compIdDes ); + TUint uint( 0 ); + User::LeaveIfError( lex.Val( uint ) ); + //for each usif entry check if entry has to be removed + for( TInt k( 0 ); k < aUsifArray.Count(); k++ ) + { + if( aUsifArray[k]->ComponentId() == uint + && iSoftwareRegistry.IsComponentPresentL( uint ) ) + { + delete aCaArray[idx]; + aCaArray.Remove( idx ); + break; + } + } + } + } + } + +// --------------------------------------------------------------------------- +// +// --------------------------------------------------------------------------- +// +void CCaUsifScanner::RemoveEntriesFromDbL( + RPointerArray& aCaArray ) + { + RArray entriesId; + CleanupClosePushL( entriesId ); + for( TInt i( 0 ); i < aCaArray.Count(); i++ ) + { + entriesId.Append( aCaArray[i]->GetId() ); + } + iStorageProxy.RemoveL( entriesId ); + CleanupStack::PopAndDestroy( &entriesId ); + } diff -r a6d55a2e75be -r 782e3408c2ab contentstorage/casrv/causifscanner/src/proxy.cpp --- a/contentstorage/casrv/causifscanner/src/proxy.cpp Fri Mar 26 13:00:55 2010 +0200 +++ b/contentstorage/casrv/causifscanner/src/proxy.cpp Fri Apr 16 14:45:49 2010 +0300 @@ -32,7 +32,6 @@ EXPORT_C const TImplementationProxy* ImplementationGroupProxy( TInt& aTableCount ) { - aTableCount = sizeof( ImplementationTable ) - / sizeof(TImplementationProxy); + aTableCount = sizeof( ImplementationTable ) / sizeof(TImplementationProxy); return ImplementationTable; } diff -r a6d55a2e75be -r 782e3408c2ab contentstorage/casrv/cawidgetscanner/group/cawidgetscanner.mmp --- a/contentstorage/casrv/cawidgetscanner/group/cawidgetscanner.mmp Fri Mar 26 13:00:55 2010 +0200 +++ b/contentstorage/casrv/cawidgetscanner/group/cawidgetscanner.mmp Fri Apr 16 14:45:49 2010 +0300 @@ -39,7 +39,6 @@ SOURCE cawidgetscannerparser.cpp SOURCE cawidgetdescription.cpp SOURCE cawidgetstoragehandler.cpp -SOURCE cawidgetmmcwatcher.cpp SOURCE widgetscannerutils.cpp USERINCLUDE ../inc diff -r a6d55a2e75be -r 782e3408c2ab contentstorage/casrv/cawidgetscanner/inc/cawidgetmmcwatcher.h --- a/contentstorage/casrv/cawidgetscanner/inc/cawidgetmmcwatcher.h Fri Mar 26 13:00:55 2010 +0200 +++ /dev/null Thu Jan 01 00:00:00 1970 +0000 @@ -1,122 +0,0 @@ -/* -* Copyright (c) 2008 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: -* -*/ - -#ifndef C_CAWIDGETMMCWATCHER_H -#define C_CAWIDGETMMCWATCHER_H - - -#include -#include - -/** - * Interface for observing MMC events. - * - * @since S60 S60 v3.1 - */ -class MWidgetMmcWatcherCallback - { - -public: - /** - * MmcChangeL is called when the MMC is removed or inserted. - */ - virtual void MmcChangeL() = 0; - - }; - -/** - * This active object waits for an indication that the media has changed. - * - * @since S60 S60 v3.1 - */ -class CCaWidgetMmcWatcher : public CActive - { - -public: - - /** - * Two-phased constructor. - * @param aObserver Pointer to notifier interface. - * @param aFs file server session. - */ - static CCaWidgetMmcWatcher* NewL( RFs& aFs, - MWidgetMmcWatcherCallback* aObserver ); - - /** - * Two-phased constructor. - * @param aObserver Pointer to notifier interface. - * @param aFs file server session. - */ - static CCaWidgetMmcWatcher* NewLC( RFs& aFs, - MWidgetMmcWatcherCallback* aObserver ); - - /** - * Destructor - */ - ~CCaWidgetMmcWatcher(); - -private: - - /** - * C++ default constructor - * @param aObserver Pointer to notifier interface. - * @param aFs file server session. - */ - CCaWidgetMmcWatcher( RFs& aFs, MWidgetMmcWatcherCallback* aObserver ); - - /** - * By default Symbian OS constructor is private. - */ - void ConstructL(); - - /** - * Set notification request - */ - void WaitForChangeL(); - - /** - * From CActive. - */ - void DoCancel(); - - /** - * From CActive. - */ - void RunL(); - - /** - * From CActive. - */ - TInt RunError( TInt aError ); - -private: - - /** - * File server session. - * Not Own - */ - RFs iFs; - - /** - * MMC events observer - * Not own. - */ - MWidgetMmcWatcherCallback* iObserver; - }; - - -#endif // C_CAWIDGETMMCWATCHER_H diff -r a6d55a2e75be -r 782e3408c2ab contentstorage/casrv/cawidgetscanner/inc/cawidgetscannerplugin.h --- a/contentstorage/casrv/cawidgetscanner/inc/cawidgetscannerplugin.h Fri Mar 26 13:00:55 2010 +0200 +++ b/contentstorage/casrv/cawidgetscanner/inc/cawidgetscannerplugin.h Fri Apr 16 14:45:49 2010 +0300 @@ -22,16 +22,16 @@ #include #include #include "cawidgetdescription.h" -#include "cawidgetmmcwatcher.h" +#include "cammcwatcher.h" class TPluginParams; class CCaWidgetScannerParser; class CCaWidgetScannerInstallNotifier; class CCaWidgetStorageHandler; -class CCaWidgetScannerPlugin : public CCaSrvPlugin, MWidgetMmcWatcherCallback +class CCaWidgetScannerPlugin : public CCaSrvPlugin, MMmcWatcherCallback { - + public: // Constructors and destructor @@ -45,7 +45,7 @@ * C++ destructor */ ~CCaWidgetScannerPlugin(); - + /** * SynchronizeL */ @@ -53,12 +53,12 @@ private: //from MWidgetMmcWatcherCallback - + /** * MmcChangeL is called when the MMC is removed or inserted. */ void MmcChangeL(); - + private: /** @@ -72,7 +72,7 @@ void ConstructL( TPluginParams* aPluginParams ); private: - + /** * File session. Own */ @@ -92,12 +92,12 @@ * Content Storage Handler. Own. */ CCaWidgetStorageHandler* iStorageHandler; - + /** * Mmc watcher. Own. */ - CCaWidgetMmcWatcher* iMmcWatcher; - + CCaMmcWatcher* iMmcWatcher; + }; #endif // C_CAWIDGETSCANNERPLUGIN_H diff -r a6d55a2e75be -r 782e3408c2ab contentstorage/casrv/cawidgetscanner/src/cawidgetdescription.cpp --- a/contentstorage/casrv/cawidgetscanner/src/cawidgetdescription.cpp Fri Mar 26 13:00:55 2010 +0200 +++ b/contentstorage/casrv/cawidgetscanner/src/cawidgetdescription.cpp Fri Apr 16 14:45:49 2010 +0300 @@ -57,8 +57,7 @@ void CCaWidgetDescription::ConstructL( CCaInnerEntry* aEntry ) { iEntryId = aEntry->GetId(); - iDescription.CreateL(aEntry->GetDescription().Length()); - iDescription = aEntry->GetDescription(); + iDescription.CreateL( aEntry->GetDescription() ); //package uid TBuf uidDesc; aEntry->FindAttribute( KCaPackageUid, uidDesc ); @@ -67,10 +66,8 @@ TLex uidLex(uidDesc); User::LeaveIfError( uidLex.Val( iPackageUid, EHex )); } - iTitle.CreateL(aEntry->GetText().Length()); - iTitle = aEntry->GetText(); - iIconUri.CreateL(aEntry->GetIcon().iFileName.Length()); - iIconUri = aEntry->GetIcon().iFileName; + iTitle.CreateL( aEntry->GetText() ); + iIconUri.CreateL( aEntry->Icon()->FileName() ); //library iLibrary.CreateL( KCaMaxAttrValueLen ); aEntry->FindAttribute( KAttrWidgetLibrary, iLibrary ); diff -r a6d55a2e75be -r 782e3408c2ab contentstorage/casrv/cawidgetscanner/src/cawidgetmmcwatcher.cpp --- a/contentstorage/casrv/cawidgetscanner/src/cawidgetmmcwatcher.cpp Fri Mar 26 13:00:55 2010 +0200 +++ /dev/null Thu Jan 01 00:00:00 1970 +0000 @@ -1,133 +0,0 @@ -/* -* Copyright (c) 2008 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 - -#include "cawidgetmmcwatcher.h" - -// ================= MEMBER FUNCTIONS ======================= - -// --------------------------------------------------------- -// CCaWidgetMmcWatcher::NewL -// Second phase constructor -// --------------------------------------------------------- -// -CCaWidgetMmcWatcher* CCaWidgetMmcWatcher::NewL( RFs& aFs, - MWidgetMmcWatcherCallback* aObserver ) - { - CCaWidgetMmcWatcher* self = NewLC( aFs, aObserver ); - CleanupStack::Pop( self ); - return self; - } - -// --------------------------------------------------------- -// CCaWidgetMmcWatcher::NewLC -// Second phase constructor -// --------------------------------------------------------- -// -CCaWidgetMmcWatcher* CCaWidgetMmcWatcher::NewLC( RFs& aFs, - MWidgetMmcWatcherCallback* aObserver ) - { - CCaWidgetMmcWatcher* self = new (ELeave) CCaWidgetMmcWatcher( aFs, - aObserver ); - CleanupStack::PushL ( self ); - self->ConstructL(); - return self; - } - -// --------------------------------------------------------- -// CCaWidgetMmcWatcher::~CCaWidgetMmcWatcher -// Destructor -// --------------------------------------------------------- -// -CCaWidgetMmcWatcher::~CCaWidgetMmcWatcher() - { - Cancel(); - } - -// --------------------------------------------------------- -// CCaWidgetMmcWatcher::CCaWidgetMmcWatcher -// Default constructor -// --------------------------------------------------------- -// -CCaWidgetMmcWatcher::CCaWidgetMmcWatcher( RFs& aFs, - MWidgetMmcWatcherCallback* aObserver ) - : CActive( CActive::EPriorityStandard ), - iFs(aFs), - iObserver(aObserver) - { - CActiveScheduler::Add(this); - } - -// --------------------------------------------------------- -// CCaWidgetMmcWatcher::ConstructL -// default Symbian OS constructor -// --------------------------------------------------------- -// -void CCaWidgetMmcWatcher::ConstructL() - { - WaitForChangeL(); - } - -// --------------------------------------------------------- -// CCaWidgetMmcWatcher::WaitForChangeL -// Request notification for disk change -// --------------------------------------------------------- -// -void CCaWidgetMmcWatcher::WaitForChangeL() - { - TInt mmcDrive; - User::LeaveIfError( DriveInfo::GetDefaultDrive( - DriveInfo::EDefaultRemovableMassStorage, mmcDrive ) ); - TDriveName mmcDriveName( TDriveUnit( mmcDrive ).Name() ); - iFs.NotifyChange( ENotifyEntry, iStatus, mmcDriveName ); - SetActive(); - } - -// --------------------------------------------------------- -// CCaWidgetMmcWatcher::DoCancel -// --------------------------------------------------------- -// -void CCaWidgetMmcWatcher::DoCancel() - { - iFs.NotifyChangeCancel(); - } - -// --------------------------------------------------------------------------- -// CCaWidgetMmcWatcher::RunError -// --------------------------------------------------------------------------- -// -TInt CCaWidgetMmcWatcher::RunError( TInt /*aError*/ ) - { - // No need to do anything - return KErrNone; - } - -// --------------------------------------------------------- -// CCaWidgetMmcWatcher::RunL -// --------------------------------------------------------- -// -void CCaWidgetMmcWatcher::RunL() - { - TInt status( iStatus.Int() ); - WaitForChangeL(); - if ( status >= KErrNone ) - { - iObserver->MmcChangeL(); - } - } - diff -r a6d55a2e75be -r 782e3408c2ab contentstorage/casrv/cawidgetscanner/src/cawidgetscannerparser.cpp --- a/contentstorage/casrv/cawidgetscanner/src/cawidgetscannerparser.cpp Fri Mar 26 13:00:55 2010 +0200 +++ b/contentstorage/casrv/cawidgetscanner/src/cawidgetscannerparser.cpp Fri Apr 16 14:45:49 2010 +0300 @@ -239,7 +239,7 @@ SetIconUriL( aElement, aPackageUid, widget); widget->SetPackageUidL( aPackageUid ); SetMmcIdL( widget ); - + TTime modificationTime; iFs.Modified( aFilePath, modificationTime); TInt64 modificationIntTime = modificationTime.Int64(); @@ -268,7 +268,7 @@ void CCaWidgetScannerParser::SetUriL( TXmlEngElement & aElement, CCaWidgetDescription * aWidget ) { - HBufC *attributeValue = CnvUtfConverter::ConvertToUnicodeFromUtf7L( + HBufC *attributeValue = CnvUtfConverter::ConvertToUnicodeFromUtf8L( aElement.AttributeValueL( KUri ) ); CleanupStack::PushL( attributeValue ); @@ -286,7 +286,7 @@ void CCaWidgetScannerParser::SetLibraryL( TXmlEngElement & aElement, const TDesC & aPackageUid, CCaWidgetDescription * aWidget ) { - HBufC *attributeValue = CnvUtfConverter::ConvertToUnicodeFromUtf7L( + HBufC *attributeValue = CnvUtfConverter::ConvertToUnicodeFromUtf8L( aElement.AttributeValueL( KLibrary ) ); CleanupStack::PushL( attributeValue ); @@ -296,7 +296,7 @@ //set path for hs to use, trim last 2 chars (doubleslash) aWidget->SetPathL(libraryPath->Mid(0,libraryPath->Length()-1)); - + libraryPath->ReAllocL( libraryPath->Length() + attributeValue->Length()); @@ -320,7 +320,7 @@ void CCaWidgetScannerParser::SetTitleL( TXmlEngElement & aElement, CCaWidgetDescription * aWidget ) { - HBufC *attributeValue = CnvUtfConverter::ConvertToUnicodeFromUtf7L( + HBufC *attributeValue = CnvUtfConverter::ConvertToUnicodeFromUtf8L( aElement.AttributeValueL( KTitle ) ); CleanupStack::PushL( attributeValue ); @@ -338,7 +338,7 @@ void CCaWidgetScannerParser::SetDescriptionL( TXmlEngElement & aElement, CCaWidgetDescription * aWidget ) { - HBufC *attributeValue = CnvUtfConverter::ConvertToUnicodeFromUtf7L( + HBufC *attributeValue = CnvUtfConverter::ConvertToUnicodeFromUtf8L( aElement.AttributeValueL( KDescription ) ); CleanupStack::PushL( attributeValue ); @@ -356,7 +356,7 @@ void CCaWidgetScannerParser::SetVisibilityL( TXmlEngElement & aElement, CCaWidgetDescription * aWidget ) { - HBufC *hidden = CnvUtfConverter::ConvertToUnicodeFromUtf7L( + HBufC *hidden = CnvUtfConverter::ConvertToUnicodeFromUtf8L( aElement.AttributeValueL( KHidden ) ); CleanupStack::PushL( hidden ); @@ -374,7 +374,7 @@ void CCaWidgetScannerParser::SetIconUriL( TXmlEngElement & aElement, const TDesC & aPackageUid, CCaWidgetDescription * aWidget ) { - HBufC *attributeValue = CnvUtfConverter::ConvertToUnicodeFromUtf7L( + HBufC *attributeValue = CnvUtfConverter::ConvertToUnicodeFromUtf8L( aElement.AttributeValueL( KIconUri ) ); CleanupStack::PushL( attributeValue ); diff -r a6d55a2e75be -r 782e3408c2ab contentstorage/casrv/cawidgetscanner/src/cawidgetscannerplugin.cpp --- a/contentstorage/casrv/cawidgetscanner/src/cawidgetscannerplugin.cpp Fri Mar 26 13:00:55 2010 +0200 +++ b/contentstorage/casrv/cawidgetscanner/src/cawidgetscannerplugin.cpp Fri Apr 16 14:45:49 2010 +0300 @@ -11,7 +11,7 @@ * * Contributors: * -* Description: +* Description: * */ @@ -48,7 +48,7 @@ // ============================ MEMBER FUNCTIONS =============================== // ----------------------------------------------------------------------------- -// CCaWidgetScannerPlugin ::CCaWidgetScannerPlugin +// CCaWidgetScannerPlugin ::CCaWidgetScannerPlugin // C++ default constructor can NOT contain any code, that // might leave. // ----------------------------------------------------------------------------- @@ -65,11 +65,11 @@ void CCaWidgetScannerPlugin::ConstructL( TPluginParams* aPluginParams ) { User::LeaveIfError( iFs.Connect() ); - iMmcWatcher = CCaWidgetMmcWatcher::NewL( iFs, this ); + iMmcWatcher = CCaMmcWatcher::NewL( iFs, this ); iInstallNotifier = CCaWidgetScannerInstallNotifier::NewL( this, KUidSystemCategory, KSAUidSoftwareInstallKeyValue ); iParser = CCaWidgetScannerParser::NewL( iFs ); - iStorageHandler = CCaWidgetStorageHandler::NewL( + iStorageHandler = CCaWidgetStorageHandler::NewL( aPluginParams->storageProxy, iFs ); SynchronizeL(); } @@ -79,7 +79,7 @@ // Two-phased constructor. // ----------------------------------------------------------------------------- // -CCaWidgetScannerPlugin * CCaWidgetScannerPlugin::NewL( +CCaWidgetScannerPlugin * CCaWidgetScannerPlugin::NewL( TPluginParams* aPluginParams ) { CCaWidgetScannerPlugin * self = NewLC( aPluginParams ); @@ -92,7 +92,7 @@ // Two-phased constructor. // ----------------------------------------------------------------------------- // -CCaWidgetScannerPlugin * CCaWidgetScannerPlugin::NewLC( +CCaWidgetScannerPlugin * CCaWidgetScannerPlugin::NewLC( TPluginParams* aPluginParams ) { CCaWidgetScannerPlugin * self = new( ELeave ) CCaWidgetScannerPlugin ( ); @@ -115,18 +115,18 @@ } // ---------------------------------------------------------------------------- -// +// // ---------------------------------------------------------------------------- // void CCaWidgetScannerPlugin::SynchronizeL() { iStorageHandler->SynchronizeL( iParser->WidgetsScanL() ); } - + // ---------------------------------------------------------------------------- -// +// // ---------------------------------------------------------------------------- -// +// void CCaWidgetScannerPlugin::MmcChangeL() { SynchronizeL(); diff -r a6d55a2e75be -r 782e3408c2ab contentstorage/casrv/cawidgetscanner/src/cawidgetstoragehandler.cpp --- a/contentstorage/casrv/cawidgetscanner/src/cawidgetstoragehandler.cpp Fri Mar 26 13:00:55 2010 +0200 +++ b/contentstorage/casrv/cawidgetscanner/src/cawidgetstoragehandler.cpp Fri Apr 16 14:45:49 2010 +0300 @@ -174,8 +174,6 @@ // void CCaWidgetStorageHandler::RemoveWidgetsL() { - RArray widgetsToRemove; - CleanupClosePushL( widgetsToRemove ); for( TInt i = 0; i < iWidgets.Count(); i++ ) { if( iUpdatedIndexes.Find( i ) == KErrNotFound ) @@ -188,15 +186,10 @@ } else { - widgetsToRemove.AppendL( iWidgets[i]->GetEntryId() ); + SetMissingFlagL( iWidgets[i] ); } } } - if( widgetsToRemove.Count() > 0 ) - { - iStorage->RemoveL( widgetsToRemove ); - } - CleanupStack::PopAndDestroy( &widgetsToRemove ); } // ---------------------------------------------------------------------------- diff -r a6d55a2e75be -r 782e3408c2ab contentstorage/castorage/data/castorage.db Binary file contentstorage/castorage/data/castorage.db has changed diff -r a6d55a2e75be -r 782e3408c2ab contentstorage/castorage/data/castoragedb_create.sql --- a/contentstorage/castorage/data/castoragedb_create.sql Fri Mar 26 13:00:55 2010 +0200 +++ b/contentstorage/castorage/data/castoragedb_create.sql Fri Apr 16 14:45:49 2010 +0300 @@ -87,8 +87,9 @@ DROP VIEW IF EXISTS COLLECTION; CREATE VIEW COLLECTION AS SELECT - "" AS "COLLECTION_NAME", - "" AS "COL_LOCNAME", + "" AS "COLLECTION_NAME", + "" AS "COL_LOCNAME", + "" AS "COL_APP_GROUP_NAME", "" AS "ICON"; SELECT " CREATE TRIGGER collection_insert" AS " "; @@ -101,17 +102,20 @@ DELETE FROM CA_ICON WHERE ICON_ID = last_insert_rowid() AND (IC_FILENAME IS NULL OR (SELECT ICON_ID FROM CA_ICON WHERE IC_FILENAME = new.ICON AND ICON_ID <> last_insert_rowid()) IS NOT NULL); -- INSERT ENTRY - INSERT INTO CA_ENTRY (EN_TEXT, EN_ROLE, EN_TYPE_NAME, EN_FLAGS, EN_ICON_ID ) - VALUES ( new.COLLECTION_NAME , 2, "collection", 12, (SELECT ICON_ID FROM CA_ICON WHERE IC_FILENAME = new.ICON )); - -- LOCALIZATION - INSERT INTO CA_LOCALIZATION_TEXT ( LT_TABLE_NAME, LT_ATTRIBUTE_NAME, LT_STRING_ID, LT_ROW_ID ) - VALUES ( 'CA_ENTRY', 'EN_TEXT', new.COL_LOCNAME, ( SELECT last_insert_rowid() ) ); - DELETE FROM CA_LOCALIZATION_TEXT WHERE LT_STRING_ID IS NULL AND LOC_TEXT_ID = last_insert_rowid() ; - -- RELATION TO MAIN COLLECTION (ADD TO GROUP: ) + INSERT INTO CA_ENTRY (EN_TEXT, EN_ROLE, EN_TYPE_NAME, EN_FLAGS, EN_ICON_ID ) + VALUES ( new.COLLECTION_NAME , 2, "collection", 4, (SELECT ICON_ID FROM CA_ICON WHERE IC_FILENAME = new.ICON )); + -- LOCALIZATION + INSERT INTO CA_LOCALIZATION_TEXT ( LT_TABLE_NAME, LT_ATTRIBUTE_NAME, LT_STRING_ID, LT_ROW_ID ) + VALUES ( 'CA_ENTRY', 'EN_TEXT', new.COL_LOCNAME, ( SELECT last_insert_rowid() ) ); + DELETE FROM CA_LOCALIZATION_TEXT WHERE LT_STRING_ID IS NULL AND LOC_TEXT_ID = last_insert_rowid() ; + -- RELATION TO MAIN COLLECTION (ADD TO GROUP: ) INSERT INTO CA_GROUP_ENTRY (GE_GROUP_ID, GE_ENTRY_ID, GE_POSITION) VALUES ( (SELECT ENTRY_ID FROM CA_ENTRY WHERE EN_TYPE_NAME = "menucollections") , (SELECT ENTRY_ID FROM CA_ENTRY WHERE EN_TEXT = new.COLLECTION_NAME), (SELECT IFNULL(MAX(GE_POSITION)+1, 1) FROM CA_GROUP_ENTRY WHERE GE_GROUP_ID = (SELECT ENTRY_ID FROM CA_ENTRY WHERE EN_TYPE_NAME = "menucollections")) ); + -- ADD ATTRIBUTE + INSERT OR IGNORE INTO CA_ATTRIBUTE (AT_ENTRY_ID, AT_NAME, AT_VALUE ) + VALUES ( (SELECT ENTRY_ID FROM CA_ENTRY WHERE EN_TEXT = new.COLLECTION_NAME AND (EN_TYPE_NAME = "collection::downloaded" OR EN_TYPE_NAME = "collection") ), "appgroup_name", new.COL_APP_GROUP_NAME ); END; -- CREATE VIEW ITEM_TO_COLLECTION @@ -132,7 +136,7 @@ -- INSERT ENTRY INSERT OR IGNORE INTO CA_ENTRY (EN_TEXT, EN_ROLE, EN_TYPE_NAME, EN_UID ) VALUES ( new.ITEM_NAME, 1, "application", new.ITEM_DEST ); - -- RELATION TO MAIN COLLECTION (ADD TO GROUP: ) + -- RELATION TO MAIN COLLECTION (ADD TO GROUP: ) INSERT INTO CA_GROUP_ENTRY (GE_GROUP_ID, GE_ENTRY_ID, GE_POSITION) VALUES ( (SELECT ENTRY_ID FROM CA_ENTRY WHERE EN_TEXT = new.COLLECTION_NAME) , (SELECT ENTRY_ID FROM CA_ENTRY WHERE EN_TEXT = new.ITEM_NAME), @@ -152,7 +156,7 @@ VALUES ( new.ITEM_NAME, 1, "url", (SELECT ICON_ID FROM CA_ICON WHERE IC_FILENAME = new.ICON )); INSERT OR IGNORE INTO CA_ATTRIBUTE (AT_ENTRY_ID, AT_NAME, AT_VALUE ) VALUES ( ( SELECT last_insert_rowid() ) ,"url",new.ITEM_DEST); - -- RELATION TO MAIN COLLECTION (ADD TO GROUP: ) + -- RELATION TO MAIN COLLECTION (ADD TO GROUP: ) INSERT INTO CA_GROUP_ENTRY (GE_GROUP_ID, GE_ENTRY_ID, GE_POSITION) VALUES ( (SELECT ENTRY_ID FROM CA_ENTRY WHERE EN_TEXT = new.COLLECTION_NAME) , (SELECT ENTRY_ID FROM CA_ENTRY WHERE EN_TEXT = new.ITEM_NAME), @@ -160,7 +164,7 @@ END; --- CREATE VIEW WIDGET _TO_COLLECTION +-- CREATE VIEW WIDGET _TO_COLLECTION SELECT "------------------------------------" AS " "; SELECT "CREATE VIEW WIDGET_TO_COLLECTION" AS " "; DROP VIEW IF EXISTS WIDGET_TO_COLLECTION; @@ -195,15 +199,12 @@ VALUES ( ( SELECT ENTRY_ID FROM CA_ENTRY WHERE EN_TEXT = new.ITEM_NAME ) ,"long_name",new.LONG_NAME); INSERT OR IGNORE INTO CA_ATTRIBUTE (AT_ENTRY_ID, AT_NAME, AT_VALUE ) VALUES ( ( SELECT ENTRY_ID FROM CA_ENTRY WHERE EN_TEXT = new.ITEM_NAME ) ,"widget:uri",new.URI); - -- RELATION TO MAIN COLLECTION (ADD TO GROUP: ) + -- RELATION TO MAIN COLLECTION (ADD TO GROUP: ) INSERT INTO CA_GROUP_ENTRY (GE_GROUP_ID, GE_ENTRY_ID, GE_POSITION) VALUES ( (SELECT ENTRY_ID FROM CA_ENTRY WHERE EN_TEXT = new.COLLECTION_NAME) , (SELECT ENTRY_ID FROM CA_ENTRY WHERE EN_TEXT = new.ITEM_NAME), (SELECT IFNULL(MAX(GE_POSITION)+1, 1) FROM CA_GROUP_ENTRY WHERE GE_GROUP_ID = (SELECT ENTRY_ID FROM CA_ENTRY WHERE EN_TEXT = new.COLLECTION_NAME)) ); -END; - - - +END; SELECT "INSERT INITIAL DATA TO CA_DB_PROPERTIES" AS " "; @@ -215,9 +216,33 @@ INSERT INTO CA_DB_PROPERTIES ( DB_PROPERTY, DB_VALUE ) VALUES ( 'QMfile', 'db_textmap_' ); - - - +-- insert neccessary items +SELECT "INSERT menucollections ENTRY" AS " "; +INSERT INTO CA_ENTRY (EN_TEXT, EN_ROLE, EN_TYPE_NAME, EN_ICON_ID, EN_UID ) +VALUES ( 'AllCollections', 2, "menucollections", NULL , NULL ); + +INSERT OR IGNORE INTO CA_ATTRIBUTE (AT_ENTRY_ID, AT_NAME, AT_VALUE ) +VALUES ( last_insert_rowid(), "appgroup_name", "AllCollections" ); + +SELECT "------------------------------------" AS " "; +SELECT "INSERT Downloaded collection ENTRY" AS " "; +INSERT INTO CA_ICON (IC_FILENAME) +VALUES ( "qtg_large_applications_download"); + +INSERT INTO CA_ENTRY (EN_TEXT, EN_ROLE, EN_TYPE_NAME, EN_ICON_ID, EN_FLAGS ) +VALUES ( 'Downloaded', 2, "collection::downloaded", last_insert_rowid() , 8 ); + +INSERT OR IGNORE INTO CA_ATTRIBUTE (AT_ENTRY_ID, AT_NAME, AT_VALUE ) +VALUES ( last_insert_rowid(), "appgroup_name", " Downloaded" ); + +INSERT INTO CA_LOCALIZATION_TEXT ( LT_TABLE_NAME, LT_ATTRIBUTE_NAME, LT_STRING_ID, LT_ROW_ID ) +VALUES ( 'CA_ENTRY', 'EN_TEXT', "txt_applib_dblist_downloaded", ( SELECT last_insert_rowid() ) ); + +INSERT INTO CA_GROUP_ENTRY (GE_GROUP_ID, GE_ENTRY_ID, GE_POSITION) +VALUES ( (SELECT ENTRY_ID FROM CA_ENTRY WHERE EN_TYPE_NAME = "menucollections") , + (SELECT ENTRY_ID FROM CA_ENTRY WHERE EN_TYPE_NAME = "collection::downloaded"), + 1 ); + SELECT "------------------------------------" AS " "; SELECT "castoragedb_create - END" AS " "; SELECT "------------------------------------" AS " "; diff -r a6d55a2e75be -r 782e3408c2ab contentstorage/castorage/data/castoragedb_variant.sql --- a/contentstorage/castorage/data/castoragedb_variant.sql Fri Mar 26 13:00:55 2010 +0200 +++ b/contentstorage/castorage/data/castoragedb_variant.sql Fri Apr 16 14:45:49 2010 +0300 @@ -1,41 +1,16 @@ SELECT "------------------------------------" AS " "; SELECT "castoragedb_variant - BEGIN" AS " "; --- insert neccessary items -SELECT "INSERT GROUPS" AS " "; -SELECT "." AS " "; -INSERT INTO CA_ENTRY (EN_TEXT, EN_ROLE, EN_TYPE_NAME, EN_ICON_ID, EN_UID ) -VALUES ( 'Menu', 2, "folder", NULL , NULL ); - -SELECT "INSERT menucollections ENTRY" AS " "; -INSERT INTO CA_ENTRY (EN_TEXT, EN_ROLE, EN_TYPE_NAME, EN_ICON_ID, EN_UID ) -VALUES ( 'AllCollections', 2, "menucollections", NULL , NULL ); - -INSERT INTO CA_ENTRY (EN_TEXT, EN_ROLE, EN_TYPE_NAME, EN_ICON_ID, EN_UID, EN_FLAGS ) -VALUES ( 'Application Library', 2, "applicationlibrary", NULL, NULL, 8 ); - -SELECT "------------------------------------" AS " "; -SELECT "INSERT Downloaded collection ENTRY" AS " "; -INSERT INTO CA_ICON (IC_FILENAME) -VALUES ( "qtg_large_applications_download"); -INSERT INTO CA_ENTRY (EN_TEXT, EN_ROLE, EN_TYPE_NAME, EN_ICON_ID, EN_FLAGS ) -VALUES ( 'Downloaded', 2, "collection::downloaded", last_insert_rowid() , 8 ); -INSERT INTO CA_LOCALIZATION_TEXT ( LT_TABLE_NAME, LT_ATTRIBUTE_NAME, LT_STRING_ID, LT_ROW_ID ) -VALUES ( 'CA_ENTRY', 'EN_TEXT', "txt_applib_dblist_downloaded", ( SELECT last_insert_rowid() ) ); -INSERT INTO CA_GROUP_ENTRY (GE_GROUP_ID, GE_ENTRY_ID, GE_POSITION) -VALUES ( (SELECT ENTRY_ID FROM CA_ENTRY WHERE EN_TYPE_NAME = "menucollections") , - (SELECT ENTRY_ID FROM CA_ENTRY WHERE EN_TYPE_NAME = "collection::downloaded"), - 1 ); -- insert additional items -INSERT INTO COLLECTION (COLLECTION_NAME, COL_LOCNAME, ICON) VALUES ( 'Office', "txt_applib_dblist_office", "qtg_large_applications_user"); +INSERT INTO COLLECTION (COLLECTION_NAME, COL_LOCNAME, COL_APP_GROUP_NAME ,ICON) VALUES ( 'Office', "txt_applib_dblist_office", 'Office', "qtg_large_applications_user"); INSERT INTO ITEM_TO_COLLECTION (ITEM_TYPE,ITEM_NAME,ITEM_DEST, COLLECTION_NAME) VALUES ("application", 'calendar', 268458241, 'Office' ); INSERT INTO ITEM_TO_COLLECTION (ITEM_TYPE,ITEM_NAME,ITEM_DEST, COLLECTION_NAME) VALUES ("application", 'Phonebook', 537014009, 'Office' ); -INSERT INTO COLLECTION (COLLECTION_NAME, ICON) VALUES ( 'Multimedia', "qtg_large_applications_user" ); +INSERT INTO COLLECTION (COLLECTION_NAME, COL_APP_GROUP_NAME ,ICON) VALUES ( 'Multimedia', 'Multimedia' , "qtg_large_applications_user" ); INSERT INTO ITEM_TO_COLLECTION (ITEM_TYPE,ITEM_NAME,ITEM_DEST, COLLECTION_NAME) VALUES ("application", 'Themes', 268458546, 'Multimedia' ); INSERT INTO ITEM_TO_COLLECTION (ITEM_TYPE,ITEM_NAME,ITEM_DEST, COLLECTION_NAME) @@ -43,7 +18,7 @@ INSERT INTO ITEM_TO_COLLECTION (ITEM_TYPE,ITEM_NAME,ITEM_DEST, COLLECTION_NAME) VALUES ("application", 'Videoplayer', 537006590, 'Multimedia' ); -INSERT INTO COLLECTION (COLLECTION_NAME, ICON) VALUES ( 'Utils', "qtg_large_applications_user" ); +INSERT INTO COLLECTION (COLLECTION_NAME, COL_APP_GROUP_NAME ,ICON) VALUES ( 'Utils', 'Utils', "qtg_large_applications_user" ); INSERT INTO ITEM_TO_COLLECTION (ITEM_TYPE,ITEM_NAME,ITEM_DEST, COLLECTION_NAME) VALUES ("application", 'ControlPanel', 537026521, 'Utils' ); INSERT INTO ITEM_TO_COLLECTION (ITEM_TYPE,ITEM_NAME,ITEM_DEST, COLLECTION_NAME) @@ -54,9 +29,8 @@ VALUES ("application", 'eshell', 270498535, 'Utils' ); INSERT INTO ITEM_TO_COLLECTION (ITEM_TYPE,ITEM_NAME,ITEM_DEST, COLLECTION_NAME) VALUES ("application", 'Conn. mgr.', 270501072, 'Utils' ); - -INSERT INTO COLLECTION (COLLECTION_NAME, COL_LOCNAME, ICON) VALUES ( 'Games', "txt_applib_dblist_games", "qtg_large_applications_user" ); +INSERT INTO COLLECTION (COLLECTION_NAME, COL_LOCNAME, COL_APP_GROUP_NAME ,ICON) VALUES ( 'Games', "txt_applib_dblist_games", 'Games',"qtg_large_applications_user" ); SELECT "castoragedb_variant - END" AS " "; SELECT "------------------------------------" AS " "; diff -r a6d55a2e75be -r 782e3408c2ab contentstorage/castorage/data/stub/castorage.db Binary file contentstorage/castorage/data/stub/castorage.db has changed diff -r a6d55a2e75be -r 782e3408c2ab contentstorage/castorage/inc/casqlcommands.h --- a/contentstorage/castorage/inc/casqlcommands.h Fri Mar 26 13:00:55 2010 +0200 +++ b/contentstorage/castorage/inc/casqlcommands.h Fri Apr 16 14:45:49 2010 +0300 @@ -91,6 +91,10 @@ _LIT( KSQLUpdateEntryFlags, "EN_FLAGS = :EN_FLAGS " ); _LIT( KSQLUpdateWhere, "WHERE ENTRY_ID = :ENTRY_ID " ); +// Null Icon params +_LIT( KSQLEmptyIconFileName, "(IC_FILENAME IS NULL OR IC_FILENAME = '')" ); +_LIT( KSQLEmptyIconSkinId, "(IC_SKIN_ID IS NULL OR IC_SKIN_ID = '')" ); +_LIT( KSQLEmptyIconAppId, "(IC_APP_ID IS NULL OR IC_APP_ID = '')" ); // Update Icon _LIT( KSQLUpdateIconId, "ICON_ID = :ICON_ID " ); @@ -175,10 +179,7 @@ _LIT( KSQLNotINIds," AND GE_GROUP_ID NOT IN( %S )" ); -_LIT( KSQLGetIconId,"SELECT ICON_ID AS Data FROM CA_ICON \ -WHERE IC_FILENAME = :IC_FILENAME AND \ -IC_SKIN_ID = :IC_SKIN_ID AND \ -IC_APP_ID = :IC_APP_ID"); +_LIT( KSQLGetIconIdWhere,"SELECT ICON_ID AS Data FROM CA_ICON WHERE "); _LIT( KSQLGetEntryIdFromEntryTable,"SELECT ENTRY_ID AS Data FROM CA_ENTRY \ WHERE ENTRY_ID = :ENTRY_ID"); diff -r a6d55a2e75be -r 782e3408c2ab contentstorage/castorage/inc/casqlquery.h --- a/contentstorage/castorage/inc/casqlquery.h Fri Mar 26 13:00:55 2010 +0200 +++ b/contentstorage/castorage/inc/casqlquery.h Fri Apr 16 14:45:49 2010 +0300 @@ -327,7 +327,7 @@ * @param aIconAttributes an icon attributes. * @return Entry count. */ - TInt ExecuteL( CCaInnerEntry::TIconAttributes& aIconAttributes ); + TInt ExecuteL( CCaInnerIconDescription* aInnerIconDescription ); private: diff -r a6d55a2e75be -r 782e3408c2ab contentstorage/castorage/inc/casqlquerycreator.h --- a/contentstorage/castorage/inc/casqlquerycreator.h Fri Mar 26 13:00:55 2010 +0200 +++ b/contentstorage/castorage/inc/casqlquerycreator.h Fri Apr 16 14:45:49 2010 +0300 @@ -167,6 +167,15 @@ static void CreateCustomSortQueryL( const RArray& aEntryIds, RPointerArray& aSqlQuery, RSqlDatabase& aSqlDb ); + + /** + * Creates an sql query for finding an icon. + * + * @param aEntry The entry which has icon description. + * @param aQuery The result query. + */ + static void CreateFindIconQueryL( CCaInnerEntry* aEntry, + CCaSqlQuery* aQuery); private: @@ -220,7 +229,7 @@ */ static void CreateUpdateQueryEntryL( const CCaInnerEntry* aEntry, CCaSqlQuery* aQuery ); - + /** * Creates an sql query to get a list of entries by the given ids. * diff -r a6d55a2e75be -r 782e3408c2ab contentstorage/castorage/src/casqlitestorage.cpp --- a/contentstorage/castorage/src/casqlitestorage.cpp Fri Mar 26 13:00:55 2010 +0200 +++ b/contentstorage/castorage/src/casqlitestorage.cpp Fri Apr 16 14:45:49 2010 +0300 @@ -500,12 +500,12 @@ { //check if icon exists - just update CCaSqlQuery* query = CCaSqlQuery::NewLC( iSqlDb ); - query->SetQueryL( KSQLGetIconId ); + CaSqlQueryCreator::CreateFindIconQueryL(aEntry, query); query->SetTableType( CCaSqlQuery::EIconTable ); query->PrepareL(); query->BindValuesForGetIconL( aEntry ); - CCaInnerEntry::TIconAttributes iconAttributes; - TInt countIcons = query->ExecuteL( iconAttributes ); + TInt idIcon( 0 ); + query->ExecuteL( idIcon ); CleanupStack::PopAndDestroy( query ); aSqlQuery[i]->PrepareL(); @@ -513,11 +513,10 @@ TInt tmpId( 0 ); TRAPD( err, tmpId = aSqlQuery[i]->ExecuteL() ); aSqlQuery[i]->CloseStatement(); - if( !countIcons && !aEntry->GetIconId() ) + if( !idIcon && !aEntry->GetIconId() ) { // new icon added aEntry->SetIconId( tmpId ); } - if( err == KSqlErrConstraint ) { // ignore, this means that the icon cannot be removed diff -r a6d55a2e75be -r 782e3408c2ab contentstorage/castorage/src/casqlquery.cpp --- a/contentstorage/castorage/src/casqlquery.cpp Fri Mar 26 13:00:55 2010 +0200 +++ b/contentstorage/castorage/src/casqlquery.cpp Fri Apr 16 14:45:49 2010 +0300 @@ -509,22 +509,22 @@ if( iQuery.Find( KSQLIconId ) != KErrNotFound ) { BindIntL(iStatement.ParameterIndex( KSQLIconId ), - aEntry->GetIcon().iId ); + aEntry->Icon()->Id() ); } if( iQuery.Find( KSQLIcFileName ) != KErrNotFound ) { BindTextL( iStatement.ParameterIndex( KSQLIcFileName ), - aEntry->GetIcon().iFileName ); + aEntry->Icon()->FileName() ); } if( iQuery.Find( KSQLIcSkinId ) != KErrNotFound ) { BindTextL( iStatement.ParameterIndex( KSQLIcSkinId ), - aEntry->GetIcon().iSkinId ); + aEntry->Icon()->SkinId() ); } if( iQuery.Find( KSQLIcAppId ) != KErrNotFound ) { BindTextL( iStatement.ParameterIndex( KSQLIcAppId ), - aEntry->GetIcon().iApplicationId ); + aEntry->Icon()->ApplicationId() ); } } @@ -853,24 +853,36 @@ // // --------------------------------------------------------------------------- // -TInt CCaSqlQuery::ExecuteL( CCaInnerEntry::TIconAttributes& aIconAttributes ) +TInt CCaSqlQuery::ExecuteL( CCaInnerIconDescription* aInnerIconDescription ) { TInt columnCount( 0 ); + + RBuf description; + description.CleanupClosePushL(); + description.CreateL(KMaxFileName); + while( iStatement.Next() == KSqlAtRow ) { - aIconAttributes.iId = iStatement.ColumnInt( - ColumnIndexL( iStatement, KColumnIconId ) ); + aInnerIconDescription->SetId( iStatement.ColumnInt( + ColumnIndexL( iStatement, KColumnIconId ) ) ); User::LeaveIfError(iStatement.ColumnText( ColumnIndexL( iStatement, KColumnIcFileName), - aIconAttributes.iFileName)); + description)); + aInnerIconDescription->SetFileNameL(description); + User::LeaveIfError(iStatement.ColumnText( ColumnIndexL( iStatement, KColumnIcSkinId), - aIconAttributes.iSkinId)); + description)); + aInnerIconDescription->SetSkinIdL(description); + User::LeaveIfError(iStatement.ColumnText( ColumnIndexL( iStatement, KColumnIcAppId), - aIconAttributes.iApplicationId)); + description)); + aInnerIconDescription->SetApplicationIdL(description); + columnCount++; } + CleanupStack::PopAndDestroy(&description); return columnCount; } diff -r a6d55a2e75be -r 782e3408c2ab contentstorage/castorage/src/casqlquerycreator.cpp --- a/contentstorage/castorage/src/casqlquerycreator.cpp Fri Mar 26 13:00:55 2010 +0200 +++ b/contentstorage/castorage/src/casqlquerycreator.cpp Fri Apr 16 14:45:49 2010 +0300 @@ -209,6 +209,72 @@ aQuery->SetQueryL( query ); CleanupStack::PopAndDestroy( &query ); } + +// --------------------------------------------------------------------------- +// +// --------------------------------------------------------------------------- +// +void CaSqlQueryCreator::CreateFindIconQueryL( CCaInnerEntry* aEntry, + CCaSqlQuery* aQuery) + { + RBuf iconQuery; + iconQuery.CleanupClosePushL(); + iconQuery.CreateL( KSQLGetIconIdWhere ); + + if( aEntry->Icon()->FileName().Compare( KNullDesC ) ) + { + iconQuery.ReAllocL( iconQuery.Length() + KSQLUpdateIconFileName().Length() + + KAnd().Length() ); + iconQuery.Append( KSQLUpdateIconFileName ); + iconQuery.Append( KAnd ); + } + else + { + iconQuery.ReAllocL( iconQuery.Length() + KSQLEmptyIconFileName().Length() + + KAnd().Length() ); + iconQuery.Append( KSQLEmptyIconFileName ); + iconQuery.Append( KAnd ); + } + + if( aEntry->Icon()->SkinId().Compare( KNullDesC ) ) + { + iconQuery.ReAllocL( iconQuery.Length() + KSQLUpdateIconSkinId().Length() + + KAnd().Length() ); + iconQuery.Append( KSQLUpdateIconSkinId ); + iconQuery.Append( KAnd ); + } + else + { + iconQuery.ReAllocL( iconQuery.Length() + KSQLEmptyIconSkinId().Length() + + KAnd().Length() ); + iconQuery.Append( KSQLEmptyIconSkinId ); + iconQuery.Append( KAnd ); + } + + if( aEntry->Icon()->ApplicationId().Compare( KNullDesC ) ) + { + iconQuery.ReAllocL( iconQuery.Length() + KSQLUpdateIconAppId().Length() + + KAnd().Length() ); + iconQuery.Append( KSQLUpdateIconAppId ); + iconQuery.Append( KAnd ); + } + else + { + iconQuery.ReAllocL( iconQuery.Length() + KSQLEmptyIconAppId().Length() + + KAnd().Length() ); + iconQuery.Append( KSQLEmptyIconAppId ); + iconQuery.Append( KAnd ); + } + + if (!iconQuery.Right(KAnd().Length()).Compare(KAnd)) + { + iconQuery.Delete( iconQuery.Length() - KAnd().Length(), KAnd().Length() ); + } + + aQuery->SetQueryL( iconQuery ); + CleanupStack::PopAndDestroy( &iconQuery ); + } + // --------------------------------------------------------------------------- // // --------------------------------------------------------------------------- @@ -218,9 +284,9 @@ { DEBUG( ("_CA_:CASqlQueryCreator::CreateAddIconQueryForNewL") ); CCaSqlQuery* query = CCaSqlQuery::NewLC( aSqlDb ); - query->SetQueryL( KSQLGetIconId ); + + CreateFindIconQueryL(aEntry, query); query->SetTableType( CCaSqlQuery::EIconTable ); - query->PrepareL(); query->BindValuesForGetIconL( aEntry ); TInt idIcon( 0 ); @@ -230,9 +296,9 @@ if( idIcon == 0 ) { // entry's icon data is not in DB - if( ( aEntry->GetIcon().iFileName.Length() != 0 ) || - ( aEntry->GetIcon().iSkinId.Length() != 0 ) || - ( aEntry->GetIcon().iApplicationId.Length() != 0 ) + if( ( aEntry->Icon()->FileName().Length() != 0 ) || + ( aEntry->Icon()->SkinId().Length() != 0 ) || + ( aEntry->Icon()->ApplicationId().Length() != 0 ) ) { // icon is not null, so that insert it to storage @@ -251,6 +317,7 @@ aQuery->SetTableType( CCaSqlQuery::ENoTableType ); } } + // --------------------------------------------------------------------------- // // --------------------------------------------------------------------------- @@ -265,12 +332,14 @@ query->PrepareL(); query->BindValuesForGetEntriesL( aEntry ); - CCaInnerEntry::TIconAttributes iconAttributs; - query->ExecuteL( iconAttributs ); + + CCaInnerIconDescription* innerIcon = CCaInnerIconDescription::NewLC(); + + query->ExecuteL( innerIcon ); query->CloseStatement(); - if( !( !iconAttributs.iFileName.Compare( aEntry->GetIcon().iFileName ) - && (!iconAttributs.iSkinId.Compare( aEntry->GetIcon().iSkinId )) - && (!iconAttributs.iApplicationId.Compare( aEntry->GetIcon().iApplicationId )) + if( !( !innerIcon->FileName().Compare( aEntry->Icon()->FileName() ) + && (!innerIcon->SkinId().Compare( aEntry->Icon()->SkinId() )) + && (!innerIcon->ApplicationId().Compare( aEntry->Icon()->ApplicationId() )) ) ) { // entry's icon data is updated @@ -299,8 +368,11 @@ CleanupStack::PopAndDestroy( &innerEntries ); } + CleanupStack::PopAndDestroy( innerIcon ); + CleanupStack::PopAndDestroy( query ); } + // --------------------------------------------------------------------------- // // --------------------------------------------------------------------------- @@ -323,6 +395,7 @@ CreateAddIconQueryForUpdateL( aEntry, aQuery, aSqlDb ); } } + // --------------------------------------------------------------------------- // // --------------------------------------------------------------------------- @@ -335,21 +408,21 @@ query.CleanupClosePushL(); query.CreateL( KSQLUpdateIcon().Length() ); query.Append( KSQLUpdateIcon ); - if( aEntry->GetIcon().iFileName.Compare( KNullDesC ) ) + if( aEntry->Icon()->FileName().Compare( KNullDesC ) ) { query.ReAllocL( query.Length() + KSQLUpdateIconFileName().Length() + KComma().Length() ); query.Append( KSQLUpdateIconFileName ); query.Append( KComma ); } - if( aEntry->GetIcon().iSkinId.Compare( KNullDesC ) ) + if( aEntry->Icon()->SkinId().Compare( KNullDesC ) ) { query.ReAllocL( query.Length() + KSQLUpdateIconSkinId().Length() + KComma().Length() ); query.Append( KSQLUpdateIconSkinId ); query.Append( KComma ); } - if( aEntry->GetIcon().iApplicationId.Compare(KNullDesC) ) + if( aEntry->Icon()->ApplicationId().Compare(KNullDesC) ) { query.ReAllocL( query.Length() + KSQLUpdateIconAppId().Length() + KComma().Length() ); @@ -357,8 +430,7 @@ } if( !query.Right( KComma().Length() ).Compare( KComma ) ) { - query.Assign( query.Mid( query.Length() - - KComma().Length()).AllocL() ); + query.Delete( query.Length() - KComma().Length(), KComma().Length() ); } // add WHERE expr query.ReAllocL( query.Length() + KSQLUpdateIconWhere().Length() ); @@ -1035,9 +1107,9 @@ { CaSqlQueryCreator::TIconType iconType; if( - aEntry->GetIcon().iApplicationId.Length() == 0 && - aEntry->GetIcon().iSkinId.Length() == 0 && - aEntry->GetIcon().iFileName.Length() == 0 ) + aEntry->Icon()->ApplicationId().Length() == 0 && + aEntry->Icon()->SkinId().Length() == 0 && + aEntry->Icon()->FileName().Length() == 0 ) { if( aEntry->GetIconId() > 0 ) { diff -r a6d55a2e75be -r 782e3408c2ab contentstorage/cautils/inc/caentryattribute.h --- a/contentstorage/cautils/inc/caentryattribute.h Fri Mar 26 13:00:55 2010 +0200 +++ b/contentstorage/cautils/inc/caentryattribute.h Fri Apr 16 14:45:49 2010 +0300 @@ -131,6 +131,15 @@ */ IMPORT_C TBool Find( const TDesC& aName, TDes& aAttrVal ); + /** + * Find attribute by name. + * @param aId Id. + * @param aName Name. + * @param aAttr Attribute value. + * @return TBool, ETrue if attribute was found + */ + IMPORT_C TBool Find( const TDesC& aName, TPtrC& aAttrVal ); + /* * Check if attribute exists * @param aId Id diff -r a6d55a2e75be -r 782e3408c2ab contentstorage/cautils/inc/cainnerentry.h --- a/contentstorage/cautils/inc/cainnerentry.h Fri Mar 26 13:00:55 2010 +0200 +++ b/contentstorage/cautils/inc/cainnerentry.h Fri Apr 16 14:45:49 2010 +0300 @@ -21,6 +21,7 @@ #include #include "caentryattribute.h" +#include "cainnericondescription.h" /** * Class represents Content Arsenal entry @@ -28,19 +29,6 @@ NONSHARABLE_CLASS( CCaInnerEntry ): public CBase { public: - /* - * Struct containing icon attributes - */ - struct TIconAttributes - { - //TODO: maybe it should be C class with RBuf instead of TFileName - TInt iId; - TFileName iFileName; - TBuf iSkinId; - TBuf iApplicationId; - }; - -public: /** * Destructor. @@ -77,7 +65,7 @@ * @return Entry description. */ IMPORT_C const RBuf& GetDescription() const; - + /** * Gets entry typename. * @return Entry typename. @@ -85,10 +73,10 @@ IMPORT_C const RBuf& GetEntryTypeName() const; /** - * Gets icon attributes. - * @return Icon atrributes. + * Gets icon description. + * @return Icon description. */ - IMPORT_C const CCaInnerEntry::TIconAttributes& GetIcon() const; + IMPORT_C const CCaInnerIconDescription* Icon() const; /** * Gets entry flags. @@ -138,7 +126,7 @@ * @param aText Entry description. */ IMPORT_C void SetDescriptionL( const TDesC& aText ); - + /** * Sets the entry typename. * @param aTypeName Entry typename. @@ -151,8 +139,8 @@ * @param aSkinId Skin id. * @param aApplicationId application id. */ - IMPORT_C void SetIconDataL( - const TDesC& aFilename, const TDesC& aSkinId, const TDesC& aApplicationId ); + IMPORT_C void SetIconDataL( + const TDesC& aFilename, const TDesC& aSkinId, const TDesC& aApplicationId ); /** * Adds attribute to entry. @@ -186,7 +174,15 @@ * @return ETrue if attribute exists. */ IMPORT_C TBool FindAttribute( const TDesC& aKey, TDes& aAttrVal ); - + + /** + * Verifies if attribute exists, and returns its value for the given key. + * @param aKey Attribute key. + * @param aAttrVal Attribute value. + * @return ETrue if attribute exists. + */ + IMPORT_C TBool FindAttribute( const TDesC& aKey, TPtrC& aAttrVal ); + /** * Sets the entry uid. * @param aUid Entry uid. @@ -242,7 +238,7 @@ * Own. */ RBuf iDescription; - + /* * Entry type. * Own. @@ -250,9 +246,10 @@ RBuf iEntryTypeName; /* + * Icon. * Own. */ - TIconAttributes iIcon; + CCaInnerIconDescription* iIcon; /* * Flags. diff -r a6d55a2e75be -r 782e3408c2ab contentstorage/cautils/inc/cainnericondescription.h --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/contentstorage/cautils/inc/cainnericondescription.h Fri Apr 16 14:45:49 2010 +0300 @@ -0,0 +1,165 @@ +/* + * Copyright (c) 2008 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: Definition of entry attribute + * + */ + +#ifndef __CAINNERICONDESCRIPTION_H__ +#define __CAINNERICONDESCRIPTION_H__ + +#include + +//FORWARD DECLARATIONS +class RWriteStream; +class RReadStream; + +/** + * CA entry icon. + * @lib .lib + * @since S60 v5.0 + */ +NONSHARABLE_CLASS( CCaInnerIconDescription ): public CBase + { + +public: + + /** + * Destructor. + */ + virtual ~CCaInnerIconDescription(); + + /** + * Two-phased constructor. + * @return The created object. + */ + IMPORT_C static CCaInnerIconDescription* NewL(); + + /** + * Two-phased constructor. + * @return The created object. + */ + IMPORT_C static CCaInnerIconDescription* NewLC(); + + /** + * Gets icon id. + * @return iId. + */ + TInt Id() const + { + return iId; + } + + /** + * Gets file name. + * @return iFileName. + */ + TPtrC FileName() const + { + return iFileName; + } + + /** + * Gets skin id. + * @return iSkinId + */ + TPtrC SkinId() const + { + return iSkinId; + } + + /** + * Gets application id. + * @return iApplicationId + */ + TPtrC ApplicationId() const + { + return iApplicationId; + } + + /** + * Set icon id. + * @param aId Value + */ + IMPORT_C void SetId( const TInt aId ); + + /** + * Set icon file name. + * @param aFileName Value + * Ownership taken. + */ + IMPORT_C void SetFileNameL( const TDesC& aFileName ); + + /** + * Set icon skin id. + * @param aSkinId Value + * Ownership taken. + */ + IMPORT_C void SetSkinIdL( const TDesC& aSkinId ); + + /** + * Set application id. + * @param aApplicationId Value + * Ownership taken. + */ + IMPORT_C void SetApplicationIdL( const TDesC& aApplicationId ); + + /** + * Externalizes icon to the stream + * @param aStream a write stream + */ + void ExternalizeL( RWriteStream& aStream ) const; + + /** + * Internalizes stream to the icon + * @param aStream a read stream + */ + void InternalizeL( RReadStream& aStream ); + +private: + + /** + * Second phased constructor. + */ + void ConstructL(); + + /** + * Constructor + */ + CCaInnerIconDescription(); + +private: + // data + + /* + * icon id + */ + TInt iId; + + /* + * Icon filename + */ + RBuf iFileName; + + /* + * Icon skin id + */ + RBuf iSkinId; + + /* + * Icon application id + */ + RBuf iApplicationId; + }; + +#endif // __CAINNERICONDESCRIPTION_H__ diff -r a6d55a2e75be -r 782e3408c2ab contentstorage/cautils/src/caentryattribute.cpp --- a/contentstorage/cautils/src/caentryattribute.cpp Fri Mar 26 13:00:55 2010 +0200 +++ b/contentstorage/cautils/src/caentryattribute.cpp Fri Apr 16 14:45:49 2010 +0300 @@ -124,6 +124,23 @@ } // --------------------------------------------------------- +// RMenuSrvAttrArray::Find +// --------------------------------------------------------- +// +EXPORT_C TBool RCaEntryAttrArray::Find( const TDesC& aName, TPtrC& aAttrVal ) + { + for( TInt i = 0; i < Count(); i++ ) + { + if( aName.Compare( operator[]( i )->Name() ) == KErrNone ) + { + aAttrVal.Set( operator[]( i )->Value() ); + return ETrue; + } + } + return EFalse; + } + +// --------------------------------------------------------- // RCaEntryAttrArray::Exist // --------------------------------------------------------- // diff -r a6d55a2e75be -r 782e3408c2ab contentstorage/cautils/src/cainnerentry.cpp --- a/contentstorage/cautils/src/cainnerentry.cpp Fri Mar 26 13:00:55 2010 +0200 +++ b/contentstorage/cautils/src/cainnerentry.cpp Fri Apr 16 14:45:49 2010 +0300 @@ -30,6 +30,7 @@ iDescription.Close(); iEntryTypeName.Close(); iAttributes.ResetAndDestroy(); + delete iIcon; } // --------------------------------------------------------------------------- @@ -63,13 +64,6 @@ { aStream.WriteInt32L( iId ); aStream.WriteInt32L( iUid ); - aStream.WriteInt32L( iIcon.iId ); - aStream.WriteUint32L( iIcon.iFileName.Length() ); - aStream.WriteL( iIcon.iFileName, iIcon.iFileName.Length() ); - aStream.WriteUint32L( iIcon.iSkinId.Length() ); - aStream.WriteL( iIcon.iSkinId, iIcon.iSkinId.Length() ); - aStream.WriteUint32L( iIcon.iApplicationId.Length() ); - aStream.WriteL( iIcon.iApplicationId, iIcon.iApplicationId.Length() ); aStream.WriteUint32L( iFlags ); aStream.WriteUint32L( iRole ); aStream.WriteUint32L( iText.Length() ); @@ -79,6 +73,7 @@ aStream.WriteUint32L( iEntryTypeName.Length() ); aStream.WriteL( iEntryTypeName, iEntryTypeName.Length() ); iAttributes.ExternalizeL( aStream ); + iIcon->ExternalizeL( aStream ); aStream.CommitL(); } @@ -90,16 +85,9 @@ { iId = aStream.ReadInt32L(); iUid = aStream.ReadInt32L(); - iIcon.iId = aStream.ReadInt32L(); - TUint length = aStream.ReadUint32L(); - aStream.ReadL( iIcon.iFileName, length ); - length = aStream.ReadUint32L(); - aStream.ReadL( iIcon.iSkinId, length ); - length = aStream.ReadUint32L(); - aStream.ReadL( iIcon.iApplicationId, length ); iFlags = aStream.ReadUint32L(); iRole = aStream.ReadUint32L(); - length = aStream.ReadUint32L(); + TUint length = aStream.ReadUint32L(); iText.Close(); iText.CreateL( length ); aStream.ReadL( iText, length ); @@ -112,6 +100,7 @@ iEntryTypeName.CreateL( length ); aStream.ReadL( iEntryTypeName, length ); iAttributes.InternalizeL( aStream ); + iIcon->InternalizeL( aStream ); } // --------------------------------------------------------------------------- @@ -120,7 +109,7 @@ // void CCaInnerEntry::ConstructL() { - + iIcon = CCaInnerIconDescription::NewL(); } // --------------------------------------------------------------------------- @@ -129,7 +118,6 @@ // CCaInnerEntry::CCaInnerEntry() { - } // --------------------------------------------------------------------------- @@ -172,7 +160,7 @@ // // --------------------------------------------------------------------------- // -EXPORT_C const CCaInnerEntry::TIconAttributes& CCaInnerEntry::GetIcon() const +EXPORT_C const CCaInnerIconDescription* CCaInnerEntry::Icon() const { return iIcon; } @@ -219,7 +207,7 @@ // EXPORT_C TInt CCaInnerEntry::GetIconId() const { - return iIcon.iId; + return iIcon->Id(); } // SETTERS @@ -269,9 +257,9 @@ EXPORT_C void CCaInnerEntry::SetIconDataL( const TDesC& aFilename, const TDesC& aSkinId, const TDesC& aApplicationId ) { - iIcon.iFileName.Copy( aFilename ); - iIcon.iSkinId.Copy( aSkinId ); - iIcon.iApplicationId.Copy(aApplicationId); + iIcon->SetFileNameL( aFilename ); + iIcon->SetSkinIdL( aSkinId ); + iIcon->SetApplicationIdL( aApplicationId ); } // --------------------------------------------------------------------------- @@ -333,6 +321,16 @@ // // --------------------------------------------------------------------------- // +EXPORT_C TBool CCaInnerEntry::FindAttribute( const TDesC& aKey, + TPtrC& aAttrVal ) + { + return iAttributes.Find( aKey, aAttrVal ); + } + +// --------------------------------------------------------------------------- +// +// --------------------------------------------------------------------------- +// EXPORT_C void CCaInnerEntry::SetUid( TInt32 aUid ) { iUid = aUid; @@ -344,5 +342,5 @@ // EXPORT_C void CCaInnerEntry::SetIconId( TInt aIconId ) { - iIcon.iId = aIconId; + iIcon->SetId( aIconId ); } diff -r a6d55a2e75be -r 782e3408c2ab contentstorage/cautils/src/cainnericondescription.cpp --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/contentstorage/cautils/src/cainnericondescription.cpp Fri Apr 16 14:45:49 2010 +0300 @@ -0,0 +1,162 @@ +/* + * Copyright (c) 2008 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: Definition of entry attribute + * + */ + +// INCLUDE FILES +#include +#include "cainnericondescription.h" + +// ================= MEMBER FUNCTIONS ======================= + +// --------------------------------------------------------- +// CCaInnerIconDescription::~CCaInnerIconDescription +// --------------------------------------------------------- +// +CCaInnerIconDescription::~CCaInnerIconDescription() + { + iFileName.Close(); + iSkinId.Close(); + iApplicationId.Close(); + } + +// --------------------------------------------------------- +// CCaInnerIconDescription::NewL +// --------------------------------------------------------- +// +EXPORT_C CCaInnerIconDescription* CCaInnerIconDescription::NewL() + { + CCaInnerIconDescription* self = NewLC(); + CleanupStack::Pop( self ); + return self; + } + +// --------------------------------------------------------- +// CCaInnerIconDescription::NewLC +// --------------------------------------------------------- +// +EXPORT_C CCaInnerIconDescription* CCaInnerIconDescription::NewLC() + { + CCaInnerIconDescription* self = new ( ELeave ) CCaInnerIconDescription(); + CleanupStack::PushL( self ); + self->ConstructL(); + return self; + } + +// --------------------------------------------------------- +// CCaInnerIconDescription::ConstructL +// --------------------------------------------------------- +// +void CCaInnerIconDescription::ConstructL() + { + } + +// --------------------------------------------------------- +// CCaInnerIconDescription::CCaInnerIconDescription +// --------------------------------------------------------- +// +CCaInnerIconDescription::CCaInnerIconDescription() + { + } + +// --------------------------------------------------------- +// CCaInnerIconDescription::SetId +// --------------------------------------------------------- +// +EXPORT_C void CCaInnerIconDescription::SetId( const TInt aId ) + { + iId = aId; + } + +// --------------------------------------------------------- +// CCaInnerIconDescription::SetFileNameL +// --------------------------------------------------------- +// +EXPORT_C void CCaInnerIconDescription::SetFileNameL( const TDesC& aFileName ) + { + if( iFileName.Length() > 0 ) + { + iFileName.Close(); + } + iFileName.CreateL( aFileName ); + } + +// --------------------------------------------------------- +// CCaInnerIconDescription::SetSkinIdL +// --------------------------------------------------------- +// +EXPORT_C void CCaInnerIconDescription::SetSkinIdL( const TDesC& aSkinId ) + { + if( iSkinId.Length() > 0 ) + { + iSkinId.Close(); + } + iSkinId.CreateL( aSkinId ); + } + +// --------------------------------------------------------- +// CCaInnerIconDescription::SetApplicationIdL +// --------------------------------------------------------- +// +EXPORT_C void CCaInnerIconDescription::SetApplicationIdL( const TDesC& aApplicationId ) + { + if( iApplicationId.Length() > 0 ) + { + iApplicationId.Close(); + } + iApplicationId.CreateL( aApplicationId ); + } + +// --------------------------------------------------------------------------- +// CCaInnerIconDescription::ExternalizeL +// --------------------------------------------------------------------------- +// +void CCaInnerIconDescription::ExternalizeL( RWriteStream& aStream ) const + { + aStream.WriteInt32L( iId ); + aStream.WriteUint32L( iFileName.Length() ); + aStream.WriteL( iFileName, iFileName.Length() ); + aStream.WriteUint32L( iSkinId.Length() ); + aStream.WriteL( iSkinId, iSkinId.Length() ); + aStream.WriteUint32L( iApplicationId.Length() ); + aStream.WriteL( iApplicationId, iApplicationId.Length() ); + aStream.CommitL(); + } + +// --------------------------------------------------------------------------- +// CCaInnerIconDescription::InternalizeL +// --------------------------------------------------------------------------- +// +void CCaInnerIconDescription::InternalizeL( RReadStream& aStream ) + { + iId = aStream.ReadInt32L(); + + TUint length = aStream.ReadUint32L(); + iFileName.Close(); + iFileName.CreateL( length ); + aStream.ReadL( iFileName, length ); + + length = aStream.ReadUint32L(); + iSkinId.Close(); + iSkinId.CreateL( length ); + aStream.ReadL( iSkinId, length ); + + length = aStream.ReadUint32L(); + iApplicationId.Close(); + iApplicationId.CreateL( length ); + aStream.ReadL( iApplicationId, length ); + } + +// End of File diff -r a6d55a2e75be -r 782e3408c2ab contentstorage/contentstorage.pro --- a/contentstorage/contentstorage.pro Fri Mar 26 13:00:55 2010 +0200 +++ b/contentstorage/contentstorage.pro Fri Apr 16 14:45:49 2010 +0300 @@ -20,6 +20,7 @@ SUBDIRS += cautils SUBDIRS += group SUBDIRS += casrv/calocalizerscanner +SUBDIRS += cahandler } SUBDIRS += caclient CONFIG += ordered diff -r a6d55a2e75be -r 782e3408c2ab contentstorage/eabi/caextendedmenuu.def --- a/contentstorage/eabi/caextendedmenuu.def Fri Mar 26 13:00:55 2010 +0200 +++ /dev/null Thu Jan 01 00:00:00 1970 +0000 @@ -1,3 +0,0 @@ -EXPORTS - _ZN17CaMenuIconUtility11GetItemIconERK13CCaInnerEntry @ 1 NONAME - diff -r a6d55a2e75be -r 782e3408c2ab contentstorage/eabi/camenuu.def --- a/contentstorage/eabi/camenuu.def Fri Mar 26 13:00:55 2010 +0200 +++ b/contentstorage/eabi/camenuu.def Fri Apr 16 14:45:49 2010 +0300 @@ -21,4 +21,6 @@ _ZNK14CCaSrvEngUtils13GetApaAppInfoE4TUidR11TApaAppInfo @ 20 NONAME _ZTI15CCaStorageProxy @ 21 NONAME _ZTV15CCaStorageProxy @ 22 NONAME + _ZN13CCaMmcWatcher4NewLER3RFsP19MMmcWatcherCallback @ 23 NONAME + _ZN13CCaMmcWatcher5NewLCER3RFsP19MMmcWatcherCallback @ 24 NONAME diff -r a6d55a2e75be -r 782e3408c2ab contentstorage/eabi/cautilsu.def --- a/contentstorage/eabi/cautilsu.def Fri Mar 26 13:00:55 2010 +0200 +++ b/contentstorage/eabi/cautilsu.def Fri Apr 16 14:45:49 2010 +0300 @@ -50,42 +50,50 @@ _ZN22CCaInnerNotifierFilter4NewLENS_13TNotifierTypeE @ 49 NONAME _ZN22CCaInnerNotifierFilter5NewLCENS_13TNotifierTypeE @ 50 NONAME _ZN22CCaInnerNotifierFilter7SetIdsLERK6RArrayIiE @ 51 NONAME - _ZN9MenuUtils8GetTUintERK7TDesC16Rj @ 52 NONAME - _ZNK11RCaIdsArray12ExternalizeLER12RWriteStream @ 53 NONAME - _ZNK11RCaIdsArray13MarshalDataLCEv @ 54 NONAME - _ZNK13CCaInnerEntry12ExternalizeLER12RWriteStream @ 55 NONAME - _ZNK13CCaInnerEntry13GetAttributesEv @ 56 NONAME - _ZNK13CCaInnerEntry14GetDescriptionEv @ 57 NONAME - _ZNK13CCaInnerEntry16GetEntryTypeNameEv @ 58 NONAME - _ZNK13CCaInnerEntry5GetIdEv @ 59 NONAME - _ZNK13CCaInnerEntry6GetUidEv @ 60 NONAME - _ZNK13CCaInnerEntry7GetIconEv @ 61 NONAME - _ZNK13CCaInnerEntry7GetRoleEv @ 62 NONAME - _ZNK13CCaInnerEntry7GetTextEv @ 63 NONAME - _ZNK13CCaInnerEntry8GetFlagsEv @ 64 NONAME - _ZNK13CCaInnerEntry9GetIconIdEv @ 65 NONAME - _ZNK13CCaInnerQuery10GetFlagsOnEv @ 66 NONAME - _ZNK13CCaInnerQuery11GetFlagsOffEv @ 67 NONAME - _ZNK13CCaInnerQuery11GetParentIdEv @ 68 NONAME - _ZNK13CCaInnerQuery12ExternalizeLER12RWriteStream @ 69 NONAME - _ZNK13CCaInnerQuery13GetAttributesEv @ 70 NONAME - _ZNK13CCaInnerQuery17GetEntryTypeNamesEv @ 71 NONAME - _ZNK13CCaInnerQuery6GetIdsEv @ 72 NONAME - _ZNK13CCaInnerQuery6GetUidEv @ 73 NONAME - _ZNK13CCaInnerQuery7GetRoleEv @ 74 NONAME - _ZNK13CCaInnerQuery7GetSortEv @ 75 NONAME - _ZNK13CCaInnerQuery8GetCountEv @ 76 NONAME - _ZNK15RCaEntriesArray12ExternalizeLER12RWriteStream @ 77 NONAME - _ZNK20CCaLocalizationEntry11GetStringIdEv @ 78 NONAME - _ZNK20CCaLocalizationEntry12GetTableNameEv @ 79 NONAME - _ZNK20CCaLocalizationEntry16GetAttributeNameEv @ 80 NONAME - _ZNK20CCaLocalizationEntry18GetLocalizedStringEv @ 81 NONAME - _ZNK20CCaLocalizationEntry8GetRowIdEv @ 82 NONAME - _ZNK20CCaLocalizationEntry9GetTextIdEv @ 83 NONAME - _ZNK22CCaInnerNotifierFilter11GetParentIdEv @ 84 NONAME - _ZNK22CCaInnerNotifierFilter12ExternalizeLER12RWriteStream @ 85 NONAME - _ZNK22CCaInnerNotifierFilter12GetEntryRoleEv @ 86 NONAME - _ZNK22CCaInnerNotifierFilter12GetTypeNamesEv @ 87 NONAME - _ZNK22CCaInnerNotifierFilter15GetNotifierTypeEv @ 88 NONAME - _ZNK22CCaInnerNotifierFilter6GetIdsEv @ 89 NONAME + _ZN23CCaInnerIconDescription10SetSkinIdLERK7TDesC16 @ 52 NONAME + _ZN23CCaInnerIconDescription12SetFileNameLERK7TDesC16 @ 53 NONAME + _ZN23CCaInnerIconDescription17SetApplicationIdLERK7TDesC16 @ 54 NONAME + _ZN23CCaInnerIconDescription4NewLEv @ 55 NONAME + _ZN23CCaInnerIconDescription5NewLCEv @ 56 NONAME + _ZN23CCaInnerIconDescription5SetIdEi @ 57 NONAME + _ZN9MenuUtils8GetTUintERK7TDesC16Rj @ 58 NONAME + _ZNK11RCaIdsArray12ExternalizeLER12RWriteStream @ 59 NONAME + _ZNK11RCaIdsArray13MarshalDataLCEv @ 60 NONAME + _ZNK13CCaInnerEntry12ExternalizeLER12RWriteStream @ 61 NONAME + _ZNK13CCaInnerEntry13GetAttributesEv @ 62 NONAME + _ZNK13CCaInnerEntry14GetDescriptionEv @ 63 NONAME + _ZNK13CCaInnerEntry16GetEntryTypeNameEv @ 64 NONAME + _ZNK13CCaInnerEntry4IconEv @ 65 NONAME + _ZNK13CCaInnerEntry5GetIdEv @ 66 NONAME + _ZNK13CCaInnerEntry6GetUidEv @ 67 NONAME + _ZNK13CCaInnerEntry7GetRoleEv @ 68 NONAME + _ZNK13CCaInnerEntry7GetTextEv @ 69 NONAME + _ZNK13CCaInnerEntry8GetFlagsEv @ 70 NONAME + _ZNK13CCaInnerEntry9GetIconIdEv @ 71 NONAME + _ZNK13CCaInnerQuery10GetFlagsOnEv @ 72 NONAME + _ZNK13CCaInnerQuery11GetFlagsOffEv @ 73 NONAME + _ZNK13CCaInnerQuery11GetParentIdEv @ 74 NONAME + _ZNK13CCaInnerQuery12ExternalizeLER12RWriteStream @ 75 NONAME + _ZNK13CCaInnerQuery13GetAttributesEv @ 76 NONAME + _ZNK13CCaInnerQuery17GetEntryTypeNamesEv @ 77 NONAME + _ZNK13CCaInnerQuery6GetIdsEv @ 78 NONAME + _ZNK13CCaInnerQuery6GetUidEv @ 79 NONAME + _ZNK13CCaInnerQuery7GetRoleEv @ 80 NONAME + _ZNK13CCaInnerQuery7GetSortEv @ 81 NONAME + _ZNK13CCaInnerQuery8GetCountEv @ 82 NONAME + _ZNK15RCaEntriesArray12ExternalizeLER12RWriteStream @ 83 NONAME + _ZNK20CCaLocalizationEntry11GetStringIdEv @ 84 NONAME + _ZNK20CCaLocalizationEntry12GetTableNameEv @ 85 NONAME + _ZNK20CCaLocalizationEntry16GetAttributeNameEv @ 86 NONAME + _ZNK20CCaLocalizationEntry18GetLocalizedStringEv @ 87 NONAME + _ZNK20CCaLocalizationEntry8GetRowIdEv @ 88 NONAME + _ZNK20CCaLocalizationEntry9GetTextIdEv @ 89 NONAME + _ZNK22CCaInnerNotifierFilter11GetParentIdEv @ 90 NONAME + _ZNK22CCaInnerNotifierFilter12ExternalizeLER12RWriteStream @ 91 NONAME + _ZNK22CCaInnerNotifierFilter12GetEntryRoleEv @ 92 NONAME + _ZNK22CCaInnerNotifierFilter12GetTypeNamesEv @ 93 NONAME + _ZNK22CCaInnerNotifierFilter15GetNotifierTypeEv @ 94 NONAME + _ZNK22CCaInnerNotifierFilter6GetIdsEv @ 95 NONAME + _ZN13CCaInnerEntry13FindAttributeERK7TDesC16R7TPtrC16 @ 96 NONAME + _ZN17RCaEntryAttrArray4FindERK7TDesC16R7TPtrC16 @ 97 NONAME diff -r a6d55a2e75be -r 782e3408c2ab contentstorage/extinc/camenuiconutility.h --- a/contentstorage/extinc/camenuiconutility.h Fri Mar 26 13:00:55 2010 +0200 +++ /dev/null Thu Jan 01 00:00:00 1970 +0000 @@ -1,46 +0,0 @@ -/* -* Copyright (c) 2008 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 API supports requesting raw bitmaps - * -*/ - - -#ifndef __CAMENUICONUTILITY_H__ -#define __CAMENUICONUTILITY_H__ - -#include - -class CCaInnerEntry; - -/** - * Icon utility. - * This is a utilitiy class providing method(s) for querying raw bitmap data - * belonging to menu items - * @lib caextendedmenu.lib - * @since S60 v5.0 - */ -NONSHARABLE_CLASS( CaMenuIconUtility ) - { -public: - /** - * Creates the icon that belongs to a menu item. - * @since S60 v5.0. - * @param aEntry entry for which an icon is queried for - * @return the icon of the specified entry. The ownership of the icon - * object is transferred to the caller. - */ - IMPORT_C static CAknIcon* GetItemIcon( const CCaInnerEntry &aEntry ); - }; - -#endif // __CAMENUICONUTILITY_H__ diff -r a6d55a2e75be -r 782e3408c2ab contentstorage/extinc/casathandler.h --- a/contentstorage/extinc/casathandler.h Fri Mar 26 13:00:55 2010 +0200 +++ b/contentstorage/extinc/casathandler.h Fri Apr 16 14:45:49 2010 +0300 @@ -20,7 +20,7 @@ #include -#include +#include #include #ifdef SIM_ATK_SERVICE_API_V1 #include // MCL diff -r a6d55a2e75be -r 782e3408c2ab contentstorage/extsrc/caiconutility.cpp --- a/contentstorage/extsrc/caiconutility.cpp Fri Mar 26 13:00:55 2010 +0200 +++ /dev/null Thu Jan 01 00:00:00 1970 +0000 @@ -1,172 +0,0 @@ -/* - * Copyright (c) 2008 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 API supports requesting raw bitmaps - * - */ - -// INCLUDE FILES -#include -#include -#include -#include -#include -#include -#include "cadef.h" -#include "cautils.h" -#include "cainnerentry.h" -#include "camenuiconutility.h" -#include "caarraycleanup.inl" -#include "casathandler.h" - -// ================= LOCAL FUNCTIONS ======================== - -// --------------------------------------------------------- -// LoadSkinL -// --------------------------------------------------------- -// -LOCAL_C CAknIcon* GetSkinL( TInt majorId, TInt minorId ) - { - CAknIcon* icon = NULL; - if( majorId >= 0 && minorId >= 0 ) - { - CFbsBitmap* bitmap( 0 ); - CFbsBitmap* mask( 0 ); - - TAknsItemID skinId; - skinId.Set( majorId, minorId ); - - MAknsSkinInstance* skinInstance = AknsUtils::SkinInstance(); - if( skinInstance ) - { - AknsUtils::CreateIconLC( skinInstance, skinId, bitmap, mask, - KNullDesC, KErrNotFound, KErrNotFound ); - icon = CAknIcon::NewL(); - icon->SetBitmap( bitmap ); - icon->SetMask( mask ); - } - - // bitmap and icon, AknsUtils::CreateIconLC doesn't specify the order - CleanupStack::Pop( 2 ); - } - - return icon; - } - -// --------------------------------------------------------- -// GetAppSkinL -// --------------------------------------------------------- -// -LOCAL_C CAknIcon* GetAppSkinL( TUid& aAppUid ) - { - CAknIcon* icon = NULL; - CFbsBitmap* bitmap( 0 ); - CFbsBitmap* mask( 0 ); - - MAknsSkinInstance* skin = AknsUtils::SkinInstance(); - if( skin ) - { - TRAPD( err, - { - AknsUtils::CreateAppIconLC( skin, aAppUid, - EAknsAppIconTypeList, bitmap, mask ); - CleanupStack::Pop(2); //for trap - } - ); - if( err == KErrNone ) - { - icon = CAknIcon::NewL(); - icon->SetBitmap( bitmap ); - icon->SetMask( mask ); - } - } - return icon; - } - - -// --------------------------------------------------------- -// GetDefaultSkinL -// --------------------------------------------------------- -// -LOCAL_C CAknIcon* GetDefaultSkinL( const CCaInnerEntry &aItem ) - { - CAknIcon* icon = NULL; - if( aItem.GetEntryTypeName().Compare( KCaTypeApp ) == KErrNone ) - { - TUid appUid( TUid::Uid( aItem.GetUid() ) ); - if( appUid == KSatUid ) - { - CCaSatHandler* satHandler = CCaSatHandler::NewL(); - CleanupStack::PushL( satHandler ); - icon = satHandler->LoadIconL(); - CleanupStack::PopAndDestroy( satHandler ); - } - if( !icon ) - { - icon = GetAppSkinL( appUid ); - } - if( !icon ) - { - icon = GetSkinL( KAknsIIDQgnMenuUnknownLst.iMajor, - KAknsIIDQgnMenuUnknownLst.iMinor ); - } - } - else if( aItem.GetEntryTypeName().Compare( KCaTypeFolder ) == KErrNone - || aItem.GetEntryTypeName().Compare( KCaTypeCollection ) - == KErrNone || aItem.GetEntryTypeName().Compare( - KCaTypeCollectionDownload ) == KErrNone ) - { - icon = GetSkinL( KAknsIIDQgnPropFolderAppsMedium.iMajor, - KAknsIIDQgnPropFolderAppsMedium.iMinor ); - } - else if( aItem.GetEntryTypeName().Compare( KCaTypeUrl ) == KErrNone ) - { - icon = GetSkinL( KAknsIIDQgnPropPbCommUrl.iMajor, - KAknsIIDQgnPropPbCommUrl.iMinor ); - } - else if( aItem.GetEntryTypeName().Compare( KCaTypeWidget ) == KErrNone ) - { - icon = GetSkinL( KAknsIIDQgnIndiBrowserTbFeeds.iMajor, - KAknsIIDQgnIndiBrowserTbFeeds.iMinor ); - } - else if( aItem.GetEntryTypeName().Compare( KCaTypeTemplatedApp ) == KErrNone ) - { - TInt uid; - TLex lex (aItem.GetIcon().iApplicationId); - lex.Val(uid); - TUid appUid( TUid::Uid( uid ) ); - icon = GetAppSkinL( appUid ); - if( !icon ) - { - icon = GetSkinL( KAknsIIDQgnMenuUnknownLst.iMajor, - KAknsIIDQgnMenuUnknownLst.iMinor ); - } - } - - return icon; - } - -// ================= MEMBER FUNCTIONS ======================= - -// --------------------------------------------------------- -// MenuIconUtility::GetItemIcon -// --------------------------------------------------------- -// -EXPORT_C CAknIcon* CaMenuIconUtility::GetItemIcon( - const CCaInnerEntry &aEntry ) - { - CAknIcon* icon = NULL; - CCaInnerEntry::TIconAttributes iconAttributes( aEntry.GetIcon() ); - TRAP_IGNORE( icon = GetDefaultSkinL( aEntry ) ); - return icon; - } diff -r a6d55a2e75be -r 782e3408c2ab contentstorage/group/caextendedmenu.mmp --- a/contentstorage/group/caextendedmenu.mmp Fri Mar 26 13:00:55 2010 +0200 +++ /dev/null Thu Jan 01 00:00:00 1970 +0000 @@ -1,47 +0,0 @@ -/* -* Copyright (c) 2008 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: -* -*/ - -// To get the MW_LAYER_SYSTEMINCLUDE-definition -#include - -TARGET caextendedmenu.dll -TARGETTYPE dll -UID 0x1000008D 0x20022F8C -CAPABILITY CAP_GENERAL_DLL -VENDORID VID_DEFAULT - -SOURCEPATH ../extsrc -SOURCE caiconutility.cpp - -USERINCLUDE ../inc -USERINCLUDE ../extinc -USERINCLUDE ../cautils/inc -USERINCLUDE ../castorage/inc/ - -MW_LAYER_SYSTEMINCLUDE - -LIBRARY euser.lib -LIBRARY aknskins.lib -LIBRARY aknicon.lib -LIBRARY camenu.lib -LIBRARY cautils.lib -LIBRARY fbscli.lib -LIBRARY casathandler.lib -LIBRARY efsrv.lib -LIBRARY apgrfx.lib -LIBRARY ecom.lib - diff -r a6d55a2e75be -r 782e3408c2ab contentstorage/group/camenu.mmp --- a/contentstorage/group/camenu.mmp Fri Mar 26 13:00:55 2010 +0200 +++ b/contentstorage/group/camenu.mmp Fri Apr 16 14:45:49 2010 +0300 @@ -12,7 +12,7 @@ * Contributors: * * Description: -* Version : %version: 19.1.3 % << Don't touch! Updated by Synergy at check-out. +* Version : %version: 19.1.6 % << Don't touch! Updated by Synergy at check-out. * */ @@ -34,6 +34,8 @@ SOURCE casrv.cpp SOURCE casrvmmchistory.cpp SOURCE cainstallnotifier.cpp +SOURCE cainstallstrategy.cpp +SOURCE cammcwatcher.cpp SOURCE casrvengutils.cpp SOURCE casrvnotifier.cpp SOURCE castorageproxy.cpp @@ -46,7 +48,7 @@ USERINCLUDE ../casrv/casrvmgr/inc -MW_LAYER_SYSTEMINCLUDE +APP_LAYER_SYSTEMINCLUDE LIBRARY euser.lib LIBRARY efsrv.lib @@ -56,6 +58,7 @@ LIBRARY cautils.lib LIBRARY castorage.lib LIBRARY sysutil.lib +LIBRARY platformenv.lib LIBRARY ws32.lib LIBRARY bafl.lib diff -r a6d55a2e75be -r 782e3408c2ab contentstorage/group/group.pro --- a/contentstorage/group/group.pro Fri Mar 26 13:00:55 2010 +0200 +++ b/contentstorage/group/group.pro Fri Apr 16 14:45:49 2010 +0300 @@ -31,11 +31,11 @@ "../casrv/casrvmgr/group/casrvmanager.mmp" \ "camenu.mmp" \ "camenusrv.mmp" \ - "caextendedmenu.mmp" \ "../casrv/caappscanner/group/caappscanner.mmp" \ "../casrv/casatmonitor/group/casatmonitor.mmp" \ "../casrv/cawidgetscanner/group/cawidgetscanner.mmp" \ - "../casrv/carunningappmonitor/group/carunningappmonitor.mmp" + "../casrv/carunningappmonitor/group/carunningappmonitor.mmp" \ + "../casrv/causifscanner/group/causifscanner.mmp" \ tests_krakow { BLD_INF_RULES.prj_mmpfiles += \ diff -r a6d55a2e75be -r 782e3408c2ab contentstorage/inc/cadef.h --- a/contentstorage/inc/cadef.h Fri Mar 26 13:00:55 2010 +0200 +++ b/contentstorage/inc/cadef.h Fri Apr 16 14:45:49 2010 +0300 @@ -12,7 +12,7 @@ * Contributors: * * Description: Definition of different constants - * Version : %version: 10.1.7 % << Don't touch! Updated by Synergy at check-out. + * Version : %version: 10.1.12 % << Don't touch! Updated by Synergy at check-out. * */ @@ -57,11 +57,14 @@ EMissing = 64 }; // Ca - Application + +_LIT( KCaTypeMenuCollections, "menucollections" ); _LIT( KCaTypeFolder, "folder" ); _LIT( KCaTypeCollection, "collection" ); _LIT( KCaTypeApp, "application" ); _LIT( KCaTypeWidget, "widget" ); _LIT( KCaTypeUrl, "url" ); +_LIT( KCaTypePackage, "package" ); _LIT( KCaAttrView, "view" ); ///< View. _LIT( KCaAttrUrl, "url" ); _LIT( KCaAttrWindowGroupId, "window_group_id" ); @@ -69,6 +72,20 @@ _LIT( KCaPackageUid,"packageuid"); _LIT( KCaAttrInstallationTime, "installationTime"); _LIT( KCaTypeTemplatedApp, "templatedApplication" ); +_LIT( KCaAttrAppType, "apptype"); +_LIT( KCaAttrAppTypeValueJava, "java"); +_LIT( KCaAttrAppTypeValueCWRT, "cwrt"); +_LIT( KCaAttrAppTypeValueNative, "native"); +_LIT( KCaAttrComponentId, "component_id" ); +_LIT( KCaAttrAppSettingsPlugin, "app_settings_plugin"); +// app settings plugin for java apps +_LIT( KCaAttrJavaAppSettingsPluginValue, + "/resource/qt/plugins/appsettings/javaapplicationsettingsview.qtplugin"); +_LIT( KCaAttrAppWidgetUri, "widget:uri"); +_LIT( KCaAttrAppWidgetUriCWRTValue, "wrtwidgetuiplugin"); +_LIT( KCaAttrAppWidgetParamWebAppId, "widgetparam:webAppId"); + +_LIT( KCaAppGroupName, "appgroup_name" ); const TInt KGranularityOne = 1; const TInt KUidChars = 10; @@ -95,7 +112,17 @@ { 0x20022F35 }; - + +const TUid KMidletApplicationTypeUid = + { + 0x10210E26 + }; + +const TUid KCWRTApplicationTypeUid = + { + 0x200267DC + }; + const TInt KCenRepBufferSize = 255; // // Attributes commonly used for all items. diff -r a6d55a2e75be -r 782e3408c2ab contentstorage/srvinc/cainstallnotifier.h --- a/contentstorage/srvinc/cainstallnotifier.h Fri Mar 26 13:00:55 2010 +0200 +++ b/contentstorage/srvinc/cainstallnotifier.h Fri Apr 16 14:45:49 2010 +0300 @@ -23,6 +23,8 @@ #include #include "castorage_global.h" +class CNotifierStrategy; + /** * Interface for updating after installer events. * @@ -37,7 +39,7 @@ * Pure virtual method. * @param aEvent event type. */ - virtual void HandleInstallNotifyL( TInt aEvent ) = 0; + virtual void HandleInstallNotifyL(TInt aEvent) = 0; }; /** @@ -45,43 +47,24 @@ * * @since S60 v5.0 */ -NONSHARABLE_CLASS( CCaInstallNotifier ): public CActive +NONSHARABLE_CLASS( CCaInstallNotifier ) : public CActive { public: /** - * Enum defining the operation type. - */ - enum TInstOp - { - EInstOpNone = 0x00000000, - EInstOpInstall = 0x00000001, - EInstOpUninstall = 0x00000002, - EInstOpRestore = 0x00000004 - }; - - /** - * Enum defining the operation status. - */ - enum TInstOpStatus - { - EInstOpStatusNone = 0x00000000, - EInstOpStatusSuccess = 0x00000100, - EInstOpStatusAborted = 0x00000200 - }; - - /** * Enum defining notification type. */ enum TNotificationType { - ENoNotification = 0x00000000, - ESisInstallNotification = KUidSwiLatestInstallation, ///< installation notification + ENoNotification, ///< No notification. + ESisInstallNotification, ///< System installation notification. + EJavaInstallNotification, ///< Java instalation and uninstallation notification. + EUsifUninstallNotification, ///< Usif's uninstalation notification. }; /** - * Creates an instance of CCaInstallNotifier implementation. + * Creates an instance of CCaInstallNotifier. * @param aNotifier Reference to notifier interface. * @param aNotificationType Notification type. */ @@ -99,14 +82,13 @@ * Constructor. * @param aNotifier Reference to notifier interface. */ - CCaInstallNotifier( MCaInstallListener& aListener, - TNotificationType aNotificationType ); + CCaInstallNotifier( MCaInstallListener& aListener ); /** * Symbian 2nd phase constructor. * @param aNotificationType Notification type. */ - void ConstructL(); + void ConstructL( TNotificationType aNotificationType ); /** * From CActive. @@ -138,9 +120,9 @@ MCaInstallListener& iListener; /* - * Notification type. + * Notification strategy. */ - TInt iRPropertyKey; + CNotifierStrategy* iNotifierStrategy; }; diff -r a6d55a2e75be -r 782e3408c2ab contentstorage/srvinc/cainstallstrategy.h --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/contentstorage/srvinc/cainstallstrategy.h Fri Apr 16 14:45:49 2010 +0300 @@ -0,0 +1,168 @@ +/* + * Copyright (c) 2008 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: ?Description + * + */ + +#ifndef CAINSTALLSTRATEGY_H +#define CAINSTALLSTRATEGY_H + +#include "cainstallnotifier.h" +#include +#include + +/** + * Strategy interface. + * + * @since S60 v5.0 + */ +class CNotifierStrategy: public CBase + { +public: + + /** + * Notifies listener with changes in property. + * @param aProperty to read values from. + * @param aListener listener to notify. + */ + virtual void NotifyListenerL( RProperty& aProperty, + MCaInstallListener& aListener ) = 0; + + }; + +/** + * CA Install strategy. + * + * @since S60 v5.0 + */ +NONSHARABLE_CLASS( CCaSwiInstallStrategy ): public CNotifierStrategy + { +public: + + /** + * Creates an instance of CCaInstallStrategy. + * @param aProperty property to handle. + */ + static CCaSwiInstallStrategy* NewL( RProperty& aProperty ); + + /** + * Notifies listener with changes in property. + * @param aProperty to read values from. + * @param aListener listener to notify. + */ + void NotifyListenerL( RProperty& aProperty, + MCaInstallListener& aListener ); + +private: + + /** + * Constructor. + * @param aProperty property to handle. + */ + CCaSwiInstallStrategy( RProperty& aProperty ); + + /** + * Symbian 2nd phase constructor. + */ + void ConstructL(); + + }; + +/** + * CA Java install strategy. + * + * @since S60 v5.0 + */ +NONSHARABLE_CLASS( CCaJavaInstallStrategy ): public CNotifierStrategy + { +public: + + /** + * Creates an instance of CCaInstallStrategy. + * @param aProperty property to handle. + */ + static CCaJavaInstallStrategy* NewL( RProperty& aProperty ); + + /** + * Notifies listener with changes in property. + * @param aProperty to read values from. + * @param aListener listener to notify. + */ + void NotifyListenerL( RProperty& aProperty, + MCaInstallListener& aListener ); + +private: + + /** + * Constructor. + * @param aProperty property to handle. + */ + CCaJavaInstallStrategy( RProperty& aProperty ); + + /** + * Symbian 2nd phase constructor. + */ + void ConstructL(); + + }; + +/** + * CA Unninstal with USIF strategy. + * + * @since S60 v5.0 + */ +NONSHARABLE_CLASS( CCaUsifUninstallStrategy ): public CNotifierStrategy + { +public: + + /** + * Creates an instance of CCaInstallStrategy. + * @param aProperty property to handle. + */ + static CCaUsifUninstallStrategy* NewL( RProperty& aProperty ); + + /** + * Notifies listener with changes in property. + * @param aProperty to read values from. + * @param aListener listener to notify. + */ + void NotifyListenerL( RProperty& aProperty, + MCaInstallListener& aListener ); + +private: + + /** + * Constructor. + * @param aProperty property to handle. + */ + CCaUsifUninstallStrategy( RProperty& aProperty ); + + /** + * Symbian 2nd phase constructor. + */ + void ConstructL(); + +private: + + /** + * Contains uid of application that was started to uninstall. + */ + TInt iAppUid; + + }; + +#endif /* CAINSTALLSTRATEGY_H */ + +// End of File + diff -r a6d55a2e75be -r 782e3408c2ab contentstorage/srvinc/cammcwatcher.h --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/contentstorage/srvinc/cammcwatcher.h Fri Apr 16 14:45:49 2010 +0300 @@ -0,0 +1,122 @@ +/* +* Copyright (c) 2008 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: +* +*/ + +#ifndef C_CAMMCWATCHER_H +#define C_CAMMCWATCHER_H + + +#include +#include + +/** + * Interface for observing MMC events. + * + * @since S60 S60 v3.1 + */ +class MMmcWatcherCallback + { + +public: + /** + * MmcChangeL is called when the MMC is removed or inserted. + */ + virtual void MmcChangeL() = 0; + + }; + +/** + * This active object waits for an indication that the media has changed. + * + * @since S60 S60 v3.1 + */ +NONSHARABLE_CLASS( CCaMmcWatcher ) : public CActive + { + +public: + + /** + * Two-phased constructor. + * @param aObserver Pointer to notifier interface. + * @param aFs file server session. + */ +IMPORT_C static CCaMmcWatcher* NewL( RFs& aFs, + MMmcWatcherCallback* aObserver ); + + /** + * Two-phased constructor. + * @param aObserver Pointer to notifier interface. + * @param aFs file server session. + */ +IMPORT_C static CCaMmcWatcher* NewLC( RFs& aFs, + MMmcWatcherCallback* aObserver ); + + /** + * Destructor + */ + ~CCaMmcWatcher(); + +private: + + /** + * C++ default constructor + * @param aObserver Pointer to notifier interface. + * @param aFs file server session. + */ + CCaMmcWatcher( RFs& aFs, MMmcWatcherCallback* aObserver ); + + /** + * By default Symbian OS constructor is private. + */ + void ConstructL(); + + /** + * Set notification request + */ + void WaitForChangeL(); + + /** + * From CActive. + */ + void DoCancel(); + + /** + * From CActive. + */ + void RunL(); + + /** + * From CActive. + */ + TInt RunError( TInt aError ); + +private: + + /** + * File server session. + * Not Own + */ + RFs iFs; + + /** + * MMC events observer + * Not own. + */ + MMmcWatcherCallback* iObserver; + }; + + +#endif // C_CAMMCWATCHER_H diff -r a6d55a2e75be -r 782e3408c2ab contentstorage/srvinc/casrvengutils.h --- a/contentstorage/srvinc/casrvengutils.h Fri Mar 26 13:00:55 2010 +0200 +++ b/contentstorage/srvinc/casrvengutils.h Fri Apr 16 14:45:49 2010 +0300 @@ -47,7 +47,7 @@ * @param aAttrExists ETrue if attribute exist. * @param aAttrVal attribute value. */ - TBool IsNative( const CCaInnerEntry& aEntry ); + TBool IsNativeL( const CCaInnerEntry& aEntry ); private: @@ -61,7 +61,7 @@ * @param aAppUid applications uid * @param aIsNative ETrue if apppication is native */ - void IsNative( TUid aAppUid, TBool& aIsNative ); + void IsNativeL( TUid aAppUid, TBool& aIsNative ); private: // Data diff -r a6d55a2e75be -r 782e3408c2ab contentstorage/srvsrc/cainstallnotifier.cpp --- a/contentstorage/srvsrc/cainstallnotifier.cpp Fri Mar 26 13:00:55 2010 +0200 +++ b/contentstorage/srvsrc/cainstallnotifier.cpp Fri Apr 16 14:45:49 2010 +0300 @@ -16,14 +16,14 @@ */ #include "cainstallnotifier.h" +#include "cainstallstrategy.h" EXPORT_C CCaInstallNotifier* CCaInstallNotifier::NewL( MCaInstallListener& aListener, TNotificationType aNotificationType ) { - CCaInstallNotifier* self = new ( ELeave ) CCaInstallNotifier( - aListener, aNotificationType ); + CCaInstallNotifier* self = new ( ELeave ) CCaInstallNotifier( aListener ); CleanupStack::PushL( self ); - self->ConstructL(); + self->ConstructL( aNotificationType ); CleanupStack::Pop( self ); return self; } @@ -32,21 +32,34 @@ { Cancel(); iProperty.Close(); + delete iNotifierStrategy; } -CCaInstallNotifier::CCaInstallNotifier( MCaInstallListener& aListener, - TNotificationType aNotificationType ) : +CCaInstallNotifier::CCaInstallNotifier( MCaInstallListener& aListener ) : CActive( EPriorityNormal ), iListener( aListener ) { - iRPropertyKey = aNotificationType; - iProperty.Attach( KUidSystemCategory, iRPropertyKey ); CActiveScheduler::Add( this ); - iProperty.Subscribe( iStatus ); SetActive(); } -void CCaInstallNotifier::ConstructL() +void CCaInstallNotifier::ConstructL( TNotificationType aNotificationType ) { + switch( aNotificationType ) + { + case ESisInstallNotification: + iNotifierStrategy = CCaSwiInstallStrategy::NewL( iProperty ); + break; + case EUsifUninstallNotification: + iNotifierStrategy = CCaUsifUninstallStrategy::NewL( iProperty ); + break; + case EJavaInstallNotification: + iNotifierStrategy = CCaJavaInstallStrategy::NewL( iProperty ); + break; + default: + User::Leave( KErrNotSupported ); + break; + } + iProperty.Subscribe( iStatus ); } void CCaInstallNotifier::DoCancel() @@ -58,13 +71,7 @@ { SetActive(); iProperty.Subscribe( iStatus ); - TInt appUid; - User::LeaveIfError( iProperty.Get( KUidSystemCategory, iRPropertyKey, - appUid ) ); - if( appUid ) - { - iListener.HandleInstallNotifyL( appUid ); - } + iNotifierStrategy->NotifyListenerL( iProperty, iListener ); } TInt CCaInstallNotifier::RunError( TInt /*aError*/) @@ -72,3 +79,4 @@ // No need to do anything return KErrNone; } + diff -r a6d55a2e75be -r 782e3408c2ab contentstorage/srvsrc/cainstallstrategy.cpp --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/contentstorage/srvsrc/cainstallstrategy.cpp Fri Apr 16 14:45:49 2010 +0300 @@ -0,0 +1,172 @@ +/* + * Copyright (c) 2008 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: ?Description + * + */ +#include +#include +#include +#include "cainstallstrategy.h" + +// --------------------------------------------------------------------------- +// +// --------------------------------------------------------------------------- +// +CCaSwiInstallStrategy* CCaSwiInstallStrategy::NewL( RProperty& aProperty ) + { + CCaSwiInstallStrategy* self = new ( ELeave ) CCaSwiInstallStrategy( + aProperty ); + CleanupStack::PushL( self ); + self->ConstructL(); + CleanupStack::Pop( self ); + return self; + } + +// --------------------------------------------------------------------------- +// +// --------------------------------------------------------------------------- +// +void CCaSwiInstallStrategy::NotifyListenerL( + RProperty& aProperty, MCaInstallListener& aListener ) + { + TInt appUid; + User::LeaveIfError( aProperty.Get( KUidSystemCategory, + KUidSwiLatestInstallation, appUid ) ); + if( appUid ) + { + aListener.HandleInstallNotifyL(appUid ); + } + } + +// --------------------------------------------------------------------------- +// +// --------------------------------------------------------------------------- +// +CCaSwiInstallStrategy::CCaSwiInstallStrategy( RProperty& aProperty ) + { + aProperty.Attach( KUidSystemCategory, KUidSwiLatestInstallation ); + } + +// --------------------------------------------------------------------------- +// +// --------------------------------------------------------------------------- +// +void CCaSwiInstallStrategy::ConstructL() + { + } + +// --------------------------------------------------------------------------- +// +// --------------------------------------------------------------------------- +// +CCaJavaInstallStrategy* CCaJavaInstallStrategy::NewL( RProperty& aProperty ) + { + CCaJavaInstallStrategy* self = + new ( ELeave ) CCaJavaInstallStrategy( aProperty ); + CleanupStack::PushL( self ); + self->ConstructL(); + CleanupStack::Pop( self ); + return self; + } + +// --------------------------------------------------------------------------- +// +// --------------------------------------------------------------------------- +// +void CCaJavaInstallStrategy::NotifyListenerL( + RProperty& aProperty, MCaInstallListener& aListener ) + { +//TODO: temporary sollution until new notification mechanism from usif in wk14 +// TInt state; +// User::LeaveIfError( aProperty.Get( KUidSystemCategory, +// KPSUidJavaLatestInstallationState, state ) ); +// if( ( ( state & ESASwisInstall ) || ( state & ESASwisUninstall ) ) +// && ( state & ESASwisStatusSuccess ) ) +// { + TInt appUid; + User::LeaveIfError( aProperty.Get( KUidSystemCategory, + KPSUidJavaLatestInstallation, appUid ) ); + aListener.HandleInstallNotifyL(appUid ); +// } + } + +// --------------------------------------------------------------------------- +// +// --------------------------------------------------------------------------- +// +CCaJavaInstallStrategy::CCaJavaInstallStrategy( RProperty& aProperty ) + { + aProperty.Attach( KUidSystemCategory, KPSUidJavaLatestInstallationState ); + } + +// --------------------------------------------------------------------------- +// +// --------------------------------------------------------------------------- +// +void CCaJavaInstallStrategy::ConstructL() + { + } + +// --------------------------------------------------------------------------- +// +// --------------------------------------------------------------------------- +// +CCaUsifUninstallStrategy* CCaUsifUninstallStrategy::NewL( + RProperty& aProperty ) + { + CCaUsifUninstallStrategy* self = + new ( ELeave ) CCaUsifUninstallStrategy( aProperty ); + CleanupStack::PushL( self ); + self->ConstructL(); + CleanupStack::Pop( self ); + return self; + } + +// --------------------------------------------------------------------------- +// +// --------------------------------------------------------------------------- +// +void CCaUsifUninstallStrategy::NotifyListenerL( + RProperty& aProperty, MCaInstallListener& aListener ) + { + TInt appUid; + User::LeaveIfError( aProperty.Get( KPSUidSWInstallerUiNotification, + KSWInstallerUninstallation, appUid ) ); + // if there is some value!=0 in iAppUid and appUid==0 that means + // application with uid==iAppUid was uninstalled, so we notify aListener + if( iAppUid && !appUid ) + { + aListener.HandleInstallNotifyL( iAppUid ); + } + iAppUid = appUid; + } + +// --------------------------------------------------------------------------- +// +// --------------------------------------------------------------------------- +// +CCaUsifUninstallStrategy::CCaUsifUninstallStrategy( RProperty& aProperty ) + { + aProperty.Attach( + KPSUidSWInstallerUiNotification, KSWInstallerUninstallation ); + } + +// --------------------------------------------------------------------------- +// +// --------------------------------------------------------------------------- +// +void CCaUsifUninstallStrategy::ConstructL() + { + } + diff -r a6d55a2e75be -r 782e3408c2ab contentstorage/srvsrc/cammcwatcher.cpp --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/contentstorage/srvsrc/cammcwatcher.cpp Fri Apr 16 14:45:49 2010 +0300 @@ -0,0 +1,133 @@ +/* +* Copyright (c) 2008 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 + +#include "cammcwatcher.h" + +// ================= MEMBER FUNCTIONS ======================= + +// --------------------------------------------------------- +// CCaWidgetMmcWatcher::NewL +// Second phase constructor +// --------------------------------------------------------- +// +EXPORT_C CCaMmcWatcher* CCaMmcWatcher::NewL( RFs& aFs, + MMmcWatcherCallback* aObserver ) + { + CCaMmcWatcher* self = NewLC( aFs, aObserver ); + CleanupStack::Pop( self ); + return self; + } + +// --------------------------------------------------------- +// CCaWidgetMmcWatcher::NewLC +// Second phase constructor +// --------------------------------------------------------- +// +EXPORT_C CCaMmcWatcher* CCaMmcWatcher::NewLC( RFs& aFs, + MMmcWatcherCallback* aObserver ) + { + CCaMmcWatcher* self = new (ELeave) CCaMmcWatcher( aFs, + aObserver ); + CleanupStack::PushL ( self ); + self->ConstructL(); + return self; + } + +// --------------------------------------------------------- +// CCaWidgetMmcWatcher::~CCaWidgetMmcWatcher +// Destructor +// --------------------------------------------------------- +// +CCaMmcWatcher::~CCaMmcWatcher() + { + Cancel(); + } + +// --------------------------------------------------------- +// CCaWidgetMmcWatcher::CCaWidgetMmcWatcher +// Default constructor +// --------------------------------------------------------- +// +CCaMmcWatcher::CCaMmcWatcher( RFs& aFs, + MMmcWatcherCallback* aObserver ) + : CActive( CActive::EPriorityStandard ), + iFs(aFs), + iObserver(aObserver) + { + CActiveScheduler::Add(this); + } + +// --------------------------------------------------------- +// CCaWidgetMmcWatcher::ConstructL +// default Symbian OS constructor +// --------------------------------------------------------- +// +void CCaMmcWatcher::ConstructL() + { + WaitForChangeL(); + } + +// --------------------------------------------------------- +// CCaWidgetMmcWatcher::WaitForChangeL +// Request notification for disk change +// --------------------------------------------------------- +// +void CCaMmcWatcher::WaitForChangeL() + { + TInt mmcDrive; + User::LeaveIfError( DriveInfo::GetDefaultDrive( + DriveInfo::EDefaultRemovableMassStorage, mmcDrive ) ); + TDriveName mmcDriveName( TDriveUnit( mmcDrive ).Name() ); + iFs.NotifyChange( ENotifyEntry, iStatus, mmcDriveName ); + SetActive(); + } + +// --------------------------------------------------------- +// CCaWidgetMmcWatcher::DoCancel +// --------------------------------------------------------- +// +void CCaMmcWatcher::DoCancel() + { + iFs.NotifyChangeCancel(); + } + +// --------------------------------------------------------------------------- +// CCaWidgetMmcWatcher::RunError +// --------------------------------------------------------------------------- +// +TInt CCaMmcWatcher::RunError( TInt /*aError*/ ) + { + // No need to do anything + return KErrNone; + } + +// --------------------------------------------------------- +// CCaWidgetMmcWatcher::RunL +// --------------------------------------------------------- +// +void CCaMmcWatcher::RunL() + { + TInt status( iStatus.Int() ); + WaitForChangeL(); + if ( status >= KErrNone ) + { + iObserver->MmcChangeL(); + } + } + diff -r a6d55a2e75be -r 782e3408c2ab contentstorage/srvsrc/casrvengutils.cpp --- a/contentstorage/srvsrc/casrvengutils.cpp Fri Mar 26 13:00:55 2010 +0200 +++ b/contentstorage/srvsrc/casrvengutils.cpp Fri Apr 16 14:45:49 2010 +0300 @@ -115,10 +115,10 @@ } // --------------------------------------------------------- -// CMenuSrvEngUtils::IsNative +// CMenuSrvEngUtils::IsNativeL // --------------------------------------------------------- // -TBool CCaSrvEngUtils::IsNative( const CCaInnerEntry& aEntry ) +TBool CCaSrvEngUtils::IsNativeL( const CCaInnerEntry& aEntry ) { TBool native( EFalse ); if( aEntry.GetEntryTypeName().CompareF( KCaTypeApp ) == KErrNone ) @@ -126,7 +126,7 @@ TUid uid; if( GetAppUid( aEntry, uid ) == KErrNone ) { - IsNative( uid, native ); + IsNativeL( uid, native ); } } return native; @@ -137,17 +137,18 @@ // --------------------------------------------------------- // -void CCaSrvEngUtils::IsNative( TUid aAppUid, TBool& aIsNative ) +void CCaSrvEngUtils::IsNativeL( TUid aAppUid, TBool& aIsNative ) { - TApaAppInfo appInfo; + TApaAppInfo* appInfo = new( ELeave ) TApaAppInfo(); aIsNative = EFalse; - TInt error = iApaLsSession.GetAppInfo( appInfo, aAppUid ); + TInt error = iApaLsSession.GetAppInfo( *appInfo, aAppUid ); if( error == KErrNone ) { - error = iApaLsSession.IsProgram( appInfo.iFullName, aIsNative ); + error = iApaLsSession.IsProgram( appInfo->iFullName, aIsNative ); if( error != KErrNone ) { aIsNative = EFalse; } } + delete appInfo; } diff -r a6d55a2e75be -r 782e3408c2ab group/bld.inf --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/group/bld.inf Fri Apr 16 14:45:49 2010 +0300 @@ -0,0 +1,27 @@ +/* +* Copyright (c) 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: Build information file for Content Publisher Storage +* +*/ + +#include + +PRJ_PLATFORMS +TOOLS2 + +PRJ_EXPORTS +skin_icon.prf /epoc32/tools/qt/mkspecs/features/symbian/skin_icon.prf + + + diff -r a6d55a2e75be -r 782e3408c2ab group/skin_icon.prf --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/group/skin_icon.prf Fri Apr 16 14:45:49 2010 +0300 @@ -0,0 +1,16 @@ + +!isEmpty(SKINICON) { + +!count(SKINICON, 1) { + SKINICON = $$first(SKINICON) + warning("Only first icon specified in SKINICON variable is used: $$SKINICON") +} +# use proper UID +RSS_RULES.header *= "$${LITERAL_HASH}include " +RSS_RULES.header += "$${LITERAL_HASH}define SKINSERVICE 0x2002DCF3" +RSS_RULES.service_list += "uid = SKINSERVICE; opaque_data = r_skin_icon; " +RSS_RULES.footer +="RESOURCE TBUF r_skin_icon \{ buf =\"$$SKINICON\"; \}" +} + + + diff -r a6d55a2e75be -r 782e3408c2ab homescreensrv.pro --- a/homescreensrv.pro Fri Mar 26 13:00:55 2010 +0200 +++ b/homescreensrv.pro Fri Apr 16 14:45:49 2010 +0300 @@ -22,9 +22,10 @@ contentpublishingsrv \ homescreensrv_plat \ screensavermodel \ - bagetmodel \ - activityfw \ tsrc +symbian:SUBDIRS += activityfw +symbian:SUBDIRS += hsappkeyhandler + CONFIG += ordered diff -r a6d55a2e75be -r 782e3408c2ab homescreensrv_plat/contentstorage_api/caitemmodel.h --- a/homescreensrv_plat/contentstorage_api/caitemmodel.h Fri Mar 26 13:00:55 2010 +0200 +++ b/homescreensrv_plat/contentstorage_api/caitemmodel.h Fri Apr 16 14:45:49 2010 +0300 @@ -47,8 +47,8 @@ ParentIdRole, TypeRole, FlagsRole, - TextRole//contains title represented as QString, - //convinient for operations such as search + TextRole,//contains title represented as QString, + FullTextRole //'title description' convinient for operations such as search }; // Function declarations @@ -75,7 +75,7 @@ void setParentId(int parentId); void setFlagsOn(const EntryFlags &onFlags); void setFlagsOff(const EntryFlags &offFlags); - CaEntry* entry(const QModelIndex &index) const; + QSharedPointer entry(const QModelIndex &index) const; signals: diff -r a6d55a2e75be -r 782e3408c2ab homescreensrv_plat/contentstorage_api/camenuiconutility.h --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/homescreensrv_plat/contentstorage_api/camenuiconutility.h Fri Apr 16 14:45:49 2010 +0300 @@ -0,0 +1,37 @@ +/* +* Copyright (c) 2008 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 API supports requesting raw bitmaps + * +*/ + + +#ifndef __CAMENUICONUTILITY_H__ +#define __CAMENUICONUTILITY_H__ + +#include "caclient_global.h" + +class CaEntry; +class HbIcon; + +class CACLIENT_EXPORT CaMenuIconUtility +{ +public: + static HbIcon getApplicationIcon(int uid, + const QSize &size = QSize(50,80)); + + static HbIcon getEntryIcon(const CaEntry& entry, + const QSize &size = QSize(50,80)); +}; + +#endif // __CAMENUICONUTILITY_H__ diff -r a6d55a2e75be -r 782e3408c2ab homescreensrv_plat/contentstorage_api/caservice.h --- a/homescreensrv_plat/contentstorage_api/caservice.h Fri Mar 26 13:00:55 2010 +0200 +++ b/homescreensrv_plat/contentstorage_api/caservice.h Fri Apr 16 14:45:49 2010 +0300 @@ -44,17 +44,17 @@ static QSharedPointer instance(); - CaEntry * getEntry(int entryId) const; - QList getEntries(const QList &entryIdList) const; - QList getEntries(const CaQuery &query) const; + QSharedPointer getEntry(int entryId) const; + QList< QSharedPointer > getEntries(const QList &entryIdList) const; + QList< QSharedPointer > getEntries(const CaQuery &query) const; QList getEntryIds(const CaQuery &query) const; - CaEntry *createEntry(const CaEntry &entry) const; + QSharedPointer createEntry(const CaEntry &entry) const; bool removeEntry(int entryId) const; bool removeEntry(const CaEntry &entry) const; bool removeEntries(const QList &entryIdList) const; - bool removeEntries(const QList &entryList) const; + bool removeEntries(const QList< QSharedPointer > &entryList) const; bool updateEntry(const CaEntry &entry) const; bool touch(const CaEntry &entry) const; @@ -66,7 +66,7 @@ bool insertEntriesIntoGroup(int groupId, const QList &entryIdList, int beforeEntryId) const; bool insertEntriesIntoGroup(const CaEntry &group, - const QList &entryList, int beforeEntryId) const; + const QList< QSharedPointer > &entryList, int beforeEntryId) const; bool removeEntryFromGroup(int groupId, int entryId) const; bool removeEntryFromGroup(const CaEntry &group, @@ -74,7 +74,7 @@ bool removeEntriesFromGroup(int groupId, const QList &entryIdList) const; bool removeEntriesFromGroup(const CaEntry &group, - const QList &entryList) const; + const QList< QSharedPointer > &entryList) const; bool appendEntryToGroup(int groupId, int entryId) const; bool appendEntryToGroup(const CaEntry &group, @@ -82,7 +82,7 @@ bool appendEntriesToGroup(int groupId, const QList &entryIdList) const; bool appendEntriesToGroup(const CaEntry &group, - const QList &entryList) const; + const QList< QSharedPointer > &entryList) const; bool prependEntryToGroup(int groupId, int entryId) const; bool prependEntryToGroup(const CaEntry &group, @@ -90,7 +90,7 @@ bool prependEntriesToGroup(int groupId, const QList &entryIdList) const; bool prependEntriesToGroup(const CaEntry &group, - const QList &entryList) const; + const QList< QSharedPointer > &entryList) const; bool executeCommand(int entryId, const QString &command = caCmdOpen) const; diff -r a6d55a2e75be -r 782e3408c2ab homescreensrv_plat/contentstorage_api/contentstorage_api.pri --- a/homescreensrv_plat/contentstorage_api/contentstorage_api.pri Fri Mar 26 13:00:55 2010 +0200 +++ b/homescreensrv_plat/contentstorage_api/contentstorage_api.pri Fri Apr 16 14:45:49 2010 +0300 @@ -23,4 +23,5 @@ contentstorage_api/canotifierfilter.h \ contentstorage_api/caquery.h \ contentstorage_api/caservice.h \ - contentstorage_api/caitemmodel.h \ No newline at end of file + contentstorage_api/caitemmodel.h \ + contentstorage_api/camenuiconutility.h \ No newline at end of file diff -r a6d55a2e75be -r 782e3408c2ab homescreensrv_plat/homescreensrv_plat.pro --- a/homescreensrv_plat/homescreensrv_plat.pro Fri Mar 26 13:00:55 2010 +0200 +++ b/homescreensrv_plat/homescreensrv_plat.pro Fri Apr 16 14:45:49 2010 +0300 @@ -20,7 +20,6 @@ include(appruntimemodel_api/appruntimemodel_api.pri) include(contentstorage_api/contentstorage_api.pri) include(hswidgetmodel_api/hswidgetmodel_api.pri) -include(servicemodel_api/servicemodel_api.pri) include(statemodel_api/statemodel_api.pri) include(menu_sat_interface_api/menu_sat_interface_api.pri) include(homescreen_information_api/homescreen_information_api.pri) diff -r a6d55a2e75be -r 782e3408c2ab homescreensrv_plat/sapi_actionhandler/actionhandlerplugins/src/ahpapplauncher.cpp --- a/homescreensrv_plat/sapi_actionhandler/actionhandlerplugins/src/ahpapplauncher.cpp Fri Mar 26 13:00:55 2010 +0200 +++ b/homescreensrv_plat/sapi_actionhandler/actionhandlerplugins/src/ahpapplauncher.cpp Fri Apr 16 14:45:49 2010 +0300 @@ -77,7 +77,7 @@ TInt errCode(KErrArgument); RBuf launchMethod; CleanupClosePushL( launchMethod ); - + if ( !ExtractDesL( aMap, launchMethod, KLaunchMethod ) ) { if ( !launchMethod.CompareF( KLaunchMethodValueCmdLine ) ) @@ -90,8 +90,8 @@ errCode = ExecuteApaMessageL( aMap ); } } - - CleanupStack::PopAndDestroy( &launchMethod ); + + CleanupStack::PopAndDestroy( &launchMethod ); return errCode; } @@ -133,19 +133,19 @@ // --------------------------------------------------------------------------- // Executes provided apa message action // --------------------------------------------------------------------------- -// +// TInt CAHAppLauncher::ExecuteApaMessageL( const CLiwMap* aMap ) { TInt errCode(KErrArgument); TUid appUid= TUid::Null( ); if ( !ExtractUidL( aMap, appUid, KApplicationUid ) ) { - TApaTaskList taskList( iEnv->WsSession() ); + TApaTaskList taskList( iEnv->WsSession() ); TApaTask task = taskList.FindApp( appUid ); if ( task.Exists( ) ) { TUid messageUid= TUid::Null( ); - + RBuf8 additionalData; CleanupClosePushL( additionalData ); if ( !ExtractUidL( aMap, messageUid, KMessageUid ) @@ -153,7 +153,7 @@ { errCode = task.SendMessage( messageUid, additionalData ); } - CleanupStack::PopAndDestroy( &additionalData ); + CleanupStack::PopAndDestroy( &additionalData ); } else { // app not yet running @@ -170,7 +170,7 @@ errCode = StartAppL( aMap ); } } - CleanupStack::PopAndDestroy( &launchMethod ); + CleanupStack::PopAndDestroy( &launchMethod ); } } return errCode; @@ -179,14 +179,14 @@ // --------------------------------------------------------------------------- // Start document // --------------------------------------------------------------------------- -// +// TInt CAHAppLauncher::StartDocumentL( const CLiwMap* aMap ) { TInt errCode(KErrArgument); TUid appUid= TUid::Null( ); RBuf documentNameValue; CleanupClosePushL( documentNameValue ); - if ( !ExtractUidL( aMap, appUid, KApplicationUid ) + if ( !ExtractUidL( aMap, appUid, KApplicationUid ) && !ExtractDesL( aMap, documentNameValue, KDocumentName ) ) { RApaLsSession appArcSession; @@ -202,7 +202,7 @@ // --------------------------------------------------------------------------- // Starts application // --------------------------------------------------------------------------- -// +// TInt CAHAppLauncher::StartAppL( const CLiwMap* aMap ) { TInt errCode(KErrArgument); @@ -294,7 +294,7 @@ } // --------------------------------------------------------------------------- -// +// // --------------------------------------------------------------------------- // TInt CAHAppLauncher::ExtractDesL( const CLiwMap* aMap, @@ -306,17 +306,23 @@ TPtrC tempString( KNullDesC ); if ( aMap->FindL( aMapName, variant ) ) { - variant.Get( tempString ); - aString.ReAllocL( tempString.Length( ) ); - aString.Append( tempString ); - errCode = KErrNone; + if ( variant.Get( tempString ) ) + { + aString.ReAllocL( tempString.Length( ) ); + aString.Append( tempString ); + errCode = KErrNone; + } + else + { + errCode = KErrCorrupt; + } } - CleanupStack::PopAndDestroy( &variant ); + CleanupStack::PopAndDestroy( &variant ); return errCode; } - + // --------------------------------------------------------------------------- -// +// // --------------------------------------------------------------------------- // TInt CAHAppLauncher::ExtractDes8L( const CLiwMap* aMap, @@ -328,17 +334,23 @@ TPtrC8 tempString( KNullDesC8 ); if ( aMap->FindL( aMapName, variant ) ) { - variant.Get( tempString ); - aString.ReAllocL( tempString.Length( ) ); - aString.Append( tempString ); - errCode = KErrNone; + if ( variant.Get( tempString ) ) + { + aString.ReAllocL( tempString.Length( ) ); + aString.Append( tempString ); + errCode = KErrNone; + } + else + { + errCode = KErrCorrupt; + } } - CleanupStack::PopAndDestroy( &variant ); + CleanupStack::PopAndDestroy( &variant ); return errCode; - } + } // --------------------------------------------------------------------------- -// +// // --------------------------------------------------------------------------- // TInt CAHAppLauncher::ExtractUidL( const CLiwMap* aMap, TUid& aUid, @@ -351,16 +363,22 @@ variant.PushL( ); if ( aMap->FindL( aMapName, variant ) ) { - variant.Get( temp ); - aUid = TUid::Uid( temp ); - errCode = KErrNone; + if ( variant.Get( temp ) ) + { + aUid = TUid::Uid( temp ); + errCode = KErrNone; + } + else + { + errCode = KErrCorrupt; + } } CleanupStack::PopAndDestroy( &variant ); return errCode; } // --------------------------------------------------------------------------- -// +// // --------------------------------------------------------------------------- // TInt CAHAppLauncher::ExtractViewIdL( const CLiwMap* aMap, TVwsViewId& aViewId ) @@ -370,13 +388,25 @@ TLiwVariant variant; if ( aMap->FindL( KViewId, variant ) ) { - variant.Get( aViewId.iViewUid.iUid ); - variant.Reset( ); - if ( aMap->FindL( KViewAppUid, variant ) ) + if ( variant.Get( aViewId.iViewUid.iUid ) ) { - variant.Get( aViewId.iAppUid.iUid ); variant.Reset( ); - errCode = KErrNone; + if ( aMap->FindL( KViewAppUid, variant ) ) + { + if ( variant.Get( aViewId.iAppUid.iUid ) ) + { + variant.Reset( ); + errCode = KErrNone; + } + else + { + errCode = KErrCorrupt; + } + } + } + else + { + errCode = KErrCorrupt; } } @@ -384,7 +414,7 @@ } // --------------------------------------------------------------------------- -// +// // --------------------------------------------------------------------------- // TApaCommand CAHAppLauncher::GetCommandL( const CLiwMap* aMap ) @@ -403,4 +433,4 @@ return command; } -// End of file +// End of file diff -r a6d55a2e75be -r 782e3408c2ab homescreensrv_plat/servicemodel_api/hsiserviceprovider.h --- a/homescreensrv_plat/servicemodel_api/hsiserviceprovider.h Fri Mar 26 13:00:55 2010 +0200 +++ /dev/null Thu Jan 01 00:00:00 1970 +0000 @@ -1,99 +0,0 @@ -/* -* 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: HsService provider interface. -* -*/ - - -#ifndef HSISERVICEPROVIDER_H -#define HSISERVICEPROVIDER_H - -#include -#include -#include - -/** - * @ingroup group_hsservicemodel group_service_api_candidates - * @brief Represents a home screen service that can be created. - * - * Home screen services are located in service providers. Each provider - * exposes its contained services as service tokens. A token has all - * the needed information for service selection and creation. - * - * @lib ?library - * @since S60 ?S60_version - */ -class HsServiceToken -{ - -public: - - /** - * The name of the library/plugin that contains the service. - */ - QString mLibrary; - - /** - * Uniquely identifies the service. - */ - QString mUri; - -}; - - -class IHsPlatformServiceAdapter; - -/** - * @ingroup group_hsservicemodel group_service_api_candidates - * @brief Defines a mechanism for retrieving a home screen service. - * - * Interface that defines a mechanism for retrieving a home screen - * service. Each home screen service provider implements this interface. - * - * @lib ?library - * @since S60 ?S60_version - */ -class IHsServiceProvider -{ - -public: - - /** - * Destructor. - * @since S60 ?S60_version. - */ - virtual ~IHsServiceProvider() {} - -public: - - /** - * Returns contained services as a list of service tokens. - * @since S60 ?S60_version. - * @return Contained services as tokens. - */ - virtual QList services() = 0; - - /** - * Creates and returns a service based on the given token. - * @since S60 ?S60_version. - * @param aToken Identifies the service to be created. - * @return The created service or null in failure cases. - */ - virtual IHsPlatformServiceAdapter* createService(const HsServiceToken& aToken) = 0; - -}; - -Q_DECLARE_INTERFACE(IHsServiceProvider, "com.nokia.homescreen.iserviceprovider/1.0") - -#endif diff -r a6d55a2e75be -r 782e3408c2ab homescreensrv_plat/servicemodel_api/iplatformserviceadapter.h --- a/homescreensrv_plat/servicemodel_api/iplatformserviceadapter.h Fri Mar 26 13:00:55 2010 +0200 +++ /dev/null Thu Jan 01 00:00:00 1970 +0000 @@ -1,65 +0,0 @@ -/* -* 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: -* -*/ - - -#ifndef IPLATFORMHSSERVICEMODEL_H -#define IPLATFORMHSSERVICEMODEL_H - -#include -#include "serviceinterfaceid.h" - -class IHsServiceBase; -class HsService; - -/** - * @ingroup group_hsservicemodel group_service_api_candidates - * @brief Pure virtual class to create requested service. - * All the service plugines need to implement this class. - * - */ -class IHsPlatformServiceAdapter -{ - -public: - - /** - * Destructor. - * @since S60 ?S60_version. - */ - virtual ~IHsPlatformServiceAdapter() {} - -public: - - /** - * - * @param aService for example 'HsService.Messaging' - * @param aInterface for example 'IMessaging' - * @since S60 ?S60_version. - * @return pointer to created service. NULL if service not found. - */ - virtual HsService* getService(const QString &aService, const QString &aInterface) = 0; - - /** - * @param aInterfaceId - * @since S60 ?S60_version. - * @return pointer to created service. NULL if service not found. - */ - virtual IHsServiceBase* getService(const HsServiceInterfaceId &aInterfaceId) = 0; - -}; - -#endif diff -r a6d55a2e75be -r 782e3408c2ab homescreensrv_plat/servicemodel_api/service.h --- a/homescreensrv_plat/servicemodel_api/service.h Fri Mar 26 13:00:55 2010 +0200 +++ /dev/null Thu Jan 01 00:00:00 1970 +0000 @@ -1,101 +0,0 @@ -/* -* 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: -* -*/ - - -#ifndef SERVICE_H -#define SERVICE_H - -#include "servicemodel_global.h" -#include -#include - -class ServiceParameters; - -/** - * @ingroup group_hsservicemodel group_service_api_candidates - * @brief Base class for all the services. - */ -class HSSERVICEMODEL_EXPORT HsService : public QObject -{ - Q_OBJECT - -public: - - /** - * Constructor - * @param aParent - */ - HsService( QObject* aParent = 0 ) : QObject( aParent ) {} - - /** - * destructor - * @since S60 ?S60_version. - */ - virtual ~HsService() {} - -public: - - /** - * Execute service command - * @param aCommand service command - * @param aInParameters parameters. - * For example messaging service - * needs to have at least the following pairs to send short message: - * 'MessageType' - 'SMS' - * 'To' - 'phone number here' - * 'BodyText' - 'this is text to be sent' - * So aInParameters should include QMap: - * @code - * QMap parameters; - * parameters["MessageType"]=QVariant(QString("SMS")); - * parameters["To"]=QVariant(QString("555555")); - * parameters["BodyText"]=QVariant(QString("this is bodytext")); - * QVariant inParameters; - * inParameters.setValue(parameters); - * @endcode - */ - virtual void executeCommand(const QByteArray &aCommand, const QVariant &aInParameters) = 0; - - /** - * Cancels ALL then pending commands. - */ - virtual void cancelCommands() = 0; - - /** - * Get data after dataReceived signal has been received. - * - * @param aData data buffer to be filled - * TODO: error? - */ - virtual void getData(QVariant &aData) = 0; - -signals: - - /** - * Signal emitted when data is received, client can then make query for the received data using getData function. - */ - void dataReceived(); - - /** - * Signal emitted when data is received - * @param aData (QMap) data received from the service - */ - void dataReceived(const QVariant &aData); - -}; - -#endif diff -r a6d55a2e75be -r 782e3408c2ab homescreensrv_plat/servicemodel_api/servicebase.h --- a/homescreensrv_plat/servicemodel_api/servicebase.h Fri Mar 26 13:00:55 2010 +0200 +++ /dev/null Thu Jan 01 00:00:00 1970 +0000 @@ -1,69 +0,0 @@ -/* -* 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: HsService base -* -*/ - - -#ifndef SERVICEBASE_H -#define SERVICEBASE_H - -struct HsServiceInterfaceId; - -/** @ingroup group_hsservicemodel group_service_api_candidates - * The base class for service interfaces - * - * @lib - * @since S60 ?S60_version - */ -class IHsServiceBase - { - -public: - /** - * Default virtual destructor. - */ - virtual ~IHsServiceBase() {} - - /** - * Interface getter with casting. - * - * @since S60 ?S60_version - * @param aBase HsService base object. - * @return The queried interface, or NULL if the interface is not - * supported or available. - */ - template - static T* MakeInterface(IHsServiceBase* aBase) - { - return (aBase? static_cast(aBase->resolveService(T::type())): 0); - } - - - /** - * Interface getter. - * Derived classes should always call the base class method - * from the overridden MakeInterface. - * - * @since S60 ?S60_version - * @param aType The type id of the queried interface. - * @return The queried interface, or NULL if the interface is not - * supported or available. - */ - virtual IHsServiceBase* resolveService( const HsServiceInterfaceId &aType ) = 0; - - - }; - -#endif diff -r a6d55a2e75be -r 782e3408c2ab homescreensrv_plat/servicemodel_api/servicefinder.h --- a/homescreensrv_plat/servicemodel_api/servicefinder.h Fri Mar 26 13:00:55 2010 +0200 +++ /dev/null Thu Jan 01 00:00:00 1970 +0000 @@ -1,216 +0,0 @@ -/* -* 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: HsService Finder -* -*/ - - -#ifndef SERVICEFINDER_H -#define SERVICEFINDER_H - -#include -#include "serviceinterfaceid.h" -#include "hsiserviceprovider.h" -#include "servicemodel_global.h" - -class IHsServiceBase; -class HsServiceFinderPrivate; -class HsService; - -/** - * @ingroup group_hsservicemodel group_service_api_candidates - * @brief Helper class to search and create services. - * HsService adapter is the component to find different platform service implementations - * and offer interface to use services. - */ -class HSSERVICEMODEL_EXPORT HsServiceFinder : public QObject -{ - Q_OBJECT - -public: - - /** - * Constructor. - * @since S60 ?S60_version. - * @param aPluginManifestDirectory Directory that contains plugin manifests. - * @param aPluginDirectory Directory that contains plugin binaries. - * @param aParent Parent object. - */ - HsServiceFinder(const QString& aPluginManifestDirectory, - const QString& aPluginDirectory, - QObject* aParent = 0); - - - /** - * Destructor - */ - virtual ~HsServiceFinder(); - -public: - - /** - * Get list of all services in the device implemented according the service architecture. - * @return list of services (empty list if no services in the device). - */ - QList getServiceList(); - - /** - * Get list of all services in the device implemented according the service architecture. - * @param aService for example 'BackupService' - * @return list of matched services (empty list if no services in the device). - * @code - * if (!mServiceFinder) - * { - * mServiceFinder = new HsServiceFinder("c:/hsplugins","c:/hsplugins",this); - * } - * IBackupService* service = 0; - * QList serviceList = mServiceFinder->getServiceList(IBackupService::type().mImplementationId ); - * if ( serviceList.count() ) - * { - * // use first found service - * service = mServiceFinder->getService(IBackupService::type(), serviceList.at(0)); - * } - * - * @endcode - */ - QList getServiceList(const QString &aService); - - /** - * Get service. This method returns the service as a QObject. - * @param aService for example 'HsService.Messaging' - * @param aInterface for example 'IMessaging' - * @return pointer to HsService object. Ownership is NOT transferred to caller. - * @see releaseService - * @code - * if (!mServiceFinder) - * { - * mServiceFinder = new HsServiceFinder("c:/hsplugins","c:/hsplugins",this); - * } - * HsService* servicePtr = mServiceFinder->getService("HsService.Messaging", "IMessaging"); - * @endcode - */ - HsService *getService(const QString &aService, const QString &aInterface); - - /** - * Get service. This method returns the service as an abstract interface. - * @param aInterfaceId service interface identifier - * @param aPluginName which plugin implements this service, if empty, then first found interface is used. - * @return pointer to service interface object. Ownership is NOT transferred to caller. - * - * Example in source code: - * @code - * if (!mServiceFinder) - * { - * mServiceFinder = new HsServiceFinder("c:/hsplugins","c:/hsplugins",this); - * } - * IBackupService* service = 0; - * service = mServiceFinder->getService(IBackupService::type(), "backupservice"); - * if ( service ) - * { - * service->backupPage(); - * } - * @endcode - * where IBackupService is defined in header file: - * @code - * static const HsServiceInterfaceId Identifier= - * { - * 0,"persistanceservice" - * }; - * - * class IBackupService: public IHsServiceBase - * { - * public: - * static inline const HsServiceInterfaceId& type() - * { - * return Identifier; - * } - * public: - * virtual void backupPage() = 0; - * virtual IHsServiceBase* resolveService(const HsServiceInterfaceId& aType) = 0; - * ... other possible API functions - * @endcode - * @see more details in example backupservice implementation, IBackupService, PersistanceService... - */ - template T *getService(const HsServiceInterfaceId &aInterfaceId, const QString &aPluginName) - { - return static_cast(getService(aInterfaceId, aPluginName)); - } - - /** - * Get service. This method returns the service as an abstract interface. - * @param aInterfaceId service interface identifier - * @param aToken which plugin implements this service - * @return pointer to service interface object. Ownership is NOT transferred to caller. - * - * @code - * if (!mServiceFinder) - * { - * mServiceFinder = new HsServiceFinder("c:/hsplugins","c:/hsplugins",this); - * } - * IBackupService* service = 0; - * QList serviceList = mServiceFinder->getServiceList(IBackupService::type().mImplementationId); - * if ( serviceList.count() ) - * { - * // use first found service - * service = mServiceFinder->getService(IBackupService::type(), serviceList.at(0)); - * } - * if ( service ) - * { - * service->backupPage(); - * } - * @endcode - */ - template T *getService(const HsServiceInterfaceId &aInterfaceId, const HsServiceToken &aToken) - { - return static_cast(getService(aInterfaceId, aToken)); - } - - /** - * Get service. This method returns the service as an Base interface of the all services. - * @param aInterfaceId service interface identifier - * @param aPluginName which plugin implements this service - * @return pointer to service interface object. Ownership is NOT transferred to caller. - */ - IHsServiceBase *getService(const HsServiceInterfaceId &aInterfaceId, const QString &aPluginName); - - /** - * Get service. This method returns the service as an Base interface of the all services. - * @param aInterfaceId service interface identifier - * @param aToken which plugin implements this service - * @return pointer to service interface object. Ownership is NOT transferred to caller. - */ - IHsServiceBase *getService(const HsServiceInterfaceId &aInterfaceId, const HsServiceToken &aToken); - - /** - * Release service - * @param aService service to be released and deleted. HsService is QObject based service. - */ - void releaseService(HsService *aService); - - /** - * Cancels asynchronous service requests. - * @param aService QObject based service. - */ - void cancel(HsService *aService); - -private: - - /** - * The private implementation. - */ - HsServiceFinderPrivate *mServiceFinderPrivate; - -}; - -#endif diff -r a6d55a2e75be -r 782e3408c2ab homescreensrv_plat/servicemodel_api/serviceinterfaceid.h --- a/homescreensrv_plat/servicemodel_api/serviceinterfaceid.h Fri Mar 26 13:00:55 2010 +0200 +++ /dev/null Thu Jan 01 00:00:00 1970 +0000 @@ -1,46 +0,0 @@ -/* -* 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: -* -*/ - - -#ifndef SERVICEINTERFACEID_H -#define SERVICEINTERFACEID_H - -#include - -/** - * @ingroup group_hsservicemodel group_service_api_candidates - * @brief Interface id - * - * @lib servicemodel.lib - * - * @since S60 ?S60_version - * - */ -struct HsServiceInterfaceId -{ - /** - * Interface id. - */ - unsigned int mInterfaceId; - - /** - * Implementation id. - */ - QString mImplementationId; -}; - -#endif diff -r a6d55a2e75be -r 782e3408c2ab homescreensrv_plat/servicemodel_api/servicemodel_api.pri --- a/homescreensrv_plat/servicemodel_api/servicemodel_api.pri Fri Mar 26 13:00:55 2010 +0200 +++ /dev/null Thu Jan 01 00:00:00 1970 +0000 @@ -1,24 +0,0 @@ -# -# 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: -# - -PLATFORM_HEADERS += \ - servicemodel_api/hsiserviceprovider.h \ - servicemodel_api/iplatformserviceadapter.h \ - servicemodel_api/service.h \ - servicemodel_api/servicebase.h \ - servicemodel_api/servicefinder.h \ - servicemodel_api/serviceinterfaceid.h \ - servicemodel_api/servicemodel_global.h \ No newline at end of file diff -r a6d55a2e75be -r 782e3408c2ab homescreensrv_plat/servicemodel_api/servicemodel_global.h --- a/homescreensrv_plat/servicemodel_api/servicemodel_global.h Fri Mar 26 13:00:55 2010 +0200 +++ /dev/null Thu Jan 01 00:00:00 1970 +0000 @@ -1,37 +0,0 @@ -/* -* 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 dll header file. -* -*/ - - -#ifndef HSSERVICEMODEL_GLOBAL_H -#define HSSERVICEMODEL_GLOBAL_H - -#include - - -#ifdef HSSERVICEMODEL_LIB - #define HSSERVICEMODEL_EXPORT Q_DECL_EXPORT -#else - #ifdef HSSERVICEMODEL_TEST - #define HSSERVICEMODEL_EXPORT - #else - #define HSSERVICEMODEL_EXPORT Q_DECL_IMPORT - #endif - -#endif - - -#endif diff -r a6d55a2e75be -r 782e3408c2ab hsappkeyhandler/data/hsappkeyplugin.rss --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/hsappkeyhandler/data/hsappkeyplugin.rss Fri Apr 16 14:45:49 2010 +0300 @@ -0,0 +1,46 @@ +/* +* 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: +* +*/ + +#include +#include "../inc/hsappkeyhandleruids.hrh" + +RESOURCE REGISTRY_INFO theInfo + { + resource_format_version = RESOURCE_FORMAT_VERSION_2; + dll_uid = KUIDAPPKEYPLUGINDLL; + interfaces = + { + INTERFACE_INFO + { + interface_uid = 0x10207131; // from sysapkeyhandlerplugininterface.h + implementations = + { + IMPLEMENTATION_INFO + { + implementation_uid = KUIDAPPKEYPLUGINIMPL1; + version_no = 2; + display_name = "AppkeyPlugin"; + default_data = ""; + opaque_data = "ResidentPlugin"; + rom_only = 1; + } + }; + } + }; + } + +// End of file diff -r a6d55a2e75be -r 782e3408c2ab hsappkeyhandler/group/bld.inf --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/hsappkeyhandler/group/bld.inf Fri Apr 16 14:45:49 2010 +0300 @@ -0,0 +1,35 @@ +/* +* Copyright (c) 2006 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: +* Provides the information required for building the ES System App +* +*/ + + +#include + +PRJ_PLATFORMS +DEFAULT + +PRJ_EXPORTS + +// ROM files +../rom/hsappkeyhandler.iby CORE_MW_LAYER_IBY_EXPORT_PATH(hsappkeyhandler.iby) +../sis/stubs/hsappkeyplugin_stub.sis /epoc32/release/winscw/udeb/z/system/install/hsappkeyplugin_stub.sis +../sis/stubs/hsappkeyplugin_stub.sis /epoc32/data/z/system/install/hsappkeyplugin_stub.sis + +PRJ_MMPFILES +hsappkeyplugin.mmp + +PRJ_TESTMMPFILES diff -r a6d55a2e75be -r 782e3408c2ab hsappkeyhandler/group/hsappkeyplugin.mmp --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/hsappkeyhandler/group/hsappkeyplugin.mmp Fri Apr 16 14:45:49 2010 +0300 @@ -0,0 +1,50 @@ +/* +* 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 +#include +#include "../inc/hsappkeyhandleruids.hrh" + +TARGET hsappkeyplugin.dll +TARGETTYPE PLUGIN +CAPABILITY CAP_ECOM_PLUGIN +VENDORID VID_DEFAULT +UID 0x10009D8D KUIDAPPKEYPLUGINDLL + +START RESOURCE ../data/hsappkeyplugin.rss +TARGET hsappkeyplugin.rsc +END + +SOURCEPATH ../src +SOURCE hsappkeyplugin.cpp +SOURCE hsappkeypluginproxy.cpp + +USERINCLUDE ../inc + +APP_LAYER_SYSTEMINCLUDE + + +LIBRARY ecom.lib +LIBRARY euser.lib +LIBRARY eikcore.lib +LIBRARY eiksrv.lib +LIBRARY cone.lib +LIBRARY ws32.lib +LIBRARY HbCore.lib +LIBRARY apparc.lib +LIBRARY apgrfx.lib +DEBUGLIBRARY flogger.lib +// End of file diff -r a6d55a2e75be -r 782e3408c2ab hsappkeyhandler/hsappkeyhandler.pro --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/hsappkeyhandler/hsappkeyhandler.pro Fri Apr 16 14:45:49 2010 +0300 @@ -0,0 +1,20 @@ +# +# 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: +# + +TEMPLATE = subdirs + +BLD_INF_RULES.prj_exports += "$${LITERAL_HASH}include \"group/bld.inf\"" + diff -r a6d55a2e75be -r 782e3408c2ab hsappkeyhandler/inc/hsappkeyhandleruids.hrh --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/hsappkeyhandler/inc/hsappkeyhandleruids.hrh Fri Apr 16 14:45:49 2010 +0300 @@ -0,0 +1,28 @@ +/* +* Copyright (c) 2007-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: + * +*/ + + +#ifndef HSAPPKEYPLUGINUIDS_HRH +#define HSAPPKEYPLUGINUIDS_HRH + +#define KUIDAPPKEYPLUGINDLL 0x20026780 +#define KUIDAPPKEYPLUGINIMPL1 0x20026781 + +#endif // HSAPPKEYPLUGINUIDS_HRH + +// End of File + diff -r a6d55a2e75be -r 782e3408c2ab hsappkeyhandler/inc/hsappkeyplugin.h --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/hsappkeyhandler/inc/hsappkeyplugin.h Fri Apr 16 14:45:49 2010 +0300 @@ -0,0 +1,100 @@ +/* +* Copyright (c) 2007-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: Main plugin class + * +*/ + + +#ifndef HSAPPKEYPLUGIN_H +#define HSAPPKEYPLUGIN_H + +#include +#include + +class CEikonEnv; +class CHbDeviceDialogSymbian; + +/** +* CAppKeyPlugin +* An implementation of the CSysapKeyHandlerPlugin definition. The plugin handles EKeyXXX events. +* This is concrete class, instance of which +* ECOM framework gives to ECOM clients. +* @lib CAppKeyPlugin +* @since Series 60 version 3.1 +*/ +class CHsAppKeyPlugin : public CSysapKeyHandlerPlugin, + public MHbDeviceDialogObserver + { + public: // Constructors and destructor + /** + * Two-phased constructor. + */ + static CHsAppKeyPlugin* NewL(); + + /** + * Destructor. + */ + virtual ~CHsAppKeyPlugin(); + public: //MHbDeviceDialogObserver interfaces + void DataReceived(CHbSymbianVariantMap& aData); + + void DeviceDialogClosed(TInt aCompletionCode); + + public: // New functions + /** + * HandleKeyEventL + * @since Series 60 Series60_version 3.0 + * @param const TKeyEvent& aKeyEvent, TEventCode aType + * @return TKeyResponse If key was consumed. Generally it should be, since the KEF calls the plugins only with the right key. + */ + virtual TKeyResponse HandleKeyEventL( const TKeyEvent& aKeyEvent, + TEventCode aType ); + + /** + * Provides the key events that the plugin wants to listen to. + * Plugins should overload this method if they are of version 2 or higher. + * iCode, iScanCode and iModifiers MUST be defined in each TKeyEvent. + * + * @since S60 5.1 + * @return array of key events + */ + void ProvideKeyEventsL( RArray& aKeyEventArray ); + private: // Constructors + /** + * C++ default constructor. + */ + CHsAppKeyPlugin(); + + /** + * By default Symbian 2nd phase constructor is private. + */ + void ConstructL(); + + void HandleShortPressL(); + + void HandleLongPressL(); + + private: //data + /** Cached pointer to the CEikonEnv singelton instance */ + CEikonEnv* iEikEnv; + TBool iSecondEvent; + CHbDeviceDialogSymbian* mDialog; + }; + +#endif // HSAPPKEYPLUGIN_H + +// End of File + + + diff -r a6d55a2e75be -r 782e3408c2ab hsappkeyhandler/rom/hsappkeyhandler.iby --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/hsappkeyhandler/rom/hsappkeyhandler.iby Fri Apr 16 14:45:49 2010 +0300 @@ -0,0 +1,24 @@ +/* +* 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: +* +*/ +#ifndef __HSAPPKEYPLUGIN_IBY__ +#define __HSAPPKEYPLUGIN_IBY__ + +ECOM_PLUGIN( hsappkeyplugin.dll, hsappkeyplugin.rsc ) +// stub sis +data=ZSYSTEM/install/hsappkeyplugin_stub.sis system/install/hsappkeyplugin_stub.sis + +#endif // __HSAPPKEYPLUGIN_IBY__ diff -r a6d55a2e75be -r 782e3408c2ab hsappkeyhandler/sis/hsappkeyplugin.pkg --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/hsappkeyhandler/sis/hsappkeyplugin.pkg Fri Apr 16 14:45:49 2010 +0300 @@ -0,0 +1,29 @@ +; +; 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: +; + +;Language - standard language definitions +&EN + +; standard SIS file header +#{"hsappkeyplugin"},(0x20026780),1,0,0,TYPE=SA, RU + +;Localized Vendor Name +%{"Nokia"} + +;Unique Vendor name +:"Nokia" +"/epoc32/release/armv5/urel/hsappkeyplugin.dll"-"!:\sys\bin\hsappkeyplugin.dll" +"/epoc32/data/z/resource/plugins/hsappkeyplugin.rsc"-"!:\resource\plugins\hsappkeyplugin.rsc" diff -r a6d55a2e75be -r 782e3408c2ab hsappkeyhandler/sis/stubs/createstubs.bat --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/hsappkeyhandler/sis/stubs/createstubs.bat Fri Apr 16 14:45:49 2010 +0300 @@ -0,0 +1,17 @@ +@rem +@rem Copyright (c) 2009 Nokia Corporation and/or its subsidiary(-ies). +@rem All rights reserved. +@rem This component and the accompanying materials are made available +@rem under the terms of "Eclipse Public License v1.0" +@rem which accompanies this distribution, and is available +@rem at the URL "http://www.eclipse.org/legal/epl-v10.html". +@rem +@rem Initial Contributors: +@rem Nokia Corporation - initial contribution. +@rem +@rem Contributors: +@rem +@rem Description: +@rem + +for %%f in (*.pkg) do makesis -s %%f diff -r a6d55a2e75be -r 782e3408c2ab hsappkeyhandler/sis/stubs/hsappkeyplugin_stub.pkg --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/hsappkeyhandler/sis/stubs/hsappkeyplugin_stub.pkg Fri Apr 16 14:45:49 2010 +0300 @@ -0,0 +1,37 @@ +; +; 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: +; +; ------------------------------------------------------------------------------ +; Taskswitcher stub SIS package file. +; Used to enable Taskswitcher to be updated from ROM with a SIS package. +; When you add new files into this stub, please remember to update +; SIS stub with "makesis -s" command. +; ------------------------------------------------------------------------------ +; +;Language - standard language definitions +&EN + +; standard SIS file header +#{"hsappkeyplugin"},(0x20026780),1,0,0,TYPE=SA + +;Localized Vendor Name +%{"Nokia"} + +;Unique Vendor name +:"Nokia" + +""-"Z:\sys\bin\hsappkeyplugin.dll" +""-"Z:\resource\plugins\hsappkeyplugin.rsc" + diff -r a6d55a2e75be -r 782e3408c2ab hsappkeyhandler/sis/stubs/hsappkeyplugin_stub.sis Binary file hsappkeyhandler/sis/stubs/hsappkeyplugin_stub.sis has changed diff -r a6d55a2e75be -r 782e3408c2ab hsappkeyhandler/src/hsappkeyplugin.cpp --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/hsappkeyhandler/src/hsappkeyplugin.cpp Fri Apr 16 14:45:49 2010 +0300 @@ -0,0 +1,175 @@ +/* +* Copyright (c) 2007-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: Main plugin class + * +*/ + + +#include +#include +#include +#include +#include +#include +#include "hsappkeyplugin.h" + +const TUid KHSAppUid = { 0x20022F35 }; +_LIT(KTsPluginName, "com.nokia.taskswitcher.tsdevicedialogplugin/1.0"); + + +// ======== MEMBER FUNCTIONS ======== + +// --------------------------------------------------------------------------- +// +// --------------------------------------------------------------------------- +// +CHsAppKeyPlugin::CHsAppKeyPlugin() +: iEikEnv( CEikonEnv::Static() ) +{ +} + +// --------------------------------------------------------------------------- +// Two-phased constructor. +// --------------------------------------------------------------------------- +// +CHsAppKeyPlugin* CHsAppKeyPlugin::NewL() +{ + CHsAppKeyPlugin* self = new (ELeave) CHsAppKeyPlugin; + self->iEikEnv->RootWin().CaptureLongKey(EKeyApplication0, + EKeyApplication0, + 0, + 0, + 0, + ELongCaptureWaitShort); + return self; +} + +// --------------------------------------------------------------------------- +// C++ Destructor +// --------------------------------------------------------------------------- +// +CHsAppKeyPlugin::~CHsAppKeyPlugin() +{ + delete mDialog; +} + +// --------------------------------------------------------------------------- +// From MHbDeviceDialogObserver +// +// --------------------------------------------------------------------------- +// +void CHsAppKeyPlugin::DataReceived(CHbSymbianVariantMap& /*aData*/) +{ + //no implementation required +} + +// --------------------------------------------------------------------------- +// From MHbDeviceDialogObserver +// +// --------------------------------------------------------------------------- +// +void CHsAppKeyPlugin::DeviceDialogClosed(TInt /*aCompletionCode*/) +{ + delete mDialog; + mDialog = 0; +} + +// --------------------------------------------------------------------------- +// From CSysapKeyHandlerPlugin +// +// --------------------------------------------------------------------------- +// +TKeyResponse CHsAppKeyPlugin::HandleKeyEventL( const TKeyEvent& aKeyEvent , + TEventCode /*aType*/ + ) +{ + TKeyResponse retVal(EKeyWasNotConsumed); + if (aKeyEvent.iCode == EKeyApplication0) { + if (iSecondEvent) { + if (aKeyEvent.iRepeats > 0) + HandleLongPressL(); + else + HandleShortPressL(); + retVal = EKeyWasConsumed; + } + iSecondEvent =!iSecondEvent; + } + return retVal; +} + +// --------------------------------------------------------------------------- +// From CSysapKeyHandlerPlugin +// +// --------------------------------------------------------------------------- +// +void CHsAppKeyPlugin::ProvideKeyEventsL(RArray& aKeyEventArray) +{ + TKeyEvent key; + key.iCode = EKeyApplication0; + key.iScanCode = EStdKeyApplication0; + key.iModifiers = 0; + aKeyEventArray.Append(key); +} + +// --------------------------------------------------------------------------- +// +// --------------------------------------------------------------------------- +// +void CHsAppKeyPlugin::HandleShortPressL() +{ + RWsSession& ws = iEikEnv->WsSession(); + TApaTaskList appList(ws); + TApaTask task = appList.FindApp(KHSAppUid); + + if (task.Exists()) { + task.BringToForeground(); + } else { + RApaLsSession apaLsSession; + User::LeaveIfError(apaLsSession.Connect()); + CleanupClosePushL(apaLsSession); + + TApaAppInfo appInfo; + apaLsSession.GetAppInfo(appInfo, KHSAppUid ); + + CApaCommandLine *cmdLine = CApaCommandLine::NewLC(); + cmdLine->SetExecutableNameL(appInfo.iFullName); + User::LeaveIfError( apaLsSession.StartApp(*cmdLine)); + + CleanupStack::PopAndDestroy(cmdLine); + CleanupStack::PopAndDestroy(&apaLsSession); + } + delete mDialog; + mDialog =0; +} + +// --------------------------------------------------------------------------- +// +// --------------------------------------------------------------------------- +// +void CHsAppKeyPlugin::HandleLongPressL() +{ + if( !mDialog ) { + mDialog = CHbDeviceDialogSymbian ::NewL(); + + CHbSymbianVariantMap* params = CHbSymbianVariantMap::NewL(); + + if(KErrNone != mDialog->Show(KTsPluginName,*params,this)) { + delete mDialog; + } + delete params; + } +} +// End of File + + diff -r a6d55a2e75be -r 782e3408c2ab hsappkeyhandler/src/hsappkeypluginproxy.cpp --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/hsappkeyhandler/src/hsappkeypluginproxy.cpp Fri Apr 16 14:45:49 2010 +0300 @@ -0,0 +1,39 @@ +/* +* Copyright (c) 2007-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: ECOM implementation table + * +*/ + +#include +#include +#include +#include +#include "hsappkeyhandleruids.hrh" +#include "hsappkeyplugin.h" + +const TImplementationProxy AppkeyPluginImplementationTable[] = + { + IMPLEMENTATION_PROXY_ENTRY(KUIDAPPKEYPLUGINIMPL1, CHsAppKeyPlugin::NewL) + }; + +// --------------------------------------------------------------------------- +// +// --------------------------------------------------------------------------- +// +EXPORT_C const TImplementationProxy* ImplementationGroupProxy(TInt& aTableCount) + { + aTableCount = sizeof(AppkeyPluginImplementationTable) / sizeof(TImplementationProxy); + + return AppkeyPluginImplementationTable; + } diff -r a6d55a2e75be -r 782e3408c2ab layers.sysdef.xml --- a/layers.sysdef.xml Fri Mar 26 13:00:55 2010 +0200 +++ b/layers.sysdef.xml Fri Apr 16 14:45:49 2010 +0300 @@ -6,6 +6,12 @@ + + + + + + diff -r a6d55a2e75be -r 782e3408c2ab rom/homescreensrv_core.iby --- a/rom/homescreensrv_core.iby Fri Mar 26 13:00:55 2010 +0200 +++ b/rom/homescreensrv_core.iby Fri Apr 16 14:45:49 2010 +0300 @@ -22,12 +22,22 @@ //////////////////////////////////////// // ---- contentstorage -------------------------------------------- +file=ABI_DIR\BUILD_DIR\caapphandlerplugin.dll SHARED_LIB_DIR\caapphandlerplugin.dll +data=\epoc32\data\z\hsresources\plugins\commandhandler\caapphandlerplugin.qtplugin hsresources\plugins\commandhandler\caapphandlerplugin.qtplugin +data=\epoc32\data\z\hsresources\plugins\commandhandler\caapphandlerplugin.xml hsresources\plugins\commandhandler\caapphandlerplugin.xml + +file=ABI_DIR\BUILD_DIR\catapphandlerplugin.dll SHARED_LIB_DIR\catapphandlerplugin.dll +data=\epoc32\data\z\hsresources\plugins\commandhandler\catapphandlerplugin.qtplugin hsresources\plugins\commandhandler\catapphandlerplugin.qtplugin +data=\epoc32\data\z\hsresources\plugins\commandhandler\catapphandlerplugin.xml hsresources\plugins\commandhandler\catapphandlerplugin.xml + +file=ABI_DIR\BUILD_DIR\caurlhandlerplugin.dll SHARED_LIB_DIR\caurlhandlerplugin.dll +data=\epoc32\data\z\hsresources\plugins\commandhandler\caurlhandlerplugin.qtplugin hsresources\plugins\commandhandler\caurlhandlerplugin.qtplugin +data=\epoc32\data\z\hsresources\plugins\commandhandler\caurlhandlerplugin.xml hsresources\plugins\commandhandler\caurlhandlerplugin.xml file=ABI_DIR\BUILD_DIR\caclient.dll SHARED_LIB_DIR\caclient.dll file=ABI_DIR\BUILD_DIR\cautils.dll SHARED_LIB_DIR\cautils.dll file=ABI_DIR\BUILD_DIR\camenu.dll SHARED_LIB_DIR\camenu.dll file=ABI_DIR\BUILD_DIR\camenuserver.exe PROGRAMS_DIR\camenuserver.exe -file=ABI_DIR\BUILD_DIR\caextendedmenu.dll SHARED_LIB_DIR\caextendedmenu.dll file=ABI_DIR\BUILD_DIR\casathandler.dll SHARED_LIB_DIR\casathandler.dll file=ABI_DIR\BUILD_DIR\castorage.dll SHARED_LIB_DIR\castorage.dll file=ABI_DIR\BUILD_DIR\MenuInterface.dll SHARED_LIB_DIR\MenuInterface.dll @@ -37,14 +47,12 @@ ECOM_PLUGIN( cawidgetscanner.dll, cawidgetscanner.rsc ) ECOM_PLUGIN( calocalizerscanner.dll, calocalizerscanner.rsc ) ECOM_PLUGIN( carunningappmonitor.dll, carunningappmonitor.rsc ) +ECOM_PLUGIN( causifscanner.dll, causifscanner.rsc ) data=ZPRIVATE\20022F90\castorage.db private\20022F90\castorage.db // ---- appfoundation -------------------------------------------- -// -------- servicemodel -file=ABI_DIR\BUILD_DIR\hsservicemodel.dll SHARED_LIB_DIR\hsservicemodel.dll - // -------- statemodel file=ABI_DIR\BUILD_DIR\statemodel.dll SHARED_LIB_DIR\statemodel.dll @@ -57,9 +65,6 @@ // ---- screensavermodel -------------------------------------------- file=ABI_DIR\BUILD_DIR\screensavermodel.dll SHARED_LIB_DIR\screensavermodel.dll -// ---- bagetmodel -------------------------------------------- -file=ABI_DIR\BUILD_DIR\bagetmodel.dll SHARED_LIB_DIR\bagetmodel.dll - // ---- homescreen_information_api -------------------------------------------- data=\epoc32\data\c\resource\qt\crml\homescreeninformation.qcrml resource\qt\crml\homescreeninformation.qcrml #endif // __HOMESCREENSRV_CORE_IBY__ diff -r a6d55a2e75be -r 782e3408c2ab sis/homescreensrv.pkg --- a/sis/homescreensrv.pkg Fri Mar 26 13:00:55 2010 +0200 +++ b/sis/homescreensrv.pkg Fri Apr 16 14:45:49 2010 +0300 @@ -130,6 +130,8 @@ "/epoc32/data/z/resource/plugins/cawidgetscanner.rsc"-"c:/resource/plugins/cawidgetscanner.rsc" "/epoc32/release/armv5/urel/calocalizerscanner.dll" - "c:/sys/bin/calocalizerscanner.dll" "/epoc32/data/z/resource/plugins/calocalizerscanner.rsc"-"c:/resource/plugins/calocalizerscanner.rsc" +"/epoc32/release/armv5/urel/causifscanner.dll" - "c:/sys/bin/causifscanner.dll" +"/epoc32/data/z/resource/plugins/causifscanner.rsc"-"c:/resource/plugins/causifscanner.rsc" "/epoc32/release/armv5/urel/camenuserver.exe" - "c:/sys/bin/camenuserver.exe" @@ -142,9 +144,6 @@ ; ---- appfoundation -------------------------------------------- -; -------- servicemodel -"/epoc32/release/armv5/urel/hsservicemodel.dll" - "c:/sys/bin/hsservicemodel.dll" - ; -------- statemodel "/epoc32/release/armv5/urel/statemodel.dll" - "c:/sys/bin/statemodel.dll" @@ -156,6 +155,3 @@ ; ---- screensavermodel -------------------------------------------- "/epoc32/release/armv5/urel/screensavermodel.dll" - "c:/sys/bin/screensavermodel.dll" - -; ---- bagetmodel -------------------------------------------- -"/epoc32/release/armv5/urel/bagetmodel.dll" - "c:/sys/bin/bagetmodel.dll" diff -r a6d55a2e75be -r 782e3408c2ab sis/homescreensrv_ut_hs.pkg --- a/sis/homescreensrv_ut_hs.pkg Fri Mar 26 13:00:55 2010 +0200 +++ /dev/null Thu Jan 01 00:00:00 1970 +0000 @@ -1,82 +0,0 @@ -; -; 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: -; - -; Language -&EN - -; SIS heade name, uid, version -#{"hssrv ut hs"},(0x20022F67),1,0,0 - -; Localised Vendor name -%{"Nokia"} - -; Unique Vendor name -:"Nokia" - -; Supports S60 5th Edition -[0x1028315F], 0, 0, 0, {"S60ProductID"} - -;--------------- appfoundation --------------- - -;servicemodel: -"/epoc32/release/armv5/urel/t_hsservicemodelexe.exe" - "c:/sys/bin/t_hsservicemodelexe.exe" -"/epoc32/data/z/private/10003a3f/import/apps/t_hsservicemodelexe_reg.rsc" - "c:/private/10003a3f/import/apps/t_hsservicemodelexe_reg.rsc" -"/epoc32/data/z/resource/apps/t_hsservicemodelexe.rsc" - "c:/resource/apps/t_hsservicemodelexe.rsc" -"/epoc32/release/armv5/urel/testserviceprovider.dll" - "c:/sys/bin/testserviceprovider.dll" -"/epoc32/data/z/hsresources/testresources/hsresources/plugins/serviceproviders/testserviceprovider.qtplugin" - "c:/hsresources/testresources/hsresources/plugins/serviceproviders/testserviceprovider.qtplugin" -"/epoc32/data/z/hsresources/testresources/hsresources/plugins/serviceproviders/test1serviceprovider.manifest" - "c:/hsresources/testresources/hsresources/plugins/serviceproviders/test1serviceprovider.manifest" -"/epoc32/data/z/hsresources/testresources/hsresources/plugins/serviceproviders/test2serviceprovider.manifest" - "c:/hsresources/testresources/hsresources/plugins/serviceproviders/test2serviceprovider.manifest" -"../appfoundation/servicemodel/tsrc/t_hsservicemodelexe/invalidservice.manifest" - "c:/hsresources/testresources/invalidservice.manifest" -"../appfoundation/servicemodel/tsrc/t_hsservicemodelexe/notwellformedservice.manifest" - "c:/hsresources/testresources/notwellformedservice.manifest" -"../appfoundation/servicemodel/tsrc/t_hsservicemodelexe/validservice.manifest" - "c:/hsresources/testresources/validservice.manifest" -"../appfoundation/servicemodel/tsrc/t_hsservicemodelexe/validservice2.manifest" - "c:/hsresources/testresources/validservice2.manifest" - -;statemodel: -"/epoc32/release/armv5/urel/t_hsstatemodelexe.exe" - "c:/sys/bin/t_hsstatemodelexe.exe" -"/epoc32/data/z/private/10003a3f/import/apps/t_hsstatemodelexe_reg.rsc" - "c:/private/10003a3f/import/apps/t_hsstatemodelexe_reg.rsc" -"/epoc32/data/z/resource/apps/t_hsstatemodelexe.rsc" - "c:/resource/apps/t_hsstatemodelexe.rsc" -"/epoc32/release/armv5/urel/teststateprovider.dll" - "c:/sys/bin/teststateprovider.dll" -"/epoc32/data/z/hsresources/testresources/plugins/stateproviders/teststateprovider.qtplugin" - "c:/hsresources/testresources/plugins/stateproviders/teststateprovider.qtplugin" -"/epoc32/data/z/hsresources/testresources/plugins/stateproviders/teststateprovider.manifest" - "c:/hsresources/testresources/plugins/stateproviders/teststateprovider.manifest" -"../appfoundation/statemodel/tsrc/t_hsstatemodelexe/invalidstate.manifest" - "c:/hsresources/testresources/invalidstate.manifest" -"../appfoundation/statemodel/tsrc/t_hsstatemodelexe/notwellformedstate.manifest" - "c:/hsresources/testresources/notwellformedstate.manifest" -"../appfoundation/statemodel/tsrc/t_hsstatemodelexe/validstate2.manifest" - "c:/hsresources/testresources/validstate2.manifest" -"../appfoundation/statemodel/tsrc/t_hsstatemodelexe/validstate.manifest" - "c:/hsresources/testresources/validstate.manifest" - -;appruntimemodel: -"/epoc32/release/armv5/urel/t_hsruntimemodelexe.exe" - "c:/sys/bin/t_hsruntimemodelexe.exe" -"/epoc32/data/z/private/10003a3f/import/apps/t_hsruntimemodelexe_reg.rsc" - "c:/private/10003a3f/import/apps/t_hsruntimemodelexe_reg.rsc" -"/epoc32/data/z/resource/apps/t_hsruntimemodelexe.rsc" - "c:/resource/apps/t_hsruntimemodelexe.rsc" -"/epoc32/release/armv5/urel/testruntimeprovider.dll" - "c:/sys/bin/testruntimeprovider.dll" -"/epoc32/data/z/hsresources/testresources/plugins/runtimeproviders/testruntimeprovider.qtplugin" - "c:/hsresources/testresources/plugins/runtimeproviders/testruntimeprovider.qtplugin" -"/epoc32/data/z/hsresources/testresources/plugins/runtimeproviders/testruntimeprovider.manifest" - "c:/hsresources/testresources/plugins/runtimeproviders/testruntimeprovider.manifest" -"../appfoundation/appruntimemodel/tsrc/t_hsruntimemodelexe/invalidruntime.manifest" - "c:/hsresources/testresources/invalidruntime.manifest" -"../appfoundation/appruntimemodel/tsrc/t_hsruntimemodelexe/notwellformedruntime.manifest" - "c:/hsresources/testresources/notwellformedruntime.manifest" -"../appfoundation/appruntimemodel/tsrc/t_hsruntimemodelexe/validruntime2.manifest" - "c:/hsresources/testresources/validruntime2.manifest" -"../appfoundation/appruntimemodel/tsrc/t_hsruntimemodelexe/validruntime.manifest" - "c:/hsresources/testresources/validruntime.manifest" - -;--------------- hswidgetmodel --------------- - -"/epoc32/release/armv5/urel/t_hswidgetmodelexe.exe" - "c:/sys/bin/t_hswidgetmodelexe.exe" -"/epoc32/data/z/private/10003a3f/import/apps/t_hswidgetmodelexe_reg.rsc" - "c:/private/10003a3f/import/apps/t_hswidgetmodelexe_reg.rsc" -"/epoc32/data/z/resource/apps/t_hswidgetmodelexe.rsc" - "c:/resource/apps/t_hswidgetmodelexe.rsc" -"/epoc32/release/armv5/urel/testwidgetprovider.dll" - "c:/sys/bin/testwidgetprovider.dll" -"/epoc32/data/z/hsresources/testresources/plugins/widgetproviders/testwidgetprovider.qtplugin" - "c:/hsresources/testresources/plugins/widgetproviders/testwidgetprovider.qtplugin" -"/epoc32/data/z/hsresources/testresources/plugins/widgetproviders/testwidgetprovider.manifest" - "c:/hsresources/testresources/plugins/widgetproviders/testwidgetprovider.manifest" -"../hswidgetmodel/tsrc/t_hswidgetmodelexe/invalidwidget.manifest" - "c:/hsresources/testresources/invalidwidget.manifest" -"../hswidgetmodel/tsrc/t_hswidgetmodelexe/notwellformedwidget.manifest" - "c:/hsresources/testresources/notwellformedwidget.manifest" -"../hswidgetmodel/tsrc/t_hswidgetmodelexe/validwidget2.manifest" - "c:/hsresources/testresources/validwidget2.manifest" -"../hswidgetmodel/tsrc/t_hswidgetmodelexe/validwidget.manifest" - "c:/hsresources/testresources/validwidget.manifest" diff -r a6d55a2e75be -r 782e3408c2ab sis/homescreensrv_ut_hs_sisx.bat --- a/sis/homescreensrv_ut_hs_sisx.bat Fri Mar 26 13:00:55 2010 +0200 +++ /dev/null Thu Jan 01 00:00:00 1970 +0000 @@ -1,30 +0,0 @@ -@rem -@rem Copyright (c) 2009 Nokia Corporation and/or its subsidiary(-ies). -@rem All rights reserved. -@rem This component and the accompanying materials are made available -@rem under the terms of "Eclipse Public License v1.0" -@rem which accompanies this distribution, and is available -@rem at the URL "http://www.eclipse.org/legal/epl-v10.html". -@rem -@rem Initial Contributors: -@rem Nokia Corporation - initial contribution. -@rem -@rem Contributors: -@rem -@rem Description: -@rem -@echo off - -if exist homescreensrv_ut_hs.sisx del homescreensrv_ut_hs.sisx - -makesis homescreensrv_ut_hs.pkg -signsis homescreensrv_ut_hs.sis homescreensrv_ut_hs.sisx rd.cer rd-key.pem - -if exist homescreensrv_ut_hs.sisx ( -echo homescreensrv_ut_hs.sisx creation SUCCEEDED -del homescreensrv_ut_hs.sis -) - -if not exist homescreensrv_ut_hs.sisx ( -echo homescreensrv_ut_hs.sisx creation FAILED -) \ No newline at end of file