/*
* This program is free software; you can redistribute it and/or modify it under the
* terms of the GNU Lesser General Public License, version 2.1 as published by the Free Software
* Foundation.
*
* You should have received a copy of the GNU Lesser General Public License along with this
* program; if not, you can obtain a copy at http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html
* or from the Free Software Foundation, Inc.,
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
*
* This program 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 for more details.
*
* Copyright (c) 2001 - 2013 Object Refinery Ltd, Pentaho Corporation and Contributors.. All rights reserved.
*/
package org.pentaho.reporting.libraries.xmlns.parser;
import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
import org.xml.sax.ErrorHandler;
import org.xml.sax.SAXException;
import org.xml.sax.SAXParseException;
/**
* A SAX-Error handler that logs all incomming errors to the given log context.
*
* @author Thomas Morgner
*/
public class LoggingErrorHandler implements ErrorHandler {
private static final Log defaultLogContext = LogFactory.getLog( LoggingErrorHandler.class );
/**
* @noinspection NonConstantLogger
*/
private Log logContext;
/**
* Default-Constructor. Logs to a logger configured with this class name as category.
*/
public LoggingErrorHandler() {
logContext = defaultLogContext;
}
/**
* Creates a new LoggingErrorHandler with the given (non-null) logcontext as log-target.
*
* @param logContext the logger that should receive the messages.
*/
public LoggingErrorHandler( final Log logContext ) {
if ( logContext == null ) {
throw new NullPointerException();
}
this.logContext = logContext;
}
/**
* Receive notification of a warning. <p/> <p>SAX parsers will use this method to report conditions that are not
* errors or fatal errors as defined by the XML recommendation. The default behaviour is to take no action.</p> <p/>
* <p>The SAX parser must continue to provide normal parsing events after invoking this method: it should still be
* possible for the application to process the document through to the end.</p> <p/> <p>Filters may use this method to
* report other, non-XML warnings as well.</p>
*
* @param exception The warning information encapsulated in a SAX parse exception.
* @throws org.xml.sax.SAXException Any SAX exception, possibly wrapping another exception.
* @see org.xml.sax.SAXParseException
*/
public void warning( final SAXParseException exception ) throws SAXException {
if ( logContext.isDebugEnabled() ) {
if ( exception.getMessage().startsWith( "URI was not reported to parser for entity" ) ) {
// ignore that one. It is stupid! We do not use DTDs but old parsers like
// the GNU thing complain about it ..
return;
}
logContext.debug( "Parser-Warning", exception );
}
}
/**
* Receive notification of a recoverable error. <p/> <p>This corresponds to the definition of "error" in section 1.2
* of the W3C XML 1.0 Recommendation. For example, a validating parser would use this callback to report the
* violation of a validity constraint. The default behaviour is to take no action.</p> <p/> <p>The SAX parser must
* continue to provide normal parsing events after invoking this method: it should still be possible for the
* application to process the document through to the end. If the application cannot do so, then the parser should
* report a fatal error even if the XML recommendation does not require it to do so.</p> <p/> <p>Filters may use this
* method to report other, non-XML errors as well.</p>
*
* @param exception The error information encapsulated in a SAX parse exception.
* @throws org.xml.sax.SAXException Any SAX exception, possibly wrapping another exception.
* @see org.xml.sax.SAXParseException
*/
public void error( final SAXParseException exception ) throws SAXException {
if ( logContext.isWarnEnabled() ) {
if ( logContext.isDebugEnabled() ) {
logContext.warn( "Recoverable Parser-Error", exception );
} else {
logContext.warn( "Recoverable Parser-Error:" + exception.getMessage() );
}
}
}
/**
* Receive notification of a non-recoverable error. <p/> <p><strong>There is an apparent contradiction between the
* documentation for this method and the documentation for {@link org.xml.sax.ContentHandler#endDocument}. Until this
* ambiguity is resolved in a future major release, clients should make no assumptions about whether endDocument()
* will or will not be invoked when the parser has reported a fatalError() or thrown an exception.</strong></p> <p/>
* <p>This corresponds to the definition of "fatal error" in section 1.2 of the W3C XML 1.0 Recommendation. For
* example, a parser would use this callback to report the violation of a well-formedness constraint.</p> <p/> <p>The
* application must assume that the document is unusable after the parser has invoked this method, and should continue
* (if at all) only for the sake of collecting additional error messages: in fact, SAX parsers are free to stop
* reporting any other events once this method has been invoked.</p>
*
* @param exception The error information encapsulated in a SAX parse exception.
* @throws org.xml.sax.SAXException Any SAX exception, possibly wrapping another exception.
* @see org.xml.sax.SAXParseException
*/
public void fatalError( final SAXParseException exception ) throws SAXException {
if ( logContext.isErrorEnabled() ) {
if ( logContext.isDebugEnabled() ) {
logContext.error( "Fatal Parser-Error", exception );
} else {
logContext.error( "Fatal Parser-Error:" + exception.getMessage() );
}
}
}
}