epoc32/include/xml/dom/xmlengdomparser.h
author William Roberts <williamr@symbian.org>
Wed, 31 Mar 2010 12:27:01 +0100
branchSymbian2
changeset 3 e1b950c65cb4
parent 2 epoc32/include/xmlengdomparser.h@2fe1408b6811
child 4 837f303aceeb
permissions -rw-r--r--
Attempt to represent the S^2->S^3 header reorganisation as a series of "hg rename" operations
williamr@2
     1
/*
williamr@2
     2
* Copyright (c) 2004-2006 Nokia Corporation and/or its subsidiary(-ies). 
williamr@2
     3
* All rights reserved.
williamr@2
     4
* This component and the accompanying materials are made available
williamr@2
     5
* under the terms of the License "Symbian Foundation License v1.0" to Symbian Foundation members and "Symbian Foundation End User License Agreement v1.0" to non-members
williamr@2
     6
* which accompanies this distribution, and is available
williamr@2
     7
* at the URL "http://www.symbianfoundation.org/legal/licencesv10.html".
williamr@2
     8
*
williamr@2
     9
* Initial Contributors:
williamr@2
    10
* Nokia Corporation - initial contribution.
williamr@2
    11
*
williamr@2
    12
* Contributors:
williamr@2
    13
*
williamr@2
    14
* Description:       DOM parser functions
williamr@2
    15
*
williamr@2
    16
*/
williamr@2
    17
williamr@2
    18
williamr@2
    19
williamr@2
    20
williamr@2
    21
williamr@2
    22
williamr@2
    23
williamr@2
    24
#ifndef XMLENGINE_DOMPARSER_H_INCLUDED
williamr@2
    25
#define XMLENGINE_DOMPARSER_H_INCLUDED
williamr@2
    26
williamr@2
    27
#include <f32file.h>
williamr@2
    28
williamr@2
    29
class RXmlEngDOMImplementation;
williamr@2
    30
class RXmlEngDocument;
williamr@2
    31
williamr@2
    32
/** 
williamr@2
    33
 * DOM parser class implements methods for parsing XML data.
williamr@2
    34
 *
williamr@2
    35
 * Parse XML data in one chunk. Data can be parsed from file 
williamr@2
    36
 * or memory buffer.
williamr@2
    37
 *
williamr@2
    38
 * Sample code for parsing from buffer:
williamr@2
    39
 * @code
williamr@2
    40
 *      RXmlEngDOMImplementation domImpl;
williamr@2
    41
 *      domImpl.OpenL();              ///< opening DOM implementation object 
williamr@2
    42
 *      RXmlEngDOMParser parser;
williamr@2
    43
 *      parser.Open( domImpl );   ///< opening parser object
williamr@2
    44
 *      RXmlEngDocument iDoc;
williamr@2
    45
 *      iDoc =parser.ParseL( *aInput );   ///< parsing aInput - buffer  
williamr@2
    46
 *      iDoc.Close();               ///< closing all opened objects
williamr@2
    47
 *      parser.Close();
williamr@2
    48
 *      domImpl.Close();
williamr@2
    49
 * @endcode 
williamr@2
    50
 * 
williamr@2
    51
 * Sample code for parsing from file:
williamr@2
    52
 * @code
williamr@2
    53
 *      RXmlEngDOMImplementation domImpl;
williamr@2
    54
 *      domImpl.OpenL();              ///< opening DOM implementation object 
williamr@2
    55
 *      RXmlEngDOMParser parser;
williamr@2
    56
 *      parser.Open( domImpl );   ///< opening parser object
williamr@2
    57
 *      RXmlEngDocument iDoc;
williamr@2
    58
 *      iDoc =parser.ParseFileL( aFileName );   ///< parsing from file  
williamr@2
    59
 *      iDoc.Close();               ///< closing all openend objects
williamr@2
    60
 *      parser.Close();
williamr@2
    61
 *      domImpl.Close();
williamr@2
    62
 * @endcode 
williamr@2
    63
 * 
williamr@2
    64
 * @lib XmlEngineDOM.lib
williamr@2
    65
 * @since S60 v3.1
williamr@2
    66
 */
williamr@2
    67
