brandingserver/tools/bsimport/inc/cbsimportxmlparser.h
author hgs
Sun, 11 Apr 2010 15:33:49 +0530
changeset 31 9dbc70490d9a
parent 0 e6b17d312c8b
child 33 bb46c9d56bcb
permissions -rw-r--r--
201014
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
0
e6b17d312c8b Revision: 200949
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
     1
/*
e6b17d312c8b Revision: 200949
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
     2
* Copyright (c) 2006-2006 Nokia Corporation and/or its subsidiary(-ies).
e6b17d312c8b Revision: 200949
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
     3
* All rights reserved.
e6b17d312c8b Revision: 200949
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
     4
* This component and the accompanying materials are made available
31
hgs
parents: 0
diff changeset
     5
* under the terms of the License "Eclipse Public License v1.0"
0
e6b17d312c8b Revision: 200949
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
     6
* which accompanies this distribution, and is available
e6b17d312c8b Revision: 200949
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
     7
* at the URL "http://www.eclipse.org/legal/epl-v10.html".
e6b17d312c8b Revision: 200949
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
     8
*
e6b17d312c8b Revision: 200949
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
     9
* Initial Contributors:
e6b17d312c8b Revision: 200949
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    10
* Nokia Corporation - initial contribution.
e6b17d312c8b Revision: 200949
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    11
*
e6b17d312c8b Revision: 200949
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    12
* Contributors:
e6b17d312c8b Revision: 200949
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    13
*
31
hgs
parents: 0
diff changeset
    14
* Description:   Parses XML content and stores data to storage
0
e6b17d312c8b Revision: 200949
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    15
*
e6b17d312c8b Revision: 200949
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    16
*/
e6b17d312c8b Revision: 200949
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    17
31
hgs
parents: 0
diff changeset
    18
hgs
parents: 0
diff changeset
    19
#ifndef CBSIMPORTXMLPARSER_H
hgs
parents: 0
diff changeset
    20
#define CBSIMPORTXMLPARSER_H
hgs
parents: 0
diff changeset
    21
hgs
parents: 0
diff changeset
    22
// INCLUDE FILES
hgs
parents: 0
diff changeset
    23
#include <e32base.h>
hgs
parents: 0
diff changeset
    24
#include <f32file.h>
hgs
parents: 0
diff changeset
    25
#include <gmxmldocument.h>
hgs
parents: 0
diff changeset
    26
#include <RBSObjOwningPtrArray.h>
hgs
parents: 0
diff changeset
    27
#include <mbselement.h>
hgs
parents: 0
diff changeset
    28
hgs
parents: 0
diff changeset
    29
class CMDXMLNode;
hgs
parents: 0
diff changeset
    30
class CBSImportStorageManager;
hgs
parents: 0
diff changeset
    31
hgs
parents: 0
diff changeset
    32
// CLASS DEFINITION
hgs
parents: 0
diff changeset
    33
