📄 parseexception.java
字号:
/* Generated By:JavaCC: Do not edit this line. ParseException.java Version 3.0 */
/*
* (c) Copyright 2001-2002, 2003, 2004, 2005, 2006, 2007 Hewlett-Packard Development Company, LP All rights
* reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions are met: 1.
* Redistributions of source code must retain the above copyright notice, this
* list of conditions and the following disclaimer. 2. Redistributions in
* binary form must reproduce the above copyright notice, this list of
* conditions and the following disclaimer in the documentation and/or other
* materials provided with the distribution. 3. The name of the author may not
* be used to endorse or promote products derived from this software without
* specific prior written permission.
*
* THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR IMPLIED
* WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
* MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO
* EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
* SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
* PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS;
* OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
* WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR
* OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
* ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
* * $Id: ParseException.java,v 1.16 2007/01/02 11:48:59 andy_seaborne Exp $
*
* AUTHOR: Jeremy J. Carroll
*/
package com.hp.hpl.jena.rdf.arp;
import org.xml.sax.SAXParseException;
import com.hp.hpl.jena.rdf.arp.impl.Location;
/**
* An exception during the RDF processing of ARP. Note: it is distinguished from
* an XML related exception from Xerces because while both are
* SAXParseException's, the latter are not com.hp.hpl.jena.arp.ParseException's.
*
*/
public class ParseException extends SAXParseException implements
ARPErrorNumbers {
/**
*
*/
private static final long serialVersionUID = -5986976549492477885L;
final int id;
protected ParseException(int id, Location where, String msg) {
super(msg, where.inputName, null, where.endLine, where.endColumn);
this.id = id;
}
public ParseException(int id, Location where, Exception e) {
super(e.getMessage(), where.inputName, null, where.endLine, where.endColumn,e);
if (getCause()==null)
initCause(e);
this.id = id;
}
/**
* The error number (from {@link ARPErrorNumbers}) related to this
* exception.
*
* @return The error number.
*/
public int getErrorNumber() {
return id;
}
/**
* Is this error an RDF syntax error.
* A syntax error indicates that well-formed XML,
* uses RDF properties and attributes, and whitespace
* and XML elements, in a way that does not conform with
* the RDF/XML Syntax (Revised) specification.
* (Currently most such errors have code
* {@link ARPErrorNumbers#ERR_SYNTAX_ERROR},
* but this may change in the future).
* @return True if this is a syntax error
*/
public boolean isSyntaxError() {
switch (id) {
case ERR_SYNTAX_ERROR:
case ERR_BAD_RDF_ELEMENT:
case ERR_BAD_RDF_ATTRIBUTE:
case ERR_LI_AS_TYPE:
case ERR_NOT_WHITESPACE:
return true;
}
return false;
}
SAXParseException rootCause() {
Exception e = getException();
return e == null ? this : (SAXParseException) e;
}
private boolean promoteMe;
/**
* Intended for use within an RDFErrorHandler. This method is untested.
* Marks the exception to be promoted to be thrown from the parser's entry
* method.
*/
public void promote() {
promoteMe = true;
}
/**
* The message without location information. Use either the formatMessage
* method, or the SAXParseException interface, to access the location
* information.
*
* @return The exception message.
*/
public String getMessage() {
// turn 1 to W001
// turn 204 to E204
String idStr = id != 0 ? "{" + (id < 200 ? "W" : "E")
+ ("" + (1000 + id)).substring(1) + "} " : "";
return idStr + super.getMessage();
}
/**
* Calls e.getMessage() and also accesses line and column information for
* SAXParseException's.
*
* @return e.getMessage() possibly prepended by error location information.
* @param e
* The exception to describe.
*/
static public String formatMessage(Exception e) {
String msg = e.getMessage();
if (msg == null)
msg = e.toString();
if (!(e instanceof SAXParseException))
return msg;
SAXParseException sax = (SAXParseException) e;
String file = sax.getSystemId();
if (file == null)
file = sax.getPublicId();
String rslt = file == null ? "" : file;
if (sax.getLineNumber() == -1)
return (file != null ? (file + ": ") : "") + msg;
if (sax.getColumnNumber() == -1) {
return rslt + "(line " + sax.getLineNumber() + "): " + msg;
}
return rslt + "(line " + sax.getLineNumber() + " column " + sax.getColumnNumber()
+ "): " + msg;
}
public boolean isPromoted() {
return promoteMe;
}
/**
* The string from
* {@link ARPErrorNumbers} associated with an integer error code
* @param errNo An error code from {@link ARPErrorNumbers}.
* @return The field name from {@link ARPErrorNumbers} with this error number, or null
*/
static public String errorCodeName(int errNo) {
Class c = ARPErrorNumbers.class;
java.lang.reflect.Field flds[] = c.getDeclaredFields();
for (int i = 0; i < flds.length; i++) {
try {
if (flds[i].getInt(null) == errNo)
return flds[i].getName();
} catch (Exception e) {
// ignore exceptions
}
}
return null;
}
/**
* The integer code associated with a string from
* {@link ARPErrorNumbers}.
* @param upper A field name from {@link ARPErrorNumbers}, (in upper case).
* @return The integer value or -1, if none.
*/
static public int errorCode(String upper) {
Class c = ARPErrorNumbers.class;
try {
java.lang.reflect.Field fld = c.getField(upper);
return fld.getInt(null);
} catch (Exception e) {
return -1;
}
}
}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -