diff -r 000000000000 -r ff3acec5bc43 mpxplugins/serviceplugins/collectionplugins/mpxsqlitedbhgplugin/inc/mpxdbauxiliary.h --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/mpxplugins/serviceplugins/collectionplugins/mpxsqlitedbhgplugin/inc/mpxdbauxiliary.h Thu Dec 17 08:45:05 2009 +0200 @@ -0,0 +1,173 @@ +/* +* Copyright (c) 2007 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: This class is responsible for interacting with the Auxiliary +* table. +* +*/ + + +#ifndef MPXDBAUXILIARY_H +#define MPXDBAUXILIARY_H + +// INCLUDES +#include "mpxdbtable.h" + +// CLASS DECLARATION + +/** +* Responsible for managing the playlist tables +* +* @lib MPXDbPlugin.lib +*/ +class CMPXDbAuxiliary : + public CMPXDbTable + { + public: + + /** + * Two-phased constructor. + * @param aDbManager database manager to use for database interactions + * @return New CMPXDbManager instance. + */ + static CMPXDbAuxiliary* NewL(CMPXDbManager& aDbManager); + + /** + * Two-phased constructor. + * @param aDbManager database manager to use for database interactions + * @return New CMPXDbManager instance on the cleanup stack. + */ + static CMPXDbAuxiliary* NewLC(CMPXDbManager& aDbManager); + + /** + * Destructor + */ + virtual ~CMPXDbAuxiliary(); + + public: + + /** + * Sets the last refreshed time in the auxiliary table. + * @param aTime the last refreshed time value + */ + void SetLastRefreshedTimeL(TTime aTime); + + /** + * Gets the last refreshed time from the auxiliary table. + * @return last refreshed time value + */ + TTime LastRefreshedTimeL(); + + /** + * Sets the db corrupted flag in the auxiliary table. + * @param aCorrupted db corrupted flag value + */ + void SetDBCorruptedL(TBool aCorrupted); + + /** + * Gets the db corrupted flag value from the auxiliary table. + * @return db corrupted flag value + */ + TBool DBCorruptedL(); + + /** + * Sets the save deleted record count value. + * @param aDrive drive identifier + * @param aValue new field value + * + */ + void SetSaveDeletedRecordCountL(TInt aDrive,TUint32 aValue); + + /** + * Gets the save deleted record count field value. + * @return field value + */ + TUint32 SaveDeletedRecordCountL(); + + /** + * Gets the save deleted record count field value. + * @param aDrive drive identifier + * @return field value + */ + TUint32 SaveDeletedRecordCountL(TInt aDrive); + + /** + * Checks if all databases have been refreshed. + * @return EFalse if at least one database has not been refreshed. + */ + TBool IsRefreshedL(); + + /** + * Get the auxilary id for a drive + * @param aDrive drive to get the volume id + * @return TInt id for the aux database + */ + TInt IdL( TInt aDrive ); + + /** + * Set the auxilary id for a drive + * @param aDrive, + * @param aId + */ + void SetIdL( TInt aDrive, TInt aId ); + + private: // from MMPXTable + + /** + * @see MMPXTable + */ + virtual void CreateTableL(RSqlDatabase& aDatabase, TBool aCorruptTable); + + /** + * @see MMPXTable + */ + virtual void DropTableL(RSqlDatabase& aDatabase); + + /** + * @see MMPXTable + */ + virtual TBool CheckTableL(RSqlDatabase& aDatabase); + + private: + + /** + * C++ constructor + * @param aDbManager database manager to use for database interactions + */ + CMPXDbAuxiliary(CMPXDbManager& aDbManager); + + /** + * Safely construct things that can leave + */ + void ConstructL(); + + private: + + /** + * Column indexes in the auxiliary table + */ + enum TAuxiliaryColumns + { + EAuxiliaryId = KMPXTableDefaultIndex, + EAuxiliaryVersion, + EAuxiliaryTimeRefreshed, + EAuxiliaryTimeSynced, + EAuxiliaryCorrupt, + EAuxiliarySavedDeletedRecordCount + }; + + }; + +#endif // MPXDBAUXILIARY_H + +// End of File