1 /* 2 * Copyright (c) 2017, Oracle and/or its affiliates. All rights reserved. 3 */ 4 /* 5 * Licensed to the Apache Software Foundation (ASF) under one or more 6 * contributor license agreements. See the NOTICE file distributed with 7 * this work for additional information regarding copyright ownership. 8 * The ASF licenses this file to You under the Apache License, Version 2.0 9 * (the "License"); you may not use this file except in compliance with 10 * the License. You may obtain a copy of the License at 11 * 12 * http://www.apache.org/licenses/LICENSE-2.0 13 * 14 * Unless required by applicable law or agreed to in writing, software 15 * distributed under the License is distributed on an "AS IS" BASIS, 16 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 17 * See the License for the specific language governing permissions and 18 * limitations under the License. 19 */ 20 21 package com.sun.org.apache.xerces.internal.jaxp.validation; 22 23 import org.xml.sax.SAXException; 24 25 /** 26 * Wraps {@link SAXException} and make it an unchecked exception. 27 * <p> 28 * Xerces XNI doesn't allow {@link SAXException} to be thrown. 29 * So when the user-supplied error handler throws it, 30 * it needs to be tunneled through Xerces. 31 * 32 * <p> 33 * It is a bug if this exception "leaks" to the application. 34 * 35 * FIXME: use XNIException for this purpose. It's already doing this 36 * kind of SAXException tunneling. 37 * 38 * @author 39 * Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com) 40 * 41 * @LastModified: Oct 2017 42 */ 43 public class WrappedSAXException extends RuntimeException { 44 private static final long serialVersionUID = -3201986204982729962L; 45 46 public final SAXException exception; 47 48 WrappedSAXException( SAXException e ) { 49 this.exception = e; 50 } 51 }