class RXmlEngDOMParser
williamr@2
    68
{
williamr@2
    69
public:
williamr@2
    70
    /**
williamr@2
    71
     * Default constructor
williamr@2
    72
     */
williamr@2
    73
    IMPORT_C RXmlEngDOMParser();
williamr@2
    74
	
williamr@2
    75
    /** 
williamr@2
    76
     * Opens the parser.
williamr@2
    77
     *
williamr@2
    78
	 * @since S60 v3.2
williamr@2
    79
	 * @param aDOMImpl DOM implementation object
williamr@2
    80
     * @return KErrNone if succeed.
williamr@2
    81
     */
williamr@2
    82
    IMPORT_C TInt Open(RXmlEngDOMImplementation& aDOMImpl);
williamr@2
    83
    
williamr@2
    84
    /** 
williamr@2
    85
     * Closes the parser.
williamr@2
    86
     *
williamr@2
    87
	 * @since S60 v3.2
williamr@2
    88
	 */
williamr@2
    89
    IMPORT_C void Close();
williamr@2
    90
williamr@2
    91
    /** 
williamr@2
    92
     * Parses chunk of XML data from memory buffer and builds DOM RXmlEngDocument.
williamr@2
    93
     *
williamr@2
    94
     * @since S60 v3.2
williamr@2
    95
     * @param aBuffer XML data buffer
williamr@2
    96
     * 
williamr@2
    97
     * @leave KXmlEngErrParsing or one of general codes (e.g. KErrNoMemory)
williamr@2
    98
     */
williamr@2
    99
    IMPORT_C void ParseChunkL(const TDesC8& aBuffer);
williamr@2
   100
    /** 
williamr@2
   101
     * Creates document from parsed chunks of data.
williamr@2
   102
     * Should be called after parsing of allchunks.
williamr@2
   103
     * Ownership over returned RXmlEngDocument object is transferred to the caller of the method.
williamr@2
   104
     *
williamr@2
   105
     * @since S60 v3.2
williamr@2
   106
     * @return RXmlEngDocument created document.
williamr@2
   107
     * 
williamr@2
   108
     * @leave KXmlEngErrParsing or one of general codes (e.g. KErrNoMemory)
williamr@2
   109
     */
williamr@2
   110
    IMPORT_C RXmlEngDocument FinishL();
williamr@2
   111
    
williamr@2
   112
    /** 
williamr@2
   113
     * Parses XML file and builds DOM RXmlEngDocument
williamr@2
   114
     *
williamr@2
   115
     * @since S60 v3.2
williamr@2
   116
	 * @param aRFs File server session
williamr@2
   117
     * @param aFileName File name
williamr@2
   118
     * @param aChunkSize Size of chunk (if 0 chunks won't be used)
williamr@2
   119
     * @return Document handle
williamr@2
   120
     * 
williamr@2
   121
     * @leave KXmlEngErrParsing or one of general codes (e.g. KErrNoMemory)
williamr@2
   122
	 */
williamr@2
   123
    IMPORT_C RXmlEngDocument ParseFileL(RFs &aRFs, const TDesC& aFileName, TUint aChunkSize = 0);
williamr@2
   124
williamr@2
   125
    /** 
williamr@2
   126
     * Parses XML file and builds DOM RXmlEngDocument
williamr@2
   127
     *
williamr@2
   128
     * @since S60 v3.2
williamr@2
   129
	 * @param aFileName File name
williamr@2
   130
     * @param aChunkSize Size of chunk (if 0 chunks won't be used)
williamr@2
   131
     * @return Document handle
williamr@2
   132
     * 
williamr@2
   133
     * @leave KXmlEngErrParsing or one of general codes (e.g. KErrNoMemory)
williamr@2
   134
     */
williamr@2
   135
    IMPORT_C RXmlEngDocument ParseFileL(const TDesC& aFileName, TUint aChunkSize = 0);
williamr@2
   136
williamr@2
   137
    /** 
williamr@2
   138
     * Parses XML data from memory buffer and builds DOM RXmlEngDocument without chunks
williamr@2
   139
     *
williamr@2
   140
	 * @since S60 v3.1
williamr@2
   141
	 * @param aBuffer XML data buffer
williamr@2
   142
     * @return Document handle
williamr@2
   143
     * 
williamr@2
   144
     * @leave KXmlEngErrParsing code (besides system I/O error codes)
williamr@2
   145
     */
williamr@2
   146
    IMPORT_C RXmlEngDocument ParseL(const TDesC8& aBuffer);  
williamr@2
   147
williamr@2
   148
    /** 
williamr@2
   149
     * Return last parsing error code. 
williamr@2
   150
     *
williamr@2
   151
     * @since S60 v3.2
williamr@2
   152
	 * @return positive number
williamr@2
   153
     *
williamr@2
   154
     * @note Error codes are positive numbers. User can find them
williamr@2
   155
     *         in XmlEngDErrors.h
williamr@2
   156
     */
williamr@2
   157
    IMPORT_C TInt GetLastParsingError();
williamr@2
   158
private:
williamr@2
   159
    /** 
williamr@2
   160
     * Parses XML file and builds DOM RXmlEngDocument without usage of chunks
williamr@2
   161
     *
williamr@2
   162
     * @param aRFs File server session
williamr@2
   163
     * @param aFileName File name
williamr@2
   164
     * @return Document handle
williamr@2
   165
     * 
williamr@2
   166
     * @leave KXmlEngErrParsing code (besides system I/O error codes)
williamr@2
   167
	 */
williamr@2
   168
    RXmlEngDocument ParseFileWithoutChunksL(RFs& aRFs, const TDesC& aFileName);
williamr@2
   169
williamr@2
   170
    /** 
williamr@2
   171
     * Cleanup internal data.
williamr@2
   172
     *
williamr@2
   173
     * @since S60 v3.2
williamr@2
   174
     */
williamr@2
   175
    void Cleanup();
williamr@2
   176
private:
williamr@2
   177
    void* iInternal;
williamr@2
   178
    TInt iError;
williamr@2
   179
    RXmlEngDOMImplementation* iImpl;
williamr@2
   180
};
williamr@2
   181
williamr@2
   182
williamr@2
   183
williamr@2
   184
#endif /* XMLENGINE_DOMPARSER_H_INCLUDED */