emul/mini/src/main/java/java/lang/ReflectiveOperationException.java
author Jaroslav Tulach <jaroslav.tulach@apidesign.org>
Sat, 26 Jan 2013 08:47:05 +0100
changeset 592 5e13b1ac2886
parent 68 a2924470187b
permissions -rw-r--r--
In order to support fields of the same name in subclasses we are now prefixing them with name of the class that defines them. To provide convenient way to access them from generated bytecode and also directly from JavaScript, there is a getter/setter function for each field. It starts with _ followed by the field name. If called with a parameter, it sets the field, with a parameter it just returns it.
     1 /*
     2  * Copyright (c) 2009, Oracle and/or its affiliates. All rights reserved.
     3  * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
     4  *
     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.
    10  *
    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).
    16  *
    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.
    20  *
    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
    23  * questions.
    24  */
    25 
    26 package java.lang;
    27 
    28 /**
    29  * Common superclass of exceptions thrown by reflective operations in
    30  * core reflection.
    31  *
    32  * @see LinkageError
    33  * @since 1.7
    34  */
    35 public class ReflectiveOperationException extends Exception {
    36     static final long serialVersionUID = 123456789L;
    37 
    38     /**
    39      * Constructs a new exception with {@code null} as its detail
    40      * message.  The cause is not initialized, and may subsequently be
    41      * initialized by a call to {@link #initCause}.
    42      */
    43     public ReflectiveOperationException() {
    44         super();
    45     }
    46 
    47     /**
    48      * Constructs a new exception with the specified detail message.
    49      * The cause is not initialized, and may subsequently be
    50      * initialized by a call to {@link #initCause}.
    51      *
    52      * @param   message   the detail message. The detail message is saved for
    53      *          later retrieval by the {@link #getMessage()} method.
    54      */
    55     public ReflectiveOperationException(String message) {
    56         super(message);
    57     }
    58 
    59     /**
    60      * Constructs a new exception with the specified detail message
    61      * and cause.
    62      *
    63      * <p>Note that the detail message associated with
    64      * {@code cause} is <em>not</em> automatically incorporated in
    65      * this exception's detail message.
    66      *
    67      * @param  message the detail message (which is saved for later retrieval
    68      *         by the {@link #getMessage()} method).
    69      * @param  cause the cause (which is saved for later retrieval by the
    70      *         {@link #getCause()} method).  (A {@code null} value is
    71      *         permitted, and indicates that the cause is nonexistent or
    72      *         unknown.)
    73      */
    74     public ReflectiveOperationException(String message, Throwable cause) {
    75         super(message, cause);
    76     }
    77 
    78     /**
    79      * Constructs a new exception with the specified cause and a detail
    80      * message of {@code (cause==null ? null : cause.toString())} (which
    81      * typically contains the class and detail message of {@code cause}).
    82      *
    83      * @param  cause the cause (which is saved for later retrieval by the
    84      *         {@link #getCause()} method).  (A {@code null} value is
    85      *         permitted, and indicates that the cause is nonexistent or
    86      *         unknown.)
    87      */
    88     public ReflectiveOperationException(Throwable cause) {
    89         super(cause);
    90     }
    91 }