[Libreoffice-commits] core.git: reportdesign/source

Caolán McNamara (via logerrit) logerrit at kemper.freedesktop.org
Mon Nov 2 19:48:10 UTC 2020


 reportdesign/source/filter/xml/xmlfilter.cxx |   24 ++++++++----------------
 1 file changed, 8 insertions(+), 16 deletions(-)

New commits:
commit f821939c1d2befafda70a8e8c3ed88748ab75762
Author:     Caolán McNamara <caolanm at redhat.com>
AuthorDate: Mon Nov 2 16:21:29 2020 +0000
Commit:     Caolán McNamara <caolanm at redhat.com>
CommitDate: Mon Nov 2 20:47:30 2020 +0100

    tdf#137916 get report xml importer working again
    
    Change-Id: I238373bdfd35001c09a67b73cc38f5a96640e2ba
    Reviewed-on: https://gerrit.libreoffice.org/c/core/+/105190
    Reviewed-by: Noel Grandin <noel.grandin at collabora.co.uk>
    Reviewed-by: Caolán McNamara <caolanm at redhat.com>
    Tested-by: Jenkins

diff --git a/reportdesign/source/filter/xml/xmlfilter.cxx b/reportdesign/source/filter/xml/xmlfilter.cxx
index d3d495d79d0f..487ee306aa16 100644
--- a/reportdesign/source/filter/xml/xmlfilter.cxx
+++ b/reportdesign/source/filter/xml/xmlfilter.cxx
@@ -114,7 +114,7 @@ static ErrCode ReadThroughComponent(
     const uno::Reference<XInputStream>& xInputStream,
     const uno::Reference<XComponent>& xModelComponent,
     const uno::Reference<XComponentContext> & rContext,
-    const uno::Reference< XDocumentHandler >& _xFilter )
+    const uno::Reference<XFastParser>& rFastParser )
 {
     OSL_ENSURE(xInputStream.is(), "input stream missing");
     OSL_ENSURE(xModelComponent.is(), "document missing");
@@ -125,27 +125,18 @@ static ErrCode ReadThroughComponent(
     aParserInput.aInputStream = xInputStream;
 
     // get filter
-    SAL_WARN_IF( !_xFilter.is(), "reportdesign", "Can't instantiate filter component." );
-    if( !_xFilter.is() )
+    SAL_WARN_IF( !rFastParser.is(), "reportdesign", "Can't instantiate filter component." );
+    if( !rFastParser.is() )
         return ErrCode(1);
 
     // connect model and filter
-    uno::Reference < XImporter > xImporter( _xFilter, UNO_QUERY );
+    uno::Reference < XImporter > xImporter( rFastParser, UNO_QUERY );
     xImporter->setTargetDocument( xModelComponent );
 
     // finally, parser the stream
     try
     {
-        uno::Reference < XFastParser > xFastParser( _xFilter, UNO_QUERY );\
-        if (xFastParser.is())
-            xFastParser->parseStream( aParserInput );
-        else
-        {
-            uno::Reference< XParser > xParser = xml::sax::Parser::create(rContext);
-            // connect parser and filter
-            xParser->setDocumentHandler( _xFilter );
-            xParser->parseStream( aParserInput );
-        }
+        rFastParser->parseStream( aParserInput );
     }
     catch (const SAXParseException&)
     {
@@ -233,7 +224,8 @@ static ErrCode ReadThroughComponent(
         if ( _xProp.is() )
             aFilterCompArgs[ nArgs++ ] <<= _xProp;
 
-        Reference< xml::sax::XDocumentHandler > xDocHandler(
+        // the underlying SvXMLImport implements XFastParser, XImporter, XFastDocumentHandler
+        Reference< XFastParser > xFastParser(
             rxContext->getServiceManager()->createInstanceWithArgumentsAndContext(_sFilterName, aFilterCompArgs, rxContext),
             uno::UNO_QUERY_THROW );
         uno::Reference< XInputStream > xInputStream = xDocStream->getInputStream();
@@ -241,7 +233,7 @@ static ErrCode ReadThroughComponent(
         return ReadThroughComponent( xInputStream
                                     ,xModelComponent
                                     ,rxContext
-                                    ,xDocHandler );
+                                    ,xFastParser );
     }
 
     // TODO/LATER: better error handling


More information about the Libreoffice-commits mailing list