upnpavcontroller/upnpxmlparser/inc/upnpxmlparser.h
branchnew development branch with rendering state machine and other goodies
changeset 38 5360b7ddc251
parent 0 7f85d04be362
--- a/upnpavcontroller/upnpxmlparser/inc/upnpxmlparser.h	Fri Sep 17 08:31:21 2010 +0300
+++ b/upnpavcontroller/upnpxmlparser/inc/upnpxmlparser.h	Mon Nov 01 12:37:49 2010 +0200
@@ -1,273 +1,269 @@
-/*
-* Copyright (c) 2006-2007 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:      XML SAX Parser for UPnP.
-*
-*/
-
-
-
-
-
-
-#ifndef C_UPNPXMLPARSER_H_
-#define C_UPNPXMLPARSER_H_
-
-// INCLUDES
-#include <e32base.h>
-#include <xml/contenthandler.h>
-
-// FORWARD DECLARATIONS
-class CUpnpObject;
-class CUPnPObjectStack; 
-class CUpnpElement;
-class CUpnpItem;
-class CUpnpContainer;
-
-using namespace Xml;
-
-/**
- * XML SAX Parser for UPnP.
- *
- * @since s60 3.1
- * @lib upnpxmlparser.lib
- */
-class CUPnPXMLParser :  public CBase,
-                        public MContentHandler
-    {
-
-public:
-
-    /**
-     * 2-phased constructor.
-     */
-    IMPORT_C static CUPnPXMLParser* NewL();
-    
-    /**
-     * 2-phased constructor.
-     */
-    IMPORT_C static CUPnPXMLParser* NewLC();
-    
-    /**
-     * Destructor.
-     */
-    virtual ~CUPnPXMLParser();
-    
-public:
-
-    /**
-     * Parses xml data to the array of objects.
-     * @param aResultArray, An array for objects in xml root.
-     * @param aData, xml data.
-     */
-    IMPORT_C void ParseResultDataL( RPointerArray<CUpnpObject>& aResultArray,
-        const TDesC8& aData );
-        
-    /**
-     * Creates an xml document from a given item 
-     *
-     * @param aItem item to convert
-     * @return xml document as a heap descriptor
-     */
-    IMPORT_C static HBufC8* ItemAsXmlLC( const CUpnpItem& aItem );
-
-    /**
-     * Creates an xml document from a given item, for CreateObject-action. 
-     *
-     * @param aItem item to convert
-     * @return xml document as a heap descriptor
-     */
-    IMPORT_C static HBufC8* XmlForCreateObjectLC( const CUpnpItem& aItem );
-
-    /**
-     * Creates an xml document from a given item container
-     *
-     * @param aContainer container to convert
-     * @return xml document as a heap descriptor
-     */
-    IMPORT_C static HBufC8* ContainerToXmlLC( 
-                                    const CUpnpContainer& aContainer );
-            
-protected: // from MContentHandler
-
-    /**
-     * From MContentHandler.
-     * @param aDocParam, not used.
-     * @param aErrorCode, not used.
-     */
-    void OnStartDocumentL( const RDocumentParameters& aDocParam, 
-                           TInt aErrorCode );
-    
-    /**
-     * From MContentHandler.
-     * @param aErrorCode, not used.
-     */
-    void OnEndDocumentL( TInt aErrorCode );
-    
-    /**
-     * From MContentHandler.
-     * @param aElement, holds the element info.
-     * @param aAttributes, holds the element's attributes.
-     * @param aErrorCode, if not KErrNone, the method is ignored.
-     */
-    void OnStartElementL( const RTagInfo& aElement, 
-                          const RAttributeArray& aAttributes, 
-                          TInt aErrorCode );
-    
-    /**
-     * From MContentHandler.
-     * @param aElement, holds the element info.
-     * @param aErrorCode, if not KErrNone, the method is ignored.
-     */
-    void OnEndElementL( const RTagInfo& aElement, TInt aErrorCode );
-    
-    /**
-     * From MContentHandler.
-     * @param aBytes, The value of the content.
-     * @param aErrorCode, if not KErrNone, the method is ignored.
-     */
-    void OnContentL( const TDesC8& aBytes, TInt aErrorCode );
-    
-    /**
-     * From MContentHandler.
-     * @param aPrefix, not used.
-     * @param aUri, not used.
-     * @param aErrorCode, not used.
-     */    
-    void OnStartPrefixMappingL( const RString& aPrefix, 
-                                const RString& aUri, 
-                                TInt aErrorCode );
-    
-    /**
-     * From MContentHandler.
-     * @param aPrefix, not used.
-     * @param aErrorCode, not used.
-     */
-    void OnEndPrefixMappingL( const RString& aPrefix, TInt aErrorCode );
-    
-    /**
-     * From MContentHandler.
-     * @param aBytes, not used.
-     * @param aErrorCode, not used.
-     */
-    void OnIgnorableWhiteSpaceL( const TDesC8& aBytes, TInt aErrorCode );
-    
-    /**
-     * From MContentHandler.
-     * @param aName, not used.
-     * @param aErrorCode, not used.
-     */
-    void OnSkippedEntityL( const RString& aName, TInt aErrorCode );
-    
-    /**
-     * From MContentHandler.
-     * @param aTarget, not used.
-     * @param aData, not used.
-     * @param aErrorCode, not used. 
-     */
-    void OnProcessingInstructionL( const TDesC8& aTarget, 
-                                   const TDesC8& aData, 
-                                   TInt aErrorCode );
-    
-    /**
-     * From MContentHandler.
-     * @param aErrorCode
-     */                               
-    void OnError( TInt aErrorCode );
-    
-    /**
-     * From MContentHandler.
-     * @param aUid, not used.
-     * @return None.
-     */
-    TAny* GetExtendedInterface( const TInt32 aUid );
-
-                                    
-private:
-
-    /**
-     * Constructor.
-     */
-    CUPnPXMLParser();
-    
-    /**
-     * 2nd phase constructor.
-     */
-    void ConstructL();
-    
-private: 
-
-    /**
-     * Sets element's attributes to the object.
-     *
-     * @param aObject attributes will be set to this object
-     * @param aAttributes attributes to set
-     */
-    void SetAttributesL( CUpnpObject& aObject, 
-                         const RAttributeArray& aAttributes );
-                             
-    /**
-     * Set value to a element
-     * 
-     * @since Series 60 3.1
-     * @param aItem (CUpnpObject&) a item which owns the element
-     * @param aValue element value
-     */
-    void SetValueToElementL( CUpnpObject& aItem,
-        const TDesC8& aValue );
-        
-    /**
-     * Sets element's attributes to the element
-     *
-     * @param aElement attributes will be set to this element
-     * @param aAttributes attributes to set
-     */
-    void SetAttributesL( const RAttributeArray& aAttributes ); 
-
-    /**
-     * Reset member for parse again.
-     */
-	void ResetMember();
-private: // data
-
-    /**
-     * A pointer to result array from the client.
-     * Not own.
-     */      
-    RPointerArray<CUpnpObject>* iResultRoot;
-    
-    /**
-     * A stack for UPnP objects.
-     * Own.
-     */
-    CUPnPObjectStack*           iStack;
-    
-    /**
-     * Element value
-     * Own.
-     */
-    HBufC8*                     iElementValue;
-        
-    /**
-     * Upnp element
-     * Owned until ownership is transferred for an object
-     */
-    CUpnpElement*               iNewElement;
-    
-    TBool                       iTitle;
-    TBool                       iObjectClass;
-    };
-
-#endif // C_UPNPXMLPARSER_H_
-
-// End of File
+/*
+* Copyright (c) 2006-2007,2009 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:      XML SAX Parser for UPnP.
+*
+*/
+
+#ifndef C_UPNPXMLPARSER_H_
+#define C_UPNPXMLPARSER_H_
+
+// INCLUDES
+#include <e32base.h>
+#include <xml/contenthandler.h>
+
+// FORWARD DECLARATIONS
+class CUpnpObject;
+class CUPnPObjectStack; 
+class CUpnpElement;
+class CUpnpItem;
+class CUpnpContainer;
+
+using namespace Xml;
+
+/**
+ * XML SAX Parser for UPnP.
+ *
+ * @since s60 3.1
+ * @lib upnpxmlparser.lib
+ */
+class CUPnPXMLParser :  public CBase,
+                        public MContentHandler
+    {
+
+public:
+
+    /**
+     * 2-phased constructor.
+     */
+    IMPORT_C static CUPnPXMLParser* NewL();
+    
+    /**
+     * 2-phased constructor.
+     */
+    IMPORT_C static CUPnPXMLParser* NewLC();
+    
+    /**
+     * Destructor.
+     */
+    virtual ~CUPnPXMLParser();
+    
+public:
+
+    /**
+     * Parses xml data to the array of objects.
+     * @param aResultArray, An array for objects in xml root.
+     * @param aData, xml data.
+     */
+    IMPORT_C void ParseResultDataL( RPointerArray<CUpnpObject>& aResultArray,
+        const TDesC8& aData );
+        
+    /**
+     * Creates an xml document from a given item 
+     *
+     * @param aItem item to convert
+     * @return xml document as a heap descriptor
+     */
+    IMPORT_C static HBufC8* ItemAsXmlLC( const CUpnpItem& aItem );
+
+    /**
+     * Creates an xml document from a given item, for CreateObject-action. 
+     *
+     * @param aItem item to convert
+     * @return xml document as a heap descriptor
+     */
+    IMPORT_C static HBufC8* XmlForCreateObjectLC( const CUpnpItem& aItem );
+
+    /**
+     * Creates an xml document from a given item container
+     *
+     * @param aContainer container to convert
+     * @return xml document as a heap descriptor
+     */
+    IMPORT_C static HBufC8* ContainerToXmlLC( 
+                                    const CUpnpContainer& aContainer );
+            
+protected: // from MContentHandler
+
+    /**
+     * From MContentHandler.
+     * @param aDocParam, not used.
+     * @param aErrorCode, not used.
+     */
+    void OnStartDocumentL( const RDocumentParameters& aDocParam, 
+                           TInt aErrorCode );
+    
+    /**
+     * From MContentHandler.
+     * @param aErrorCode, not used.
+     */
+    void OnEndDocumentL( TInt aErrorCode );
+    
+    /**
+     * From MContentHandler.
+     * @param aElement, holds the element info.
+     * @param aAttributes, holds the element's attributes.
+     * @param aErrorCode, if not KErrNone, the method is ignored.
+     */
+    void OnStartElementL( const RTagInfo& aElement, 
+                          const RAttributeArray& aAttributes, 
+                          TInt aErrorCode );
+    
+    /**
+     * From MContentHandler.
+     * @param aElement, holds the element info.
+     * @param aErrorCode, if not KErrNone, the method is ignored.
+     */
+    void OnEndElementL( const RTagInfo& aElement, TInt aErrorCode );
+    
+    /**
+     * From MContentHandler.
+     * @param aBytes, The value of the content.
+     * @param aErrorCode, if not KErrNone, the method is ignored.
+     */
+    void OnContentL( const TDesC8& aBytes, TInt aErrorCode );
+    
+    /**
+     * From MContentHandler.
+     * @param aPrefix, not used.
+     * @param aUri, not used.
+     * @param aErrorCode, not used.
+     */    
+    void OnStartPrefixMappingL( const RString& aPrefix, 
+                                const RString& aUri, 
+                                TInt aErrorCode );
+    
+    /**
+     * From MContentHandler.
+     * @param aPrefix, not used.
+     * @param aErrorCode, not used.
+     */
+    void OnEndPrefixMappingL( const RString& aPrefix, TInt aErrorCode );
+    
+    /**
+     * From MContentHandler.
+     * @param aBytes, not used.
+     * @param aErrorCode, not used.
+     */
+    void OnIgnorableWhiteSpaceL( const TDesC8& aBytes, TInt aErrorCode );
+    
+    /**
+     * From MContentHandler.
+     * @param aName, not used.
+     * @param aErrorCode, not used.
+     */
+    void OnSkippedEntityL( const RString& aName, TInt aErrorCode );
+    
+    /**
+     * From MContentHandler.
+     * @param aTarget, not used.
+     * @param aData, not used.
+     * @param aErrorCode, not used. 
+     */
+    void OnProcessingInstructionL( const TDesC8& aTarget, 
+                                   const TDesC8& aData, 
+                                   TInt aErrorCode );
+    
+    /**
+     * From MContentHandler.
+     * @param aErrorCode
+     */                               
+    void OnError( TInt aErrorCode );
+    
+    /**
+     * From MContentHandler.
+     * @param aUid, not used.
+     * @return None.
+     */
+    TAny* GetExtendedInterface( const TInt32 aUid );
+
+                                    
+private:
+
+    /**
+     * Constructor.
+     */
+    CUPnPXMLParser();
+    
+    /**
+     * 2nd phase constructor.
+     */
+    void ConstructL();
+    
+private: 
+
+    /**
+     * Sets element's attributes to the object.
+     *
+     * @param aObject attributes will be set to this object
+     * @param aAttributes attributes to set
+     */
+    void SetAttributesL( CUpnpObject& aObject, 
+                         const RAttributeArray& aAttributes );
+                             
+    /**
+     * Set value to a element
+     * 
+     * @since Series 60 3.1
+     * @param aItem (CUpnpObject&) a item which owns the element
+     * @param aValue element value
+     */
+    void SetValueToElementL( CUpnpObject& aItem,
+        const TDesC8& aValue );
+        
+    /**
+     * Sets element's attributes to the element
+     *
+     * @param aElement attributes will be set to this element
+     * @param aAttributes attributes to set
+     */
+    void SetAttributesL( const RAttributeArray& aAttributes ); 
+
+    /**
+     * Reset member for parse again.
+     */
+    void ResetMember();
+
+private: // data
+
+    /**
+     * A pointer to result array from the client.
+     * Not own.
+     */      
+    RPointerArray<CUpnpObject>* iResultRoot;
+    
+    /**
+     * A stack for UPnP objects.
+     * Own.
+     */
+    CUPnPObjectStack*           iStack;
+    
+    /**
+     * Element value
+     * Own.
+     */
+    HBufC8*                     iElementValue;
+        
+    /**
+     * Upnp element
+     * Owned until ownership is transferred for an object
+     */
+    CUpnpElement*               iNewElement;
+    
+    TBool                       iTitle;
+    TBool                       iObjectClass;
+    };
+
+#endif // C_UPNPXMLPARSER_H_
+
+// End of File