net.sf.saxon.lib.StandardErrorHandler Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of Saxon-HE Show documentation
Show all versions of Saxon-HE Show documentation
The XSLT and XQuery Processor
////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
// Copyright (c) 2018-2023 Saxonica Limited
// This Source Code Form is subject to the terms of the Mozilla Public License, v. 2.0.
// If a copy of the MPL was not distributed with this file, You can obtain one at http://mozilla.org/MPL/2.0/.
// This Source Code Form is "Incompatible With Secondary Licenses", as defined by the Mozilla Public License, v. 2.0.
////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
package net.sf.saxon.lib;
import net.sf.saxon.expr.parser.Loc;
import net.sf.saxon.trans.XmlProcessingIncident;
import net.sf.saxon.trans.SaxonErrorCode;
import net.sf.saxon.trans.XmlProcessingException;
import net.sf.saxon.trans.XPathException;
import org.xml.sax.SAXException;
import org.xml.sax.SAXParseException;
import java.util.Objects;
/**
* A default implementation of the SAX ErrorHandler interface. Used by Saxon to catch XML parsing errors
* if no error handler is supplied by the application.
*/
public class StandardErrorHandler implements org.xml.sax.ErrorHandler {
////////////////////////////////////////////////////////////////////////////
// Implement the org.xml.sax.ErrorHandler interface.
////////////////////////////////////////////////////////////////////////////
private final ErrorReporter errorReporter;
private int warningCount = 0;
private int errorCount = 0;
private int fatalErrorCount = 0;
private boolean silent = false;
public StandardErrorHandler(ErrorReporter reporter) {
errorReporter = Objects.requireNonNull(reporter);
}
/**
* Indicate whether the error handler should report errors to the ErrorListener
* @param silent if true, errors should not be reported. Used during doc-available() processing
*/
public void setSilent(boolean silent) {
this.silent = silent;
}
/**
* Callback interface for SAX: not for application use
*/
@Override
public void warning(SAXParseException e) {
try {
warningCount++;
if (!silent) {
errorReporter.report(new XmlProcessingException(XPathException.makeXPathException(e)).asWarning());
}
} catch (Exception ignored) {
}
}
/**
* Callback interface for SAX: not for application use
*/
@Override
public void error(SAXParseException e) throws SAXException {
//System.err.println("ErrorHandler.error " + e.getMessage());
errorCount++;
if (!silent) {
reportError(e, false);
}
}
/**
* Callback interface for SAX: not for application use
*/
@Override
public void fatalError(/*@NotNull*/ SAXParseException e) throws SAXException {
//System.err.println("ErrorHandler.fatalError " + e.getMessage());
fatalErrorCount++;
if (!silent) {
reportError(e, true);
}
throw e;
}
/**
* Common routine for SAX errors and fatal errors
*
* @param e the exception being handled
* @param isFatal true if the error is classified as fatal
*/
protected void reportError(SAXParseException e, boolean isFatal) {
try {
Loc loc = new Loc(e.getSystemId(), e.getLineNumber(), e.getColumnNumber());
XmlProcessingIncident err = new XmlProcessingIncident(" Error reported by XML parser: "+ e.getMessage(), SaxonErrorCode.SXXP0003, loc);
err.setCause(e);
errorReporter.report(err);
} catch (Exception unexpected) {
throw new AssertionError(unexpected);
}
}
/**
* Return the number of warnings (including warnings) reported
*
* @return the number of warnings
*/
public int getWarningCount() {
return warningCount;
}
/**
* Return the number of errors reported
*
* @return the number of non-fatal errors
*/
public int getErrorCount() {
return errorCount;
}
/**
* Return the number of fatal errors reported
*
* @return the number of fatal errors
*/
public int getFatalErrorCount() {
return fatalErrorCount;
}
}