class CBSImportXMLParser : public CBase
hgs
parents: 0
diff changeset
    34
    {
hgs
parents: 0
diff changeset
    35
private: // Definitions
hgs
parents: 0
diff changeset
    36
hgs
parents: 0
diff changeset
    37
    struct TImportBitmap
hgs
parents: 0
diff changeset
    38
        {
hgs
parents: 0
diff changeset
    39
        TInt iBitmapId;
hgs
parents: 0
diff changeset
    40
        TInt iBitmapMaskId;
hgs
parents: 0
diff changeset
    41
        TInt iSkinId;
hgs
parents: 0
diff changeset
    42
        TInt iSkinMaskId;
hgs
parents: 0
diff changeset
    43
        };
hgs
parents: 0
diff changeset
    44
hgs
parents: 0
diff changeset
    45
    enum TXMLBaseTagTypes
hgs
parents: 0
diff changeset
    46
        {
hgs
parents: 0
diff changeset
    47
        EBrandUnknown,
hgs
parents: 0
diff changeset
    48
        EBrandAppID,
hgs
parents: 0
diff changeset
    49
        EBrandID,
hgs
parents: 0
diff changeset
    50
        EBrandLanguage,
hgs
parents: 0
diff changeset
    51
        EBrandVersion,
hgs
parents: 0
diff changeset
    52
        EBrandElement
hgs
parents: 0
diff changeset
    53
        };
hgs
parents: 0
diff changeset
    54
        
hgs
parents: 0
diff changeset
    55
public:
hgs
parents: 0
diff changeset
    56
hgs
parents: 0
diff changeset
    57
    static CBSImportXMLParser* NewL( CBSImportStorageManager* aStorage );
hgs
parents: 0
diff changeset
    58
    
hgs
parents: 0
diff changeset
    59
    static CBSImportXMLParser* NewLC( CBSImportStorageManager* aStorage );
hgs
parents: 0
diff changeset
    60
hgs
parents: 0
diff changeset
    61
    ~CBSImportXMLParser();
hgs
parents: 0
diff changeset
    62
hgs
parents: 0
diff changeset
    63
    /**
hgs
parents: 0
diff changeset
    64
     * Parse XML document and store data to storage
hgs
parents: 0
diff changeset
    65
     *
hgs
parents: 0
diff changeset
    66
     * @since S60 3.2
hgs
parents: 0
diff changeset
    67
     * @param aDocument XML document to parse
hgs
parents: 0
diff changeset
    68
     * @return none
hgs
parents: 0
diff changeset
    69
     */
hgs
parents: 0
diff changeset
    70
    void ParseDocumentL( CMDXMLDocument& aDocument );
hgs
parents: 0
diff changeset
    71
hgs
parents: 0
diff changeset
    72
private:
hgs
parents: 0
diff changeset
    73
hgs
parents: 0
diff changeset
    74
    CBSImportXMLParser( CBSImportStorageManager* aStorage );
hgs
parents: 0
diff changeset
    75
    
hgs
parents: 0
diff changeset
    76
    void ConstructL();
hgs
parents: 0
diff changeset
    77
    
hgs
parents: 0
diff changeset
    78
    /**
hgs
parents: 0
diff changeset
    79
     * Parses full the base element <branding> and it's child elements.
hgs
parents: 0
diff changeset
    80
     *
hgs
parents: 0
diff changeset
    81
     * @since S60 v3.2
hgs
parents: 0
diff changeset
    82
     * @param aElement to parse
hgs
parents: 0
diff changeset
    83
     */
hgs
parents: 0
diff changeset
    84
    void ParseDocumentBaseL( CMDXMLNode* aElement );
hgs
parents: 0
diff changeset
    85
    
hgs
parents: 0
diff changeset
    86
    /**
hgs
parents: 0
diff changeset
    87
     * Analyzes a child node of <branding> and stores the value to storage.
hgs
parents: 0
diff changeset
    88
     * Ignores undetected XML nodes.
hgs
parents: 0
diff changeset
    89
     *
hgs
parents: 0
diff changeset
    90
     * @since S60 v3.2
hgs
parents: 0
diff changeset
    91
     * @param aElement to parse
hgs
parents: 0
diff changeset
    92
     */
hgs
parents: 0
diff changeset
    93
    void AnalyzeNodeL( CMDXMLNode* aNode );
hgs
parents: 0
diff changeset
    94
    
hgs
parents: 0
diff changeset
    95
    /**
hgs
parents: 0
diff changeset
    96
     * Converts a given node to TXMLBaseTagTypes. This can handle all
hgs
parents: 0
diff changeset
    97
     * child nodes of <branding>
hgs
parents: 0
diff changeset
    98
     *
hgs
parents: 0
diff changeset
    99
     * @since S60 v3.2
hgs
parents: 0
diff changeset
   100
     * @param aNode node to check
hgs
parents: 0
diff changeset
   101
     * @return corresponding TXMLBaseTagTypes value (or EBrandUnknown).
hgs
parents: 0
diff changeset
   102
     */
hgs
parents: 0
diff changeset
   103
    TXMLBaseTagTypes SolveTagTypeL( CMDXMLNode* aNode );
hgs
parents: 0
diff changeset
   104
hgs
parents: 0
diff changeset
   105
    /**
hgs
parents: 0
diff changeset
   106
     * Parses full <element> node. Returns a newly constructed MBSElement
hgs
parents: 0
diff changeset
   107
     * from the content of teh node. 
hgs
parents: 0
diff changeset
   108
     * Ownership is transferred!
hgs
parents: 0
diff changeset
   109
     *
hgs
parents: 0
diff changeset
   110
     * @since S60 v3.2
hgs
parents: 0
diff changeset
   111
     * @param aNode <element> node
hgs
parents: 0
diff changeset
   112
     * @return Concrete element constructed from node. 
hgs
parents: 0
diff changeset
   113
     */
hgs
parents: 0
diff changeset
   114
    MBSElement* ParseBrandElementL( CMDXMLNode* aNode );
hgs
parents: 0
diff changeset
   115
    
hgs
parents: 0
diff changeset
   116
    /**
hgs
parents: 0
diff changeset
   117
     * Converts elements type attribute value to TBSElementType 
hgs
parents: 0
diff changeset
   118
     * (see MBSElement).
hgs
parents: 0
diff changeset
   119
     *
hgs
parents: 0
diff changeset
   120
     * @since S60 v3.2
hgs
parents: 0
diff changeset
   121
     * @param aType value of type attribute
hgs
parents: 0
diff changeset
   122
     * @return corresponding TBrandingElementType value or KErrNotFound.
hgs
parents: 0
diff changeset
   123
     */
hgs
parents: 0
diff changeset
   124
    TInt SolveElementType( const TDesC& aType );
hgs
parents: 0
diff changeset
   125
hgs
parents: 0
diff changeset
   126
    /**
hgs
parents: 0
diff changeset
   127
     * Search a child node with name inside another node. Returns the first match
hgs
parents: 0
diff changeset
   128
     *
hgs
parents: 0
diff changeset
   129
     * @since S60 v3.2
hgs
parents: 0
diff changeset
   130
     * @param aNode parent node to search 
hgs
parents: 0
diff changeset
   131
     * @param aTagName Child nodes name
hgs
parents: 0
diff changeset
   132
     * @return found node or NULL if not found;
hgs
parents: 0
diff changeset
   133
     */
hgs
parents: 0
diff changeset
   134
    CMDXMLNode* SearchChild( CMDXMLNode* aNode, const TDesC& aChildName );
hgs
parents: 0
diff changeset
   135
hgs
parents: 0
diff changeset
   136
    /**
hgs
parents: 0
diff changeset
   137
     * Parse value from <element_value> tag. Leaves if parse fails.
hgs
parents: 0
diff changeset
   138
     * Ownership is transferred to caller (NodeTextLC)
hgs
parents: 0
diff changeset
   139
     *
hgs
parents: 0
diff changeset
   140
     * @since S60 3.2
hgs
parents: 0
diff changeset
   141
     * @param aNode XML node to parse. should be <element_value>.
hgs
parents: 0
diff changeset
   142
     * @return value from <element_value>
hgs
parents: 0
diff changeset
   143
     */
hgs
parents: 0
diff changeset
   144
    HBufC* NodeTextLC( CMDXMLNode* elNode );
hgs
parents: 0
diff changeset
   145
    TInt   NodeIntL  ( CMDXMLNode* elNode );
hgs
parents: 0
diff changeset
   146
    
hgs
parents: 0
diff changeset
   147
    /**
hgs
parents: 0
diff changeset
   148
     * Parse <element> tag for given value type. Leaves if parsing fails.
hgs
parents: 0
diff changeset
   149
     *
hgs
parents: 0
diff changeset
   150
     * @since S60 3.2
hgs
parents: 0
diff changeset
   151
     * @param aNode XML node to parse
hgs
parents: 0
diff changeset
   152
     * @param aValue Parsed value
hgs
parents: 0
diff changeset
   153
     * @return none
hgs
parents: 0
diff changeset
   154
     */
hgs
parents: 0
diff changeset
   155
    void DoParseIntegerL( CMDXMLNode* aNode, TInt& aValue );
hgs
parents: 0
diff changeset
   156
    void DoParseTextL   ( CMDXMLNode* aNode, HBufC*& aText );
hgs
parents: 0
diff changeset
   157
    void DoParseFileL   ( CMDXMLNode* aNode, HBufC*& aText );
hgs
parents: 0
diff changeset
   158
    void DoParseListL   ( CMDXMLNode* aNode, RBSObjOwningPtrArray<MBSElement>& aElementArray );
hgs
parents: 0
diff changeset
   159
    void DoParseBitmapL ( CMDXMLNode* aNode, CBSBitmap*& aBitmap );
hgs
parents: 0
diff changeset
   160
    
hgs
parents: 0
diff changeset
   161
private: // Data
hgs
parents: 0
diff changeset
   162
    
hgs
parents: 0
diff changeset
   163
    // Not owned. Storage where to put parsed elements
hgs
parents: 0
diff changeset
   164
    CBSImportStorageManager* iStorage;
hgs
parents: 0
diff changeset
   165
    };
hgs
parents: 0
diff changeset
   166
hgs
parents: 0
diff changeset
   167
#endif //CBSIMPORTXMLPARSER_H