2 * Copyright (c) 1999, 2008, Oracle and/or its affiliates. All rights reserved.
3 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
5 * This code is free software; you can redistribute it and/or modify it
6 * under the terms of the GNU General Public License version 2 only, as
7 * published by the Free Software Foundation. Oracle designates this
8 * particular file as subject to the "Classpath" exception as provided
9 * by Oracle in the LICENSE file that accompanied this code.
11 * This code is distributed in the hope that it will be useful, but WITHOUT
12 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
13 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
14 * version 2 for more details (a copy is included in the LICENSE file that
15 * accompanied this code).
17 * You should have received a copy of the GNU General Public License version
18 * 2 along with this work; if not, write to the Free Software Foundation,
19 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
21 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
22 * or visit www.oracle.com if you need additional information or have any
26 package java.util.regex;
29 * Unchecked exception thrown to indicate a syntax error in a
30 * regular-expression pattern.
37 public class PatternSyntaxException
38 extends IllegalArgumentException
40 private static final long serialVersionUID = -3864639126226059218L;
42 private final String desc;
43 private final String pattern;
44 private final int index;
47 * Constructs a new instance of this class.
50 * A description of the error
53 * The erroneous pattern
56 * The approximate index in the pattern of the error,
57 * or <tt>-1</tt> if the index is not known
59 public PatternSyntaxException(String desc, String regex, int index) {
66 * Retrieves the error index.
68 * @return The approximate index in the pattern of the error,
69 * or <tt>-1</tt> if the index is not known
71 public int getIndex() {
76 * Retrieves the description of the error.
78 * @return The description of the error
80 public String getDescription() {
85 * Retrieves the erroneous regular-expression pattern.
87 * @return The erroneous pattern
89 public String getPattern() {
93 private static final String nl = System.lineSeparator();
96 * Returns a multi-line string containing the description of the syntax
97 * error and its index, the erroneous regular-expression pattern, and a
98 * visual indication of the error index within the pattern.
100 * @return The full detail message
102 public String getMessage() {
103 StringBuffer sb = new StringBuffer();
106 sb.append(" near index ");
113 for (int i = 0; i < index; i++) sb.append(' ');
116 return sb.toString();