epoc32/include/mw/sendomfragment.h
author William Roberts <williamr@symbian.org>
Wed, 31 Mar 2010 12:33:34 +0100
branchSymbian3
changeset 4 837f303aceeb
parent 2 2fe1408b6811
permissions -rw-r--r--
Current Symbian^3 public API header files (from PDK 3.0.h) This is the epoc32/include tree with the "platform" subtrees removed, and all but a selected few mbg and rsg files removed.

/*
* Copyright (c) 2002-2005 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:        Class implements DOM fragment functionality
*
*/








#ifndef SEN_DOM_FRAGMENT_H
#define SEN_DOM_FRAGMENT_H

//  INCLUDES
#include <SenBaseFragment.h>

// FORWARD DECLARATIONS
class RFileLogger;

// CLASS DECLARATION

/**
* Class implements DOM fragment functionality
* The implementation further extends CSenBaseFragment
* functionality. In DOM fragment, all child elements
* are parsed into separate element objects. This makes
* it possible to reference any child which offer methods
* declared in XML element interface. Any such element
* can also be easily extracted (detached) from this
* root DOM fragmet.
* @lib SenXML.dll
* @since Series60 3.0
*/
class CSenDomFragment : public CSenBaseFragment
    {
    public:  // Constructors and destructor
        
        /**
        * Basic contructor. Should be used only for parsing new fragments etc. 
        * Constructing DomFragments for other use should be done with at least 
        * localname parameter.
        * @since Series60 3.0
        */
        IMPORT_C static CSenDomFragment* NewL();

        /**
        * Basic constructor.
        * @since Series60 3.0
        * @param aElement Element to copy construction data from.
        */
        IMPORT_C static CSenDomFragment* NewL(
            const CSenElement& aElement);

        /**
        * Basic constructor.
        * @since Series60 3.0
        * @param aLocalName is the XML localname of this fragment
        * Leave codes:  
        *       KErrSenInvalidCharacters if aLocalName contains
        *       illegal characters.     
        *       KErrSenZeroLengthDescriptor if aLocalName is zero length.
        */
        IMPORT_C static CSenDomFragment* NewL(const TDesC8& aLocalName);

        /**
        * Basic constructor.
        * @since Series60 3.0
        * @param aNsUri is the XML namespace user of this fragment
        * @param aLocalName is the XML localname of this fragment
        * Leave codes:  
        *       KErrSenInvalidCharacters if aLocalName contains
        *       illegal characters.     
        *       KErrSenZeroLengthDescriptor if aLocalName is zero length.
        */
        IMPORT_C static CSenDomFragment* NewL(const TDesC8& aNsUri,
                                              const TDesC8& aLocalName);

        /**
        * Basic constructor.
        * @since Series60 3.0
        * @param aNsUri is the XML namespace user of this fragment
        * @param aLocalName is the XML localname of this fragment
        * @param aQName is the XML qualifiedname of this fragment
        * Leave codes:  
        *       KErrSenInvalidCharacters if aLocalName or aQName contains
        *       illegal characters.     
        *       KErrSenZeroLengthDescriptor if aLocalName or aQName is zero length.
        */
        IMPORT_C static CSenDomFragment* NewL(const TDesC8& aNsUri,
                                              const TDesC8& aLocalName,
                                              const TDesC8& aQName);

        /**
        * Basic constructor.
        * @since Series60 3.0
        * @param aNsUri is the XML namespace of this fragment
        * @param aLocalName is the XML localname of this fragment
        * @param aQName is the qualifiedname of this fragment
        * @param aAttrs are the XML attributes of this fragment
        * Leave codes:  
        *       KErrSenInvalidCharacters if aLocalName or aQName contains
        *       illegal characters.     
        *       KErrSenZeroLengthDescriptor if aLocalName or aQName is zero length.
        */
        IMPORT_C static CSenDomFragment* NewL(const TDesC8& aNsUri,
                                              const TDesC8& aLocalName,
                                              const TDesC8& aQName,
                                              const RAttributeArray& aAttrs);

        /**
        * Basic constructor.
        * @since Series60 3.0
        * @param aNsUri is the XML namespace of this fragment
        * @param aLocalName is the XML localname of this fragment
        * @param aQName is the qualifiedname of this fragment
        * @param aAttrs are the XML attributes of this fragment
        * @param aParent is the parent XML element of this fragment
        * Leave codes:  
        *       KErrSenInvalidCharacters if aLocalName or aQName contains
        *       illegal characters.     
        *       KErrSenZeroLengthDescriptor if aLocalName or aQName is zero length.
        */
        IMPORT_C static CSenDomFragment* NewL(const TDesC8& aNsUri,
                                              const TDesC8& aLocalName,
                                              const TDesC8& aQName,
                                              const RAttributeArray& aAttrs,
                                              CSenElement& aParent);

        /**
        * Destructor.
        */
        IMPORT_C virtual ~CSenDomFragment();

        // New functions
    
        /**
        * Initiates the parsing chain where new delegate will be created with
        * given parameters and parsing will be delegated to it. Should not be
        * called externally.
        * @since Series60 3.0
        * @param aNsUri     The namespace URI of the new element
        * @param aLocalName The local name of the new element
        * @param aQName     The qualified name of the new element
        * @param aAttrs     The attributes of the new element
        */
        IMPORT_C virtual void ExpandL(const TDesC8& aNsUri,
                                      const TDesC8& aLocalName,
                                      const TDesC8& aQName,
                                      const RAttributeArray& aAttrs);
                                      
        // Functions from base classes

        // From CSenBaseFragment
        
        /**
        * Resumes the parsing. Usually called by the delegate fragment which was
        *                       parsing itself after DelegateParsingL().
        * @since Series60 3.0
        * @param aNsUri     The namespace URI of the current element
        * @param aLocalName The local name of the current element
        * @param aQName     The qualified name of the current element
        */
        IMPORT_C void ResumeParsingFromL(const TDesC8& aNsUri,
                                         const TDesC8& aLocalName,
                                         const TDesC8& aQName);

        /**
        * Sets the reader for this fragment and sets this to be the 
        * content handler of the following SAX events.
        * @since Series60 3.0
        * @param aReader:   Reader to be used.
        */
        IMPORT_C virtual void ParseWithL(CSenXmlReader& aReader);

        /**
        * Sets the attributes for the fragment.
        * @since Series60 3.0
        * @param aAttrs the array of attributes.
        */
        IMPORT_C virtual void SetAttributesL(const RAttributeArray& aAttrs);

    protected:  
        
        /**
        * C++ default constructor.
        */
        IMPORT_C CSenDomFragment();

        /**
        * "ConstructL" method for calling the base classes ones.
        * @since Series60 3.0
        * @param aElement is the XML element of this fragment.
        */
        IMPORT_C void BaseConstructL(const CSenElement& aElement);

        /**
        * "ConstructL" method for calling the base classes ones.
        * @since Series60 3.0
        * @param aLocalName The local name of the element
        */
        IMPORT_C void BaseConstructL(const TDesC8& aLocalName);

        /**
        * "ConstructL" method for calling the base classes ones.
        * @since Series60 3.0
        * @param aNsUri     The namespace URI of the element
        * @param aLocalName The local name of the element
        */
        IMPORT_C void BaseConstructL(const TDesC8& aNsUri,
                                     const TDesC8& aLocalName);

        /**
        * "ConstructL" method for calling the base classes ones.
        * @since Series60 3.0
        * @param aNsUri     The namespace URI of the element
        * @param aLocalName The local name of the element
        * @param aQName     The qualified name of the element
        */
        IMPORT_C void BaseConstructL(const TDesC8& aNsUri,
                                     const TDesC8& aLocalName,
                                     const TDesC8& aQName);

        /**
        * "ConstructL" method for calling the base classes ones.
        * @since Series60 3.0
        * @param aNsUri     The namespace URI of the element
        * @param aLocalName The local name of the element
        * @param aQName     The qualified name of the element
        * @param aAttrs     The attributes of the element
        */
        IMPORT_C void BaseConstructL(const TDesC8& aNsUri,
                                     const TDesC8& aLocalName,
                                     const TDesC8& aQName,
                                     const RAttributeArray& aAttrs);

        /**
        * "ConstructL" method for calling the base classes ones.
        * @since Series60 3.0
        * @param aNsUri     The namespace URI of the element
        * @param aLocalName The local name of the element
        * @param aQName     The qualified name of the element
        * @param aAttrs     The attributes of the element
        * @param aParent    The parent of the element
        */
        IMPORT_C void BaseConstructL(const TDesC8& aNsUri,
                                     const TDesC8& aLocalName,
                                     const TDesC8& aQName,
                                     const RAttributeArray& aAttrs,
                                     CSenElement& aParent);

        /**
        * "ConstructL" method for calling the base classes ones.
        * @since Series60 3.0
        * @param aReader is the XML reader for this fragment.
        */
        IMPORT_C void BaseConstructL(CSenXmlReader& aReader);
        
        // Functions from base classes
        
        /**
         *  Callback functions which implement the XML content handler interface.
         *  Inheriting classes can override these.
         */
         
        // From CSenBaseFragment 
        
        /**
        * @since Series60 3.0
        * @param aNsUri     The namespace URI of the element
        * @param aLocalName The local name of the element
        * @param aQName     The qualified name of the element
        * @param aAttrs     The attributes of the element
        */
        IMPORT_C virtual void StartElementL(const TDesC8& aNsUri,
                                            const TDesC8& aLocalName,
                                            const TDesC8& aQName,
                                            const RAttributeArray& aAttrs);
        
        /**
        * Callback functions which implement the XML content handler interface.
        * This one is called when content is starting.
        * @since Series60 3.0
        * @param aChars     The content characters.
        * @param aStart     The starting index
        * @param aLength    The length of the characters.
        */
        IMPORT_C virtual void CharactersL(const TDesC8& aChars,TInt aStart,TInt aLength);

        /**
        * Overriding content writing from CSenBaseFragment to do nothing in
        * DOM fragment (because the tree is expanded).
        * @since Series60 3.0
        * @param aNsUri     not used
        * @param aLocalName not used
        * @param aQName     not used
        * @param aAttrs     not used
        */
        IMPORT_C void WriteStartElementL(const TDesC8& aNsUri,
                                         const TDesC8& aLocalName,
                                         const TDesC8& aQName,
                                         const RAttributeArray& aAttrs);

        /**
        * Overriding content writing from CSenBaseFragment to do nothing in
        * DOM fragment (because the tree is expanded).
        * @since Series60 3.0
        * @param aNsUri     not used
        * @param aLocalName not used
        * @param aQName     not used
        */
        IMPORT_C void WriteEndElementL(const TDesC8& aNsUri,
                                       const TDesC8& aLocalName,
                                       const TDesC8& aQName);

    protected: // Data
        CSenDomFragment* ipDomDelegate;
    };

#endif //SEN_DOM_FRAGMENT_H

// End of File