org.navimatrix.jaxen.XPathSyntaxException Maven / Gradle / Ivy
/*
* $Header: /cvs/jaxen/jaxen/src/java/main/org/jaxen/XPathSyntaxException.java,v 1.12 2006/06/03 20:26:36 elharo Exp $
* $Revision: 1.12 $
* $Date: 2006/06/03 20:26:36 $
*
* ====================================================================
*
* Copyright 2000-2002 bob mcwhirter & James Strachan.
* All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions are
* met:
*
* * Redistributions of source code must retain the above copyright
* notice, this list of conditions and the following disclaimer.
*
* * 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.
*
* * Neither the name of the Jaxen Project nor the names of its
* contributors may be used to endorse or promote products derived
* from this software without specific prior written permission.
*
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "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 COPYRIGHT OWNER
* OR CONTRIBUTORS 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.
*
* ====================================================================
* This software consists of voluntary contributions made by many
* individuals on behalf of the Jaxen Project and was originally
* created by bob mcwhirter and
* James Strachan . For more information on the
* Jaxen Project, please see .
*
* $Id: XPathSyntaxException.java,v 1.12 2006/06/03 20:26:36 elharo Exp $
*/
package org.navimatrix.jaxen;
/** Indicates an error during parsing of an XPath expression.
*
* @author bob mcwhirter
* @author James Strachan
*/
public class XPathSyntaxException extends JaxenException
{
/**
*
*/
private static final long serialVersionUID = 1980601567207604059L;
/** The textual XPath expression */
private String xpath;
/** The position of the error */
private int position;
/**
* Create a new XPathSyntaxException wrapping an existing
* org.navimatrix.jaxen.saxpath.XPathSyntaxException
.
*
* @param e the exception that caused this exception
*/
public XPathSyntaxException(org.navimatrix.jaxen.saxpath.XPathSyntaxException e)
{
super( e );
this.xpath = e.getXPath();
this.position = e.getPosition();
}
/** Constructor
*
* @param xpath the erroneous XPath expression
* @param position the position of the error
* @param message the error message
*/
public XPathSyntaxException(String xpath,
int position,
String message)
{
super( message );
this.xpath = xpath;
this.position = position;
}
/** Retrieve the position of the error.
*
* @return the position of the error
*/
public int getPosition()
{
return this.position;
}
/** Retrieve the expression containing the error.
*
* @return the erroneous expression
*/
public String getXPath()
{
return this.xpath;
}
/** Retrieve a string useful for denoting where
* the error occurred.
*
*
* This is a string composed of whitespace and
* a marker at the position (see {@link #getPosition})
* of the error. This is useful for creating
* friendly multi-line error displays.
*
*
* @return the error position marker
*/
public String getPositionMarker()
{
StringBuffer buf = new StringBuffer();
int pos = getPosition();
for ( int i = 0 ; i < pos ; ++i )
{
buf.append(" ");
}
buf.append("^");
return buf.toString();
}
/** Retrieve the friendly multi-line error message.
*
*
* This returns a multi-line string that contains
* the original erroneous XPath expression with a
* marker underneath indicating exactly where the
* error occurred.
*
*
* @return the multi-line error message
*/
public String getMultilineMessage()
{
StringBuffer buf = new StringBuffer(getMessage());
buf.append( "\n" );
buf.append( getXPath() );
buf.append( "\n" );
buf.append( getPositionMarker() );
return buf.toString();
}
}
© 2015 - 2024 Weber Informatics LLC | Privacy Policy