summaryrefslogtreecommitdiff
path: root/unoxml/source/dom/saxbuilder.hxx
diff options
context:
space:
mode:
Diffstat (limited to 'unoxml/source/dom/saxbuilder.hxx')
-rw-r--r--unoxml/source/dom/saxbuilder.hxx153
1 files changed, 153 insertions, 0 deletions
diff --git a/unoxml/source/dom/saxbuilder.hxx b/unoxml/source/dom/saxbuilder.hxx
new file mode 100644
index 000000000000..454b22f2d457
--- /dev/null
+++ b/unoxml/source/dom/saxbuilder.hxx
@@ -0,0 +1,153 @@
+/*************************************************************************
+ *
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * Copyright 2008 by Sun Microsystems, Inc.
+ *
+ * OpenOffice.org - a multi-platform office productivity suite
+ *
+ * $RCSfile: saxbuilder.hxx,v $
+ * $Revision: 1.7 $
+ *
+ * This file is part of OpenOffice.org.
+ *
+ * OpenOffice.org is free software: you can redistribute it and/or modify
+ * it under the terms of the GNU Lesser General Public License version 3
+ * only, as published by the Free Software Foundation.
+ *
+ * OpenOffice.org is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU Lesser General Public License version 3 for more details
+ * (a copy is included in the LICENSE file that accompanied this code).
+ *
+ * You should have received a copy of the GNU Lesser General Public License
+ * version 3 along with OpenOffice.org. If not, see
+ * <http://www.openoffice.org/license.html>
+ * for a copy of the LGPLv3 License.
+ *
+ ************************************************************************/
+
+#ifndef _SAXBUILDER_HXX
+#define _SAXBUILDER_HXX
+
+#include <stack>
+#include <map>
+
+#include <sal/types.h>
+#include <cppuhelper/implbase3.hxx>
+#include <com/sun/star/uno/Reference.h>
+#include <com/sun/star/uno/Sequence.h>
+
+#include <com/sun/star/uno/XInterface.hpp>
+#include <com/sun/star/uno/Exception.hpp>
+#include <com/sun/star/xml/dom/XSAXDocumentBuilder.hpp>
+#include <com/sun/star/xml/dom/SAXDocumentBuilderState.hpp>
+#include <com/sun/star/xml/dom/XDocument.hpp>
+#include <com/sun/star/xml/dom/XDocumentFragment.hpp>
+#include <com/sun/star/xml/sax/XDocumentHandler.hpp>
+#include <com/sun/star/xml/sax/XLocator.hpp>
+#include <com/sun/star/xml/sax/XAttributeList.hpp>
+#include <com/sun/star/lang/XServiceInfo.hpp>
+#include <com/sun/star/lang/XSingleServiceFactory.hpp>
+#include <com/sun/star/lang/XMultiServiceFactory.hpp>
+
+#include "libxml/tree.h"
+
+using ::rtl::OUString;
+using namespace com::sun::star::uno;
+using namespace com::sun::star::xml::dom;
+using namespace com::sun::star::xml::sax;
+
+using com::sun::star::lang::XServiceInfo;
+using com::sun::star::lang::XSingleServiceFactory;
+using com::sun::star::lang::XMultiServiceFactory;
+
+namespace DOM
+{
+
+ typedef std::stack< Reference< XNode > > NodeStack;
+ typedef std::map< OUString, OUString > NSMap;
+ typedef std::map< OUString, OUString > AttrMap;
+ typedef std::stack< NSMap > NSStack;
+
+ class CSAXDocumentBuilder
+ : public ::cppu::WeakImplHelper3< XDocumentHandler, XSAXDocumentBuilder, XServiceInfo >
+ {
+
+ private:
+ const Reference< XMultiServiceFactory > m_aServiceManager;
+
+ SAXDocumentBuilderState m_aState;
+ NodeStack m_aNodeStack;
+ NSStack m_aNSStack;
+
+ OUString resolvePrefix(const OUString& aPrefix);
+
+ Reference< XDocument > m_aDocument;
+ Reference< XDocumentFragment > m_aFragment;
+ Reference< XLocator > m_aLocator;
+
+
+ public:
+
+ // call for factory
+ static Reference< XInterface > getInstance(const Reference < XMultiServiceFactory >& xFactory);
+
+ // static helpers for service info and component management
+ static const char* aImplementationName;
+ static const char* aSupportedServiceNames[];
+ static OUString _getImplementationName();
+ static Sequence< OUString > _getSupportedServiceNames();
+ static Reference< XInterface > _getInstance(const Reference< XMultiServiceFactory >& rSMgr);
+
+ CSAXDocumentBuilder(const Reference< XMultiServiceFactory >& mgr);
+
+ // XServiceInfo
+ virtual OUString SAL_CALL getImplementationName()
+ throw (RuntimeException);
+ virtual sal_Bool SAL_CALL supportsService(const OUString& ServiceName)
+ throw (RuntimeException);
+ virtual Sequence< OUString > SAL_CALL getSupportedServiceNames ()
+ throw (RuntimeException);
+
+ // XDocumentHandler
+ virtual void SAL_CALL startDocument()
+ throw( RuntimeException, com::sun::star::xml::sax::SAXException );
+ virtual void SAL_CALL endDocument()
+ throw( RuntimeException, com::sun::star::xml::sax::SAXException );
+ virtual void SAL_CALL startElement( const OUString& aName,
+ const Reference< XAttributeList >& xAttribs )
+ throw( RuntimeException, com::sun::star::xml::sax::SAXException );
+ virtual void SAL_CALL endElement( const OUString& aName )
+ throw( RuntimeException, com::sun::star::xml::sax::SAXException );
+ virtual void SAL_CALL characters( const OUString& aChars )
+ throw( RuntimeException, com::sun::star::xml::sax::SAXException );
+ virtual void SAL_CALL ignorableWhitespace( const OUString& aWhitespaces )
+ throw( RuntimeException, com::sun::star::xml::sax::SAXException );
+ virtual void SAL_CALL processingInstruction( const OUString& aTarget,
+ const OUString& aData )
+ throw( RuntimeException, com::sun::star::xml::sax::SAXException );
+ virtual void SAL_CALL setDocumentLocator( const Reference< XLocator >& xLocator )
+ throw( RuntimeException, com::sun::star::xml::sax::SAXException );
+
+
+ // XSAXDocumentBuilder
+ virtual SAXDocumentBuilderState SAL_CALL getState()
+ throw (RuntimeException);
+ virtual void SAL_CALL reset()
+ throw (RuntimeException);
+ virtual Reference< XDocument > SAL_CALL getDocument()
+ throw (RuntimeException);
+ virtual Reference< XDocumentFragment > SAL_CALL getDocumentFragment()
+ throw (RuntimeException);
+ virtual void SAL_CALL startDocumentFragment(const Reference< XDocument >& ownerDoc)
+ throw (RuntimeException);
+ virtual void SAL_CALL endDocumentFragment()
+ throw (RuntimeException);
+
+
+ };
+}
+
+#endif