/************************************************************** * * Licensed to the Apache Software Foundation (ASF) under one * or more contributor license agreements. See the NOTICE file * distributed with this work for additional information * regarding copyright ownership. The ASF licenses this file * to you under the Apache License, Version 2.0 (the * "License"); you may not use this file except in compliance * with the License. You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, * software distributed under the License is distributed on an * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY * KIND, either express or implied. See the License for the * specific language governing permissions and limitations * under the License. * *************************************************************/ #ifndef OOX_CORE_FASTPARSER_HXX #define OOX_CORE_FASTPARSER_HXX #include #include namespace oox { struct NamespaceMap; class StorageBase; } namespace oox { namespace core { // ============================================================================ /** Wrapper for a fast SAX parser that works on automatically generated OOXML token and namespace identifiers. */ class FastParser { public: explicit FastParser( const ::com::sun::star::uno::Reference< ::com::sun::star::uno::XComponentContext >& rxContext ) throw( ::com::sun::star::uno::RuntimeException ); virtual ~FastParser(); /** Registers an OOXML namespace at the parser. */ void registerNamespace( sal_Int32 nNamespaceId ) throw( ::com::sun::star::lang::IllegalArgumentException, ::com::sun::star::uno::RuntimeException ); /** Sets the passed document handler that will receive the SAX parser events. */ void setDocumentHandler( const ::com::sun::star::uno::Reference< ::com::sun::star::xml::sax::XFastDocumentHandler >& rxDocHandler ) throw( ::com::sun::star::uno::RuntimeException ); /** Parses the passed SAX input source. @param bCloseStream True = closes the stream in the input source after parsing. */ void parseStream( const ::com::sun::star::xml::sax::InputSource& rInputSource, bool bCloseStream = false ) throw( ::com::sun::star::xml::sax::SAXException, ::com::sun::star::io::IOException, ::com::sun::star::uno::RuntimeException ); /** Parses the passed input stream. @param bCloseStream True = closes the passed stream after parsing. */ void parseStream( const ::com::sun::star::uno::Reference< ::com::sun::star::io::XInputStream >& rxInStream, const ::rtl::OUString& rStreamName, bool bCloseStream = false ) throw( ::com::sun::star::xml::sax::SAXException, ::com::sun::star::io::IOException, ::com::sun::star::uno::RuntimeException ); /** Parses a stream from the passed storage with the specified name. @param bCloseStream True = closes the stream after parsing. */ void parseStream( StorageBase& rStorage, const ::rtl::OUString& rStreamName, bool bCloseStream = false ) throw( ::com::sun::star::xml::sax::SAXException, ::com::sun::star::io::IOException, ::com::sun::star::uno::RuntimeException ); private: ::com::sun::star::uno::Reference< ::com::sun::star::xml::sax::XFastParser > mxParser; const NamespaceMap& mrNamespaceMap; }; // ============================================================================ } // namespace core } // namespace oox #endif