diff -r 000000000000 -r f72a12da539e menufw/hierarchynavigator/hnutilities/inc/hnmdkeyfactory.h --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/menufw/hierarchynavigator/hnutilities/inc/hnmdkeyfactory.h Thu Dec 17 08:40:49 2009 +0200 @@ -0,0 +1,100 @@ +/* +* Copyright (c) 2007-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 HNMDKEYFACTORY_H +#define HNMDKEYFACTORY_H + +#include +#include + +class CHnMdBaseKey; + +/** + * Provides static methods for creating particular key classes. + * + * @lib hnutilities.lib + * @since S60 v3.0 + * @ingroup group_hnutilities + */ +NONSHARABLE_CLASS( HnMdKeyFactory ) + { +public: + + /** + * Creates particular key type depending on XML element. + * Sets name and value of the key read also from XML. + * + * since S60 v5.0 + * @param aElement XML DOM Element. + * @return Pointer to created key. + */ + IMPORT_C static CHnMdBaseKey* CreateLC( TXmlEngElement aElement ); + + /** + * Creates particular key type depending on XML element. + * Sets name and value of the key read also from XML. + * + * since S60 v5.0 + * @param aElement XML DOM Element. + * @return Pointer to created key. + */ + IMPORT_C static CHnMdBaseKey* CreateL( TXmlEngElement aElement ); + + /** + * Creates particular key type depending on passed argument. + * Sets name and value of the key. + * + * since S60 v5.0 + * @param aName Key name. + * @param aType Key type. + * @param aValue Key value. + * @return Pointer to created key. + */ + IMPORT_C static CHnMdBaseKey* CreateL( + const TDesC8& aName, + const TDesC8& aType, + const TDesC8& aValue ); + + /** + * Creates particular key type depending on passed argument. + * Sets name and value of the key. + * + * since S60 v5.0 + * @param aName Key name. + * @param aType Key type. + * @param aValue Key value. + * @return Pointer to created key. + */ + IMPORT_C static CHnMdBaseKey* CreateL( + const TDesC8& aName, + const TDesC8& aType, + const TDesC& aValue ); + + private: + + /** + * Creates particular key type depending on passed argument. + * + * since S60 v5.0 + * @param aKeyType Key type. + * @return Pointer to created key. + */ + static CHnMdBaseKey* CreateL( const TDesC8& aKeyType ); + }; + +#endif // HNMDKEYFACTORY_H