001: /*
002: * NativeCompilationException.java
003: *
004: *
005: * Copyright (c) 2003 Rimfaxe ApS (www.rimfaxe.com).
006: * All rights reserved.
007: *
008: * This package is written by Lars Andersen <lars@rimfaxe.com>
009: * and licensed by Rimfaxe ApS.
010: *
011: * Redistribution and use in source and binary forms, with or without
012: * modification, are permitted provided that the following conditions
013: * are met:
014: *
015: * 1. Redistributions of source code must retain the above copyright
016: * notice, this list of conditions and the following disclaimer.
017: *
018: * 2. Redistributions in binary form must reproduce the above copyright
019: * notice, this list of conditions and the following disclaimer in
020: * the documentation and/or other materials provided with the
021: * distribution.
022: *
023: * 3. The end-user documentation included with the redistribution, if
024: * any, must include the following acknowlegement:
025: * "This product includes software developed by Rimfaxe ApS
026: (www.rimfaxe.com)"
027: * Alternately, this acknowlegement may appear in the software itself,
028: * if and wherever such third-party acknowlegements normally appear.
029: *
030: * 4. The names "Rimfaxe", "Rimfaxe Software", "Lars Andersen" and
031: * "Rimfaxe WebServer" must not be used to endorse or promote products
032: * derived from this software without prior written permission. For written
033: * permission, please contact info@rimfaxe.com
034: *
035: * 5. Products derived from this software may not be called "Rimfaxe"
036: * nor may "Rimfaxe" appear in their names without prior written
037: * permission of the Rimfaxe ApS.
038: *
039: * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
040: * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
041: * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
042: * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
043: * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
044: * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
045: * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
046: * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
047: * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
048: * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
049: * SUCH DAMAGE.
050: *
051: */
052:
053: package com.rimfaxe.webserver.compiler;
054:
055: import com.rimfaxe.webserver.compiler.jsp.Mark;
056:
057: import java.util.*;
058:
059: /**
060: *
061: * @author Lars Andersen
062: */
063: public class JspToJavaException extends java.lang.Exception {
064: Mark mark = null;
065:
066: String message = "";
067: String element = null;
068:
069: /**
070: * Creates a new instance of <code>NativeCompilationException</code> without detail message.
071: */
072: public JspToJavaException() {
073: }
074:
075: /**
076: * Constructs an instance of <code>NativeCompilationException</code> with the specified detail message.
077: * @param msg the detail message.
078: */
079: public JspToJavaException(String msg) {
080: super (msg);
081: }
082:
083: /**
084: * Constructs an instance of <code>NativeCompilationException</code> with the specified detail message.
085: * @param msg the detail message.
086: */
087: public JspToJavaException(Mark mark, String msg) {
088: super (msg);
089: this .mark = mark;
090: this .message = msg;
091: }
092:
093: /**
094: * Constructs an instance of <code>NativeCompilationException</code> with the specified detail message.
095: * @param msg the detail message.
096: */
097: public JspToJavaException(Mark mark, String msg, String element) {
098: super (msg);
099: this .mark = mark;
100: this .message = msg;
101: this .element = element;
102: }
103:
104: public String toString() {
105: StringBuffer buf = new StringBuffer();
106: buf.append("Error compiling JSP page : \n");
107: if (element != null)
108: buf.append("In JSP element : " + element + "\n");
109: buf.append(message + "\n");
110: if (mark != null)
111: buf.append("At line : " + mark.toString() + "\n");
112:
113: return "" + buf;
114: }
115: }
|