svgtopt/SVG/Xmldomimpl/inc/SVGXmlElementImpl.h
author hgs
Wed, 03 Nov 2010 18:56:10 +0200
changeset 46 88edb906c587
permissions -rw-r--r--
201044
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
46
hgs
parents:
diff changeset
     1
/*
hgs
parents:
diff changeset
     2
* Copyright (c) 2003 Nokia Corporation and/or its subsidiary(-ies).
hgs
parents:
diff changeset
     3
* All rights reserved.
hgs
parents:
diff changeset
     4
* This component and the accompanying materials are made available
hgs
parents:
diff changeset
     5
* under the terms of "Eclipse Public License v1.0"
hgs
parents:
diff changeset
     6
* which accompanies this distribution, and is available
hgs
parents:
diff changeset
     7
* at the URL "http://www.eclipse.org/legal/epl-v10.html".
hgs
parents:
diff changeset
     8
*
hgs
parents:
diff changeset
     9
* Initial Contributors:
hgs
parents:
diff changeset
    10
* Nokia Corporation - initial contribution.
hgs
parents:
diff changeset
    11
*
hgs
parents:
diff changeset
    12
* Contributors:
hgs
parents:
diff changeset
    13
*
hgs
parents:
diff changeset
    14
* Description:  XML DOM Implementation header file
hgs
parents:
diff changeset
    15
 *
hgs
parents:
diff changeset
    16
*/
hgs
parents:
diff changeset
    17
hgs
parents:
diff changeset
    18
hgs
parents:
diff changeset
    19
#ifndef __INC_CXMLELEMENTIMPL__
hgs
parents:
diff changeset
    20
#define __INC_CXMLELEMENTIMPL__
hgs
parents:
diff changeset
    21
hgs
parents:
diff changeset
    22
#if !defined(__E32BASE_H__)
hgs
parents:
diff changeset
    23
#include <e32base.h>
hgs
parents:
diff changeset
    24
#endif
hgs
parents:
diff changeset
    25
hgs
parents:
diff changeset
    26
#include "SVGXmlElement.h"
hgs
parents:
diff changeset
    27
hgs
parents:
diff changeset
    28
hgs
parents:
diff changeset
    29
hgs
parents:
diff changeset
    30
class   MXmlDocument;
hgs
parents:
diff changeset
    31
hgs
parents:
diff changeset
    32
hgs
parents:
diff changeset
    33
/**
hgs
parents:
diff changeset
    34
 * Class description
hgs
parents:
diff changeset
    35
 */
hgs
parents:
diff changeset
    36
class CXmlElementImpl : public CBase, public MXmlElement
hgs
parents:
diff changeset
    37
    {
hgs
parents:
diff changeset
    38
    public:
hgs
parents:
diff changeset
    39
hgs
parents:
diff changeset
    40
        /**
hgs
parents:
diff changeset
    41
         * Set the attribute value for a given attribute name of the current XML element
hgs
parents:
diff changeset
    42
         * Actual specification requires a new node object be created for the new attribute
hgs
parents:
diff changeset
    43
         * This implementation just sets a variable in the element class instance
hgs
parents:
diff changeset
    44
         *
hgs
parents:
diff changeset
    45
         * @since 1.0
hgs
parents:
diff changeset
    46
         * @param aName - A string buffer containig the name of the attribute to be set
hgs
parents:
diff changeset
    47
         * @param aValue - A string buffer containig the value of the attribute to be set
hgs
parents:
diff changeset
    48
         * @return An integer containing success/failure for this action
hgs
parents:
diff changeset
    49
         */
hgs
parents:
diff changeset
    50
        virtual TInt            SetAttributeL( const TDesC& aName,
hgs
parents:
diff changeset
    51
                                               const TDesC& aValue );
hgs
parents:
diff changeset
    52
hgs
parents:
diff changeset
    53
hgs
parents:
diff changeset
    54
        /**
hgs
parents:
diff changeset
    55
         * Remove attribute for an XML element
hgs
parents:
diff changeset
    56
         * Actual specification requires the attribute node be removed
hgs
parents:
diff changeset
    57
         * Since this implementation does not create an attribute node, it
hgs
parents:
diff changeset
    58
         * just changes the state of the corresponding variable
hgs
parents:
diff changeset
    59
         *
hgs
parents:
diff changeset
    60
         * @since 1.0
hgs
parents:
diff changeset
    61
         * @param aName - A string buffer containing the name of the attribute to
hgs
parents:
diff changeset
    62
         *                be removed
hgs
parents:
diff changeset
    63
         * @return An integer containing success/failure for this action
hgs
parents:
diff changeset
    64
         */
hgs
parents:
diff changeset
    65
        virtual TInt            RemoveAttribute( const TDesC& aName );
hgs
parents:
diff changeset
    66
hgs
parents:
diff changeset
    67
hgs
parents:
diff changeset
    68
        /**
hgs
parents:
diff changeset
    69
         * Accessor for the tag name of an XML element
hgs
parents:
diff changeset
    70
         *
hgs
parents:
diff changeset
    71
         * @since 1.0
hgs
parents:
diff changeset
    72
         * @param None
hgs
parents:
diff changeset
    73
         * @return A string buffer containing the tag name
hgs
parents:
diff changeset
    74
         */
hgs
parents:
diff changeset
    75
        virtual const TDesC&    TagName();
hgs
parents:
diff changeset
    76
hgs
parents:
diff changeset
    77
hgs
parents:
diff changeset
    78
        /**
hgs
parents:
diff changeset
    79
         * Append child method for an XML element
hgs
parents:
diff changeset
    80
         *
hgs
parents:
diff changeset
    81
         * @since 1.0
hgs
parents:
diff changeset
    82
         * @param aAppendChild - The element object that needs to be appended
hgs
parents:
diff changeset
    83
         * @return NULL if failed to append;
hgs
parents:
diff changeset
    84
         *         A MXmlElement pointer to the object that was just appended
hgs
parents:
diff changeset
    85
         */
hgs
parents:
diff changeset
    86
        virtual MXmlElement*    AppendChildL( MXmlElement* aAppendChild, TBool aIsJSR226Element = EFalse );
hgs
parents:
diff changeset
    87
hgs
parents:
diff changeset
    88
hgs
parents:
diff changeset
    89
        /**
hgs
parents:
diff changeset
    90
         * Remove child method for an XML element
hgs
parents:
diff changeset
    91
         *
hgs
parents:
diff changeset
    92
         * @since 1.0
hgs
parents:
diff changeset
    93
         * @param aRemoveChild - A pointer to the object that is to be removed
hgs
parents:
diff changeset
    94
         * @return None
hgs
parents:
diff changeset
    95
         */
hgs
parents:
diff changeset
    96
        virtual void            RemoveChild ( MXmlElement* aRemoveChild );
hgs
parents:
diff changeset
    97
hgs
parents:
diff changeset
    98
hgs
parents:
diff changeset
    99
        /**
hgs
parents:
diff changeset
   100
         * 'Has child nodes' method that finds out if the current element has any child
hgs
parents:
diff changeset
   101
         *  nodes
hgs
parents:
diff changeset
   102
         *
hgs
parents:
diff changeset
   103
         * @since 1.0
hgs
parents:
diff changeset
   104
         * @param None
hgs
parents:
diff changeset
   105
         * @return A boolean
hgs
parents:
diff changeset
   106
         *         ETrue if there are child nodes; EFalse otherwise
hgs
parents:
diff changeset
   107
         */
hgs
parents:
diff changeset
   108
        virtual TBool           HasChildNodes();
hgs
parents:
diff changeset
   109
hgs
parents:
diff changeset
   110
hgs
parents:
diff changeset
   111
        /**
hgs
parents:
diff changeset
   112
         * Accessor method for 'first child' of an XML element
hgs
parents:
diff changeset
   113
         *
hgs
parents:
diff changeset
   114
         * @since 1.0
hgs
parents:
diff changeset
   115
         * @param None
hgs
parents:
diff changeset
   116
         * @return An MXmlElement pointer to the first child of the current XML element
hgs
parents:
diff changeset
   117
         */
hgs
parents:
diff changeset
   118
        virtual MXmlElement*    FirstChild();
hgs
parents:
diff changeset
   119
hgs
parents:
diff changeset
   120
hgs
parents:
diff changeset
   121
        /**
hgs
parents:
diff changeset
   122
         * Accessor method for 'last child' of an XML element
hgs
parents:
diff changeset
   123
         *
hgs
parents:
diff changeset
   124
         * @since 1.0
hgs
parents:
diff changeset
   125
         * @param None
hgs
parents:
diff changeset
   126
         * @return An MXmlElement pointer to the last child of the current XML element
hgs
parents:
diff changeset
   127
         */
hgs
parents:
diff changeset
   128
        virtual MXmlElement*    LastChild();
hgs
parents:
diff changeset
   129
hgs
parents:
diff changeset
   130
hgs
parents:
diff changeset
   131
        /**
hgs
parents:
diff changeset
   132
         * Accessor method for 'owner document' of an XML element
hgs
parents:
diff changeset
   133
         *
hgs
parents:
diff changeset
   134
         * @since 1.0
hgs
parents:
diff changeset
   135
         * @param None
hgs
parents:
diff changeset
   136
         * @return A MXmlDocument pointer to the document object for this XML document
hgs
parents:
diff changeset
   137
         */
hgs
parents:
diff changeset
   138
        virtual MXmlDocument*   OwnerDocument();
hgs
parents:
diff changeset
   139
hgs
parents:
diff changeset
   140
hgs
parents:
diff changeset
   141
        /**
hgs
parents:
diff changeset
   142
         * Accessor method for 'next sibling' of an XML element
hgs
parents:
diff changeset
   143
         *
hgs
parents:
diff changeset
   144
         * @since 1.0
hgs
parents:
diff changeset
   145
         * @param None
hgs
parents:
diff changeset
   146
         * @return An MXmlElement pointer to the next sibling of the current XML element
hgs
parents:
diff changeset
   147
         */
hgs
parents:
diff changeset
   148
        virtual MXmlElement*    NextSibling();
hgs
parents:
diff changeset
   149
		virtual MXmlElement*	PreviousSibling();
hgs
parents:
diff changeset
   150
hgs
parents:
diff changeset
   151
        /**
hgs
parents:
diff changeset
   152
         * Accessor method for 'parent node' of an XML element
hgs
parents:
diff changeset
   153
         *
hgs
parents:
diff changeset
   154
         * @since 1.0
hgs
parents:
diff changeset
   155
         * @param None
hgs
parents:
diff changeset
   156
         * @return An MXmlElement pointer to the parent node of the current XML element
hgs
parents:
diff changeset
   157
         */
hgs
parents:
diff changeset
   158
        virtual MXmlElement*    ParentNode();
hgs
parents:
diff changeset
   159
hgs
parents:
diff changeset
   160
hgs
parents:
diff changeset
   161
        /**
hgs
parents:
diff changeset
   162
         * Accessor to set first child of an XML element
hgs
parents:
diff changeset
   163
         *
hgs
parents:
diff changeset
   164
         * @since 1.0
hgs
parents:
diff changeset
   165
         * @param An MXmlElement pointer to the object that is being set as first child
hgs
parents:
diff changeset
   166
         * @return None
hgs
parents:
diff changeset
   167
         */
hgs
parents:
diff changeset
   168
        virtual void            SetFirstChild( MXmlElement* );
hgs
parents:
diff changeset
   169
hgs
parents:
diff changeset
   170
hgs
parents:
diff changeset
   171
        /**
hgs
parents:
diff changeset
   172
         * Accessor to set last child of an XML element
hgs
parents:
diff changeset
   173
         *
hgs
parents:
diff changeset
   174
         * @since 1.0
hgs
parents:
diff changeset
   175
         * @param An MXmlElement pointer to the object that is being set as last child
hgs
parents:
diff changeset
   176
         * @return None
hgs
parents:
diff changeset
   177
         */
hgs
parents:
diff changeset
   178
        virtual void            SetLastChild( MXmlElement* );
hgs
parents:
diff changeset
   179
hgs
parents:
diff changeset
   180
hgs
parents:
diff changeset
   181
        /**
hgs
parents:
diff changeset
   182
         * Accessor to set owner document of an XML element
hgs
parents:
diff changeset
   183
         *
hgs
parents:
diff changeset
   184
         * @since 1.0
hgs
parents:
diff changeset
   185
         * @param An MXmlDocument pointer to the object that is being set as owner document
hgs
parents:
diff changeset
   186
         * @return None
hgs
parents:
diff changeset
   187
         */
hgs
parents:
diff changeset
   188
        virtual void            SetOwnerDocument( MXmlDocument* );
hgs
parents:
diff changeset
   189
hgs
parents:
diff changeset
   190
hgs
parents:
diff changeset
   191
        /**
hgs
parents:
diff changeset
   192
         * Accessor to set next sibling of an XML element
hgs
parents:
diff changeset
   193
         *
hgs
parents:
diff changeset
   194
         * @since 1.0
hgs
parents:
diff changeset
   195
         * @param An MXmlElement pointer to the object that is being set as next sibling
hgs
parents:
diff changeset
   196
         * @return None
hgs
parents:
diff changeset
   197
         */
hgs
parents:
diff changeset
   198
        virtual void            SetNextSibling( MXmlElement* );
hgs
parents:
diff changeset
   199
hgs
parents:
diff changeset
   200
hgs
parents:
diff changeset
   201
        /**
hgs
parents:
diff changeset
   202
         * Accessor to set parent node of an XML element
hgs
parents:
diff changeset
   203
         *
hgs
parents:
diff changeset
   204
         * @since 1.0
hgs
parents:
diff changeset
   205
         * @param An MXmlElement pointer to the object that is being set as parent node
hgs
parents:
diff changeset
   206
         * @return None
hgs
parents:
diff changeset
   207
         */
hgs
parents:
diff changeset
   208
        virtual void            SetParentNode( MXmlElement* );
hgs
parents:
diff changeset
   209
hgs
parents:
diff changeset
   210
hgs
parents:
diff changeset
   211
        /**
hgs
parents:
diff changeset
   212
         * Need method description
hgs
parents:
diff changeset
   213
         *
hgs
parents:
diff changeset
   214
         * @since 1.0
hgs
parents:
diff changeset
   215
         * @param
hgs
parents:
diff changeset
   216
         * @return
hgs
parents:
diff changeset
   217
         */
hgs
parents:
diff changeset
   218
        //        static CXmlElementImpl*     NewL( const TDesC& aTagName );
hgs
parents:
diff changeset
   219
hgs
parents:
diff changeset
   220
hgs
parents:
diff changeset
   221
        /**
hgs
parents:
diff changeset
   222
         * Need method description
hgs
parents:
diff changeset
   223
         *
hgs
parents:
diff changeset
   224
         * @since 1.0
hgs
parents:
diff changeset
   225
         * @param
hgs
parents:
diff changeset
   226
         * @return
hgs
parents:
diff changeset
   227
         */
hgs
parents:
diff changeset
   228
        //        static CXmlElementImpl*     NewLC( const TDesC& aTagName );
hgs
parents:
diff changeset
   229
hgs
parents:
diff changeset
   230
hgs
parents:
diff changeset
   231
        /**
hgs
parents:
diff changeset
   232
         * Need method description
hgs
parents:
diff changeset
   233
         *
hgs
parents:
diff changeset
   234
         * @since 1.0
hgs
parents:
diff changeset
   235
         * @param
hgs
parents:
diff changeset
   236
         * @return
hgs
parents:
diff changeset
   237
         */
hgs
parents:
diff changeset
   238
        virtual                 ~CXmlElementImpl();
hgs
parents:
diff changeset
   239
hgs
parents:
diff changeset
   240
    protected:
hgs
parents:
diff changeset
   241
hgs
parents:
diff changeset
   242
hgs
parents:
diff changeset
   243
hgs
parents:
diff changeset
   244
        TUint8                  iElemID;
hgs
parents:
diff changeset
   245
         /**
hgs
parents:
diff changeset
   246
         * Initialize the state of XML element object
hgs
parents:
diff changeset
   247
         *
hgs
parents:
diff changeset
   248
         * @since 1.0
hgs
parents:
diff changeset
   249
         * @param aTagName - A string buffer containing the tag name with which
hgs
parents:
diff changeset
   250
         *                   the element object is being built
hgs
parents:
diff changeset
   251
         * @return None
hgs
parents:
diff changeset
   252
         */
hgs
parents:
diff changeset
   253
        virtual void            InitializeL( const TUint8 aElemID );
hgs
parents:
diff changeset
   254
hgs
parents:
diff changeset
   255
hgs
parents:
diff changeset
   256
hgs
parents:
diff changeset
   257
hgs
parents:
diff changeset
   258
        MXmlElement*            iParentNode;
hgs
parents:
diff changeset
   259
hgs
parents:
diff changeset
   260
        MXmlElement*            iFirstChild;
hgs
parents:
diff changeset
   261
hgs
parents:
diff changeset
   262
        MXmlElement*            iLastChild;
hgs
parents:
diff changeset
   263
hgs
parents:
diff changeset
   264
        MXmlElement*            iNextSibling;
hgs
parents:
diff changeset
   265
hgs
parents:
diff changeset
   266
        MXmlDocument*           iOwnerDocument;
hgs
parents:
diff changeset
   267
hgs
parents:
diff changeset
   268
    public:
hgs
parents:
diff changeset
   269
hgs
parents:
diff changeset
   270
        /**
hgs
parents:
diff changeset
   271
         * A method that performs deep copy for this object
hgs
parents:
diff changeset
   272
         *
hgs
parents:
diff changeset
   273
         * @since 1.0
hgs
parents:
diff changeset
   274
         * @param  None
hgs
parents:
diff changeset
   275
         * @return An MXmlElement pointer to the newly created object
hgs
parents:
diff changeset
   276
         */
hgs
parents:
diff changeset
   277
        MXmlElement* CloneL(MXmlElement* aParentElement);
hgs
parents:
diff changeset
   278
hgs
parents:
diff changeset
   279
        /**
hgs
parents:
diff changeset
   280
         * A method that return integer ID of the element
hgs
parents:
diff changeset
   281
         *
hgs
parents:
diff changeset
   282
         * @since 1.0
hgs
parents:
diff changeset
   283
         * @param  None
hgs
parents:
diff changeset
   284
         * @return An TUint8 value correspondign the ID of the element
hgs
parents:
diff changeset
   285
         */
hgs
parents:
diff changeset
   286
hgs
parents:
diff changeset
   287
        virtual TUint8    ElemID();
hgs
parents:
diff changeset
   288
hgs
parents:
diff changeset
   289
    protected:
hgs
parents:
diff changeset
   290
hgs
parents:
diff changeset
   291
        /**
hgs
parents:
diff changeset
   292
         * Copy this object to an object that is already created and initialized
hgs
parents:
diff changeset
   293
         *
hgs
parents:
diff changeset
   294
         * @since 1.0
hgs
parents:
diff changeset
   295
         * @param aDestElement - A CXmlElementImpl pointer to an object
hgs
parents:
diff changeset
   296
         *                       requiring the copy
hgs
parents:
diff changeset
   297
         * @return None
hgs
parents:
diff changeset
   298
         */
hgs
parents:
diff changeset
   299
        void CopyL( CXmlElementImpl* aDestElement );
hgs
parents:
diff changeset
   300
hgs
parents:
diff changeset
   301
    };
hgs
parents:
diff changeset
   302
hgs
parents:
diff changeset
   303
hgs
parents:
diff changeset
   304
hgs
parents:
diff changeset
   305
#endif