1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105
/* * @(#)PatternSyntaxException.java 1.16 06/05/22 * * Copyright 2006 Sun Microsystems, Inc. All rights reserved. * SUN PROPRIETARY/CONFIDENTIAL. Use is subject to license terms. */ package java.util.regex; import sun.security.action.GetPropertyAction; /** * Unchecked exception thrown to indicate a syntax error in a * regular-expression pattern. * * @author unascribed * @version 1.16, 06/05/22 * @since 1.4 * @spec JSR-51 */ public class PatternSyntaxException extends IllegalArgumentException { private final String desc; private final String pattern; private final int index; /** * Constructs a new instance of this class. * * @param desc * A description of the error * * @param regex * The erroneous pattern * * @param index * The approximate index in the pattern of the error, * or <tt>-1</tt> if the index is not known */ public PatternSyntaxException(String desc, String regex, int index) { this.desc = desc; this.pattern = regex; this.index = index; } /** * Retrieves the error index. * * @return The approximate index in the pattern of the error, * or <tt>-1</tt> if the index is not known */ public int getIndex() { return index; } /** * Retrieves the description of the error. * * @return The description of the error */ public String getDescription() { return desc; } /** * Retrieves the erroneous regular-expression pattern. * * @return The erroneous pattern */ public String getPattern() { return pattern; } private static final String nl = java.security.AccessController .doPrivileged(new GetPropertyAction("line.separator")); /** * Returns a multi-line string containing the description of the syntax * error and its index, the erroneous regular-expression pattern, and a * visual indication of the error index within the pattern. * * @return The full detail message */ public String getMessage() { StringBuffer sb = new StringBuffer(); sb.append(desc); if (index >= 0) { sb.append(" near index "); sb.append(index); } sb.append(nl); sb.append(pattern); if (index >= 0) { sb.append(nl); for (int i = 0; i < index; i++) sb.append(' '); sb.append('^'); } return sb.toString(); } }