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 }