jdk/src/java.base/share/classes/sun/reflect/Reflection.java
author alanb
Thu, 17 Mar 2016 19:04:16 +0000
changeset 36511 9d0388c6b336
parent 34882 ce2a8ec851c1
permissions -rw-r--r--
8142968: Module System implementation Summary: Initial integration of JEP 200, JEP 260, JEP 261, and JEP 282 Reviewed-by: alanb, mchung, naoto, rriggs, psandoz, plevart, mullan, ascarpino, vinnie, prr, sherman, dfuchs, mhaupt Contributed-by: alan.bateman@oracle.com, alex.buckley@oracle.com, jonathan.gibbons@oracle.com, karen.kinnear@oracle.com, mandy.chung@oracle.com, mark.reinhold@oracle.com, chris.hegarty@oracle.com, alexandr.scherbatiy@oracle.com, amy.lu@oracle.com, calvin.cheung@oracle.com, daniel.fuchs@oracle.com, erik.joelsson@oracle.com, harold.seigel@oracle.com, jaroslav.bachorik@oracle.com, jean-francois.denise@oracle.com, jan.lahoda@oracle.com, james.laskey@oracle.com, lois.foltan@oracle.com, miroslav.kos@oracle.com, huaming.li@oracle.com, sean.mullan@oracle.com, naoto.sato@oracle.com, masayoshi.okutsu@oracle.com, peter.levart@gmail.com, philip.race@oracle.com, claes.redestad@oracle.com, sergey.bylokhov@oracle.com, alexandre.iline@oracle.com, volker.simonis@gmail.com, staffan.larsen@oracle.com, stuart.marks@oracle.com, semyon.sadetsky@oracle.com, serguei.spitsyn@oracle.com, sundararajan.athijegannathan@oracle.com, valerie.peng@oracle.com, vincent.x.ryan@oracle.com, weijun.wang@oracle.com, yuri.nesterenko@oracle.com, yekaterina.kantserova@oracle.com, alexander.kulyakhtin@oracle.com, felix.yang@oracle.com, andrei.eremeev@oracle.com, frank.yuan@oracle.com, sergei.pikalev@oracle.com, sibabrata.sahoo@oracle.com, tiantian.du@oracle.com, sha.jiang@oracle.com
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
     1
/*
20872
8e486b70dff8 8022718: Runtime accessibility checking: protected class, if extended, should be accessible from another package
drchase
parents: 16906
diff changeset
     2
 * Copyright (c) 2001, 2013, Oracle and/or its affiliates. All rights reserved.
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
     3
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
90ce3da70b43 Initial load
duke
parents:
diff changeset
     4
 *
90ce3da70b43 Initial load
duke
parents:
diff changeset
     5
 * This code is free software; you can redistribute it and/or modify it
90ce3da70b43 Initial load
duke
parents:
diff changeset
     6
 * under the terms of the GNU General Public License version 2 only, as
5506
202f599c92aa 6943119: Rebrand source copyright notices
ohair
parents: 2
diff changeset
     7
 * published by the Free Software Foundation.  Oracle designates this
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
     8
 * particular file as subject to the "Classpath" exception as provided
5506
202f599c92aa 6943119: Rebrand source copyright notices
ohair
parents: 2
diff changeset
     9
 * by Oracle in the LICENSE file that accompanied this code.
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
    10
 *
90ce3da70b43 Initial load
duke
parents:
diff changeset
    11
 * This code is distributed in the hope that it will be useful, but WITHOUT
90ce3da70b43 Initial load
duke
parents:
diff changeset
    12
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
90ce3da70b43 Initial load
duke
parents:
diff changeset
    13
 * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
90ce3da70b43 Initial load
duke
parents:
diff changeset
    14
 * version 2 for more details (a copy is included in the LICENSE file that
90ce3da70b43 Initial load
duke
parents:
diff changeset
    15
 * accompanied this code).
90ce3da70b43 Initial load
duke
parents:
diff changeset
    16
 *
90ce3da70b43 Initial load
duke
parents:
diff changeset
    17
 * You should have received a copy of the GNU General Public License version
90ce3da70b43 Initial load
duke
parents:
diff changeset
    18
 * 2 along with this work; if not, write to the Free Software Foundation,
90ce3da70b43 Initial load
duke
parents:
diff changeset
    19
 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
90ce3da70b43 Initial load
duke
parents:
diff changeset
    20
 *
5506
202f599c92aa 6943119: Rebrand source copyright notices
ohair
parents: 2
diff changeset
    21
 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
202f599c92aa 6943119: Rebrand source copyright notices
ohair
parents: 2
diff changeset
    22
 * or visit www.oracle.com if you need additional information or have any
202f599c92aa 6943119: Rebrand source copyright notices
ohair
parents: 2
diff changeset
    23
 * questions.
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
    24
 */
90ce3da70b43 Initial load
duke
parents:
diff changeset
    25
90ce3da70b43 Initial load
duke
parents:
diff changeset
    26
package sun.reflect;
90ce3da70b43 Initial load
duke
parents:
diff changeset
    27
36511
9d0388c6b336 8142968: Module System implementation
alanb
parents: 34882
diff changeset
    28
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
    29
import java.lang.reflect.*;
36511
9d0388c6b336 8142968: Module System implementation
alanb
parents: 34882
diff changeset
    30
import java.security.AccessController;
9d0388c6b336 8142968: Module System implementation
alanb
parents: 34882
diff changeset
    31
import java.security.PrivilegedAction;
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
    32
import java.util.HashMap;
90ce3da70b43 Initial load
duke
parents:
diff changeset
    33
import java.util.Map;
36511
9d0388c6b336 8142968: Module System implementation
alanb
parents: 34882
diff changeset
    34
import java.util.Objects;
31671
362e0c0acece 8076112: Add @HotSpotIntrinsicCandidate annotation to indicate methods for which Java Runtime has intrinsics
zmajo
parents: 31074
diff changeset
    35
import jdk.internal.HotSpotIntrinsicCandidate;
34882
ce2a8ec851c1 8145544: Move sun.misc.VM to jdk.internal.misc
chegar
parents: 31671
diff changeset
    36
import jdk.internal.misc.VM;
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
    37
90ce3da70b43 Initial load
duke
parents:
diff changeset
    38
/** Common utility routines used by both java.lang and
90ce3da70b43 Initial load
duke
parents:
diff changeset
    39
    java.lang.reflect */
90ce3da70b43 Initial load
duke
parents:
diff changeset
    40
90ce3da70b43 Initial load
duke
parents:
diff changeset
    41
public class Reflection {
90ce3da70b43 Initial load
duke
parents:
diff changeset
    42
90ce3da70b43 Initial load
duke
parents:
diff changeset
    43
    /** Used to filter out fields and methods from certain classes from public
90ce3da70b43 Initial load
duke
parents:
diff changeset
    44
        view, where they are sensitive or they may contain VM-internal objects.
90ce3da70b43 Initial load
duke
parents:
diff changeset
    45
        These Maps are updated very rarely. Rather than synchronize on
90ce3da70b43 Initial load
duke
parents:
diff changeset
    46
        each access, we use copy-on-write */
10342
ca0984bc9d32 7077389: Reflection classes do not build with javac -Xlint:all -Werror
jjg
parents: 5506
diff changeset
    47
    private static volatile Map<Class<?>,String[]> fieldFilterMap;
ca0984bc9d32 7077389: Reflection classes do not build with javac -Xlint:all -Werror
jjg
parents: 5506
diff changeset
    48
    private static volatile Map<Class<?>,String[]> methodFilterMap;
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
    49
90ce3da70b43 Initial load
duke
parents:
diff changeset
    50
    static {
10342
ca0984bc9d32 7077389: Reflection classes do not build with javac -Xlint:all -Werror
jjg
parents: 5506
diff changeset
    51
        Map<Class<?>,String[]> map = new HashMap<Class<?>,String[]>();
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
    52
        map.put(Reflection.class,
90ce3da70b43 Initial load
duke
parents:
diff changeset
    53
            new String[] {"fieldFilterMap", "methodFilterMap"});
90ce3da70b43 Initial load
duke
parents:
diff changeset
    54
        map.put(System.class, new String[] {"security"});
31074
0a91f3afaae7 8081320: Backout JDK-8059340: ConstantPool::_resolved_references is missing in heap dump
vlivanov
parents: 31071
diff changeset
    55
        map.put(Class.class, new String[] {"classLoader"});
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
    56
        fieldFilterMap = map;
90ce3da70b43 Initial load
duke
parents:
diff changeset
    57
10342
ca0984bc9d32 7077389: Reflection classes do not build with javac -Xlint:all -Werror
jjg
parents: 5506
diff changeset
    58
        methodFilterMap = new HashMap<>();
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
    59
    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
    60
16906
44dfee24cb71 8010117: Annotate jdk caller sensitive methods with @sun.reflect.CallerSensitive
mchung
parents: 14342
diff changeset
    61
    /** Returns the class of the caller of the method calling this method,
44dfee24cb71 8010117: Annotate jdk caller sensitive methods with @sun.reflect.CallerSensitive
mchung
parents: 14342
diff changeset
    62
        ignoring frames associated with java.lang.reflect.Method.invoke()
44dfee24cb71 8010117: Annotate jdk caller sensitive methods with @sun.reflect.CallerSensitive
mchung
parents: 14342
diff changeset
    63
        and its implementation. */
44dfee24cb71 8010117: Annotate jdk caller sensitive methods with @sun.reflect.CallerSensitive
mchung
parents: 14342
diff changeset
    64
    @CallerSensitive
31671
362e0c0acece 8076112: Add @HotSpotIntrinsicCandidate annotation to indicate methods for which Java Runtime has intrinsics
zmajo
parents: 31074
diff changeset
    65
    @HotSpotIntrinsicCandidate
16906
44dfee24cb71 8010117: Annotate jdk caller sensitive methods with @sun.reflect.CallerSensitive
mchung
parents: 14342
diff changeset
    66
    public static native Class<?> getCallerClass();
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
    67
21284
e6dfe841a88f 8025799: Restore sun.reflect.Reflection.getCallerClass(int) until a replacement API is provided
mchung
parents: 20872
diff changeset
    68
    /**
e6dfe841a88f 8025799: Restore sun.reflect.Reflection.getCallerClass(int) until a replacement API is provided
mchung
parents: 20872
diff changeset
    69
     * @deprecated This method will be removed in JDK 9.
e6dfe841a88f 8025799: Restore sun.reflect.Reflection.getCallerClass(int) until a replacement API is provided
mchung
parents: 20872
diff changeset
    70
     * This method is a private JDK API and retained temporarily for
e6dfe841a88f 8025799: Restore sun.reflect.Reflection.getCallerClass(int) until a replacement API is provided
mchung
parents: 20872
diff changeset
    71
     * existing code to run until a replacement API is defined.
e6dfe841a88f 8025799: Restore sun.reflect.Reflection.getCallerClass(int) until a replacement API is provided
mchung
parents: 20872
diff changeset
    72
     */
e6dfe841a88f 8025799: Restore sun.reflect.Reflection.getCallerClass(int) until a replacement API is provided
mchung
parents: 20872
diff changeset
    73
    @Deprecated
e6dfe841a88f 8025799: Restore sun.reflect.Reflection.getCallerClass(int) until a replacement API is provided
mchung
parents: 20872
diff changeset
    74
    public static native Class<?> getCallerClass(int depth);
e6dfe841a88f 8025799: Restore sun.reflect.Reflection.getCallerClass(int) until a replacement API is provided
mchung
parents: 20872
diff changeset
    75
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
    76
    /** Retrieves the access flags written to the class file. For
90ce3da70b43 Initial load
duke
parents:
diff changeset
    77
        inner classes these flags may differ from those returned by
90ce3da70b43 Initial load
duke
parents:
diff changeset
    78
        Class.getModifiers(), which searches the InnerClasses
90ce3da70b43 Initial load
duke
parents:
diff changeset
    79
        attribute to find the source-level access flags. This is used
90ce3da70b43 Initial load
duke
parents:
diff changeset
    80
        instead of Class.getModifiers() for run-time access checks due
90ce3da70b43 Initial load
duke
parents:
diff changeset
    81
        to compatibility reasons; see 4471811. Only the values of the
90ce3da70b43 Initial load
duke
parents:
diff changeset
    82
        low 13 bits (i.e., a mask of 0x1FFF) are guaranteed to be
90ce3da70b43 Initial load
duke
parents:
diff changeset
    83
        valid. */
31671
362e0c0acece 8076112: Add @HotSpotIntrinsicCandidate annotation to indicate methods for which Java Runtime has intrinsics
zmajo
parents: 31074
diff changeset
    84
    @HotSpotIntrinsicCandidate
20872
8e486b70dff8 8022718: Runtime accessibility checking: protected class, if extended, should be accessible from another package
drchase
parents: 16906
diff changeset
    85
    public static native int getClassAccessFlags(Class<?> c);
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
    86
90ce3da70b43 Initial load
duke
parents:
diff changeset
    87
10342
ca0984bc9d32 7077389: Reflection classes do not build with javac -Xlint:all -Werror
jjg
parents: 5506
diff changeset
    88
    public static void ensureMemberAccess(Class<?> currentClass,
ca0984bc9d32 7077389: Reflection classes do not build with javac -Xlint:all -Werror
jjg
parents: 5506
diff changeset
    89
                                          Class<?> memberClass,
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
    90
                                          Object target,
90ce3da70b43 Initial load
duke
parents:
diff changeset
    91
                                          int modifiers)
90ce3da70b43 Initial load
duke
parents:
diff changeset
    92
        throws IllegalAccessException
90ce3da70b43 Initial load
duke
parents:
diff changeset
    93
    {
90ce3da70b43 Initial load
duke
parents:
diff changeset
    94
        if (currentClass == null || memberClass == null) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
    95
            throw new InternalError();
90ce3da70b43 Initial load
duke
parents:
diff changeset
    96
        }
90ce3da70b43 Initial load
duke
parents:
diff changeset
    97
90ce3da70b43 Initial load
duke
parents:
diff changeset
    98
        if (!verifyMemberAccess(currentClass, memberClass, target, modifiers)) {
36511
9d0388c6b336 8142968: Module System implementation
alanb
parents: 34882
diff changeset
    99
            throwIllegalAccessException(currentClass, memberClass, target, modifiers);
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
   100
        }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   101
    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   102
10342
ca0984bc9d32 7077389: Reflection classes do not build with javac -Xlint:all -Werror
jjg
parents: 5506
diff changeset
   103
    public static boolean verifyMemberAccess(Class<?> currentClass,
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
   104
                                             // Declaring class of field
90ce3da70b43 Initial load
duke
parents:
diff changeset
   105
                                             // or method
10342
ca0984bc9d32 7077389: Reflection classes do not build with javac -Xlint:all -Werror
jjg
parents: 5506
diff changeset
   106
                                             Class<?> memberClass,
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
   107
                                             // May be NULL in case of statics
10342
ca0984bc9d32 7077389: Reflection classes do not build with javac -Xlint:all -Werror
jjg
parents: 5506
diff changeset
   108
                                             Object   target,
ca0984bc9d32 7077389: Reflection classes do not build with javac -Xlint:all -Werror
jjg
parents: 5506
diff changeset
   109
                                             int      modifiers)
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
   110
    {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   111
        // Verify that currentClass can access a field, method, or
90ce3da70b43 Initial load
duke
parents:
diff changeset
   112
        // constructor of memberClass, where that member's access bits are
90ce3da70b43 Initial load
duke
parents:
diff changeset
   113
        // "modifiers".
90ce3da70b43 Initial load
duke
parents:
diff changeset
   114
90ce3da70b43 Initial load
duke
parents:
diff changeset
   115
        boolean gotIsSameClassPackage = false;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   116
        boolean isSameClassPackage = false;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   117
90ce3da70b43 Initial load
duke
parents:
diff changeset
   118
        if (currentClass == memberClass) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   119
            // Always succeeds
90ce3da70b43 Initial load
duke
parents:
diff changeset
   120
            return true;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   121
        }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   122
36511
9d0388c6b336 8142968: Module System implementation
alanb
parents: 34882
diff changeset
   123
        if (!verifyModuleAccess(currentClass, memberClass)) {
9d0388c6b336 8142968: Module System implementation
alanb
parents: 34882
diff changeset
   124
            return false;
9d0388c6b336 8142968: Module System implementation
alanb
parents: 34882
diff changeset
   125
        }
9d0388c6b336 8142968: Module System implementation
alanb
parents: 34882
diff changeset
   126
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
   127
        if (!Modifier.isPublic(getClassAccessFlags(memberClass))) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   128
            isSameClassPackage = isSameClassPackage(currentClass, memberClass);
90ce3da70b43 Initial load
duke
parents:
diff changeset
   129
            gotIsSameClassPackage = true;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   130
            if (!isSameClassPackage) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   131
                return false;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   132
            }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   133
        }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   134
90ce3da70b43 Initial load
duke
parents:
diff changeset
   135
        // At this point we know that currentClass can access memberClass.
90ce3da70b43 Initial load
duke
parents:
diff changeset
   136
90ce3da70b43 Initial load
duke
parents:
diff changeset
   137
        if (Modifier.isPublic(modifiers)) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   138
            return true;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   139
        }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   140
90ce3da70b43 Initial load
duke
parents:
diff changeset
   141
        boolean successSoFar = false;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   142
90ce3da70b43 Initial load
duke
parents:
diff changeset
   143
        if (Modifier.isProtected(modifiers)) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   144
            // See if currentClass is a subclass of memberClass
90ce3da70b43 Initial load
duke
parents:
diff changeset
   145
            if (isSubclassOf(currentClass, memberClass)) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   146
                successSoFar = true;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   147
            }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   148
        }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   149
90ce3da70b43 Initial load
duke
parents:
diff changeset
   150
        if (!successSoFar && !Modifier.isPrivate(modifiers)) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   151
            if (!gotIsSameClassPackage) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   152
                isSameClassPackage = isSameClassPackage(currentClass,
90ce3da70b43 Initial load
duke
parents:
diff changeset
   153
                                                        memberClass);
90ce3da70b43 Initial load
duke
parents:
diff changeset
   154
                gotIsSameClassPackage = true;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   155
            }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   156
90ce3da70b43 Initial load
duke
parents:
diff changeset
   157
            if (isSameClassPackage) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   158
                successSoFar = true;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   159
            }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   160
        }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   161
90ce3da70b43 Initial load
duke
parents:
diff changeset
   162
        if (!successSoFar) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   163
            return false;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   164
        }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   165
90ce3da70b43 Initial load
duke
parents:
diff changeset
   166
        if (Modifier.isProtected(modifiers)) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   167
            // Additional test for protected members: JLS 6.6.2
10342
ca0984bc9d32 7077389: Reflection classes do not build with javac -Xlint:all -Werror
jjg
parents: 5506
diff changeset
   168
            Class<?> targetClass = (target == null ? memberClass : target.getClass());
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
   169
            if (targetClass != currentClass) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   170
                if (!gotIsSameClassPackage) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   171
                    isSameClassPackage = isSameClassPackage(currentClass, memberClass);
90ce3da70b43 Initial load
duke
parents:
diff changeset
   172
                    gotIsSameClassPackage = true;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   173
                }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   174
                if (!isSameClassPackage) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   175
                    if (!isSubclassOf(targetClass, currentClass)) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   176
                        return false;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   177
                    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   178
                }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   179
            }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   180
        }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   181
90ce3da70b43 Initial load
duke
parents:
diff changeset
   182
        return true;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   183
    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   184
36511
9d0388c6b336 8142968: Module System implementation
alanb
parents: 34882
diff changeset
   185
    /**
9d0388c6b336 8142968: Module System implementation
alanb
parents: 34882
diff changeset
   186
     * Returns {@code true} if memberClass's's module exports memberClass's
9d0388c6b336 8142968: Module System implementation
alanb
parents: 34882
diff changeset
   187
     * package to currentClass's module.
9d0388c6b336 8142968: Module System implementation
alanb
parents: 34882
diff changeset
   188
     */
9d0388c6b336 8142968: Module System implementation
alanb
parents: 34882
diff changeset
   189
    public static boolean verifyModuleAccess(Class<?> currentClass,
9d0388c6b336 8142968: Module System implementation
alanb
parents: 34882
diff changeset
   190
                                             Class<?> memberClass) {
9d0388c6b336 8142968: Module System implementation
alanb
parents: 34882
diff changeset
   191
        return verifyModuleAccess(currentClass.getModule(), memberClass);
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
   192
    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   193
36511
9d0388c6b336 8142968: Module System implementation
alanb
parents: 34882
diff changeset
   194
    public static boolean verifyModuleAccess(Module currentModule, Class<?> memberClass) {
9d0388c6b336 8142968: Module System implementation
alanb
parents: 34882
diff changeset
   195
        Module memberModule = memberClass.getModule();
9d0388c6b336 8142968: Module System implementation
alanb
parents: 34882
diff changeset
   196
9d0388c6b336 8142968: Module System implementation
alanb
parents: 34882
diff changeset
   197
        // module may be null during startup (initLevel 0)
9d0388c6b336 8142968: Module System implementation
alanb
parents: 34882
diff changeset
   198
        if (currentModule == memberModule)
9d0388c6b336 8142968: Module System implementation
alanb
parents: 34882
diff changeset
   199
           return true;  // same module (named or unnamed)
9d0388c6b336 8142968: Module System implementation
alanb
parents: 34882
diff changeset
   200
9d0388c6b336 8142968: Module System implementation
alanb
parents: 34882
diff changeset
   201
        // memberClass may be primitive or array class
9d0388c6b336 8142968: Module System implementation
alanb
parents: 34882
diff changeset
   202
        Class<?> c = memberClass;
9d0388c6b336 8142968: Module System implementation
alanb
parents: 34882
diff changeset
   203
        while (c.isArray()) {
9d0388c6b336 8142968: Module System implementation
alanb
parents: 34882
diff changeset
   204
            c = c.getComponentType();
9d0388c6b336 8142968: Module System implementation
alanb
parents: 34882
diff changeset
   205
        }
9d0388c6b336 8142968: Module System implementation
alanb
parents: 34882
diff changeset
   206
        if (c.isPrimitive())
9d0388c6b336 8142968: Module System implementation
alanb
parents: 34882
diff changeset
   207
            return true;
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
   208
36511
9d0388c6b336 8142968: Module System implementation
alanb
parents: 34882
diff changeset
   209
        // check that memberModule exports the package to currentModule
9d0388c6b336 8142968: Module System implementation
alanb
parents: 34882
diff changeset
   210
        return memberModule.isExported(c.getPackageName(), currentModule);
9d0388c6b336 8142968: Module System implementation
alanb
parents: 34882
diff changeset
   211
    }
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
   212
36511
9d0388c6b336 8142968: Module System implementation
alanb
parents: 34882
diff changeset
   213
    /**
9d0388c6b336 8142968: Module System implementation
alanb
parents: 34882
diff changeset
   214
     * Returns true if two classes in the same package.
9d0388c6b336 8142968: Module System implementation
alanb
parents: 34882
diff changeset
   215
     */
9d0388c6b336 8142968: Module System implementation
alanb
parents: 34882
diff changeset
   216
    private static boolean isSameClassPackage(Class<?> c1, Class<?> c2) {
9d0388c6b336 8142968: Module System implementation
alanb
parents: 34882
diff changeset
   217
        if (c1.getClassLoader() != c2.getClassLoader())
9d0388c6b336 8142968: Module System implementation
alanb
parents: 34882
diff changeset
   218
            return false;
9d0388c6b336 8142968: Module System implementation
alanb
parents: 34882
diff changeset
   219
        while (c1.isArray())
9d0388c6b336 8142968: Module System implementation
alanb
parents: 34882
diff changeset
   220
            c1 = c1.getComponentType();
9d0388c6b336 8142968: Module System implementation
alanb
parents: 34882
diff changeset
   221
        while (c2.isArray())
9d0388c6b336 8142968: Module System implementation
alanb
parents: 34882
diff changeset
   222
            c2 = c2.getComponentType();
9d0388c6b336 8142968: Module System implementation
alanb
parents: 34882
diff changeset
   223
        return Objects.equals(c1.getPackageName(), c2.getPackageName());
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
   224
    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   225
10342
ca0984bc9d32 7077389: Reflection classes do not build with javac -Xlint:all -Werror
jjg
parents: 5506
diff changeset
   226
    static boolean isSubclassOf(Class<?> queryClass,
ca0984bc9d32 7077389: Reflection classes do not build with javac -Xlint:all -Werror
jjg
parents: 5506
diff changeset
   227
                                Class<?> ofClass)
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
   228
    {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   229
        while (queryClass != null) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   230
            if (queryClass == ofClass) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   231
                return true;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   232
            }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   233
            queryClass = queryClass.getSuperclass();
90ce3da70b43 Initial load
duke
parents:
diff changeset
   234
        }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   235
        return false;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   236
    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   237
90ce3da70b43 Initial load
duke
parents:
diff changeset
   238
    // fieldNames must contain only interned Strings
10342
ca0984bc9d32 7077389: Reflection classes do not build with javac -Xlint:all -Werror
jjg
parents: 5506
diff changeset
   239
    public static synchronized void registerFieldsToFilter(Class<?> containingClass,
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
   240
                                              String ... fieldNames) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   241
        fieldFilterMap =
90ce3da70b43 Initial load
duke
parents:
diff changeset
   242
            registerFilter(fieldFilterMap, containingClass, fieldNames);
90ce3da70b43 Initial load
duke
parents:
diff changeset
   243
    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   244
90ce3da70b43 Initial load
duke
parents:
diff changeset
   245
    // methodNames must contain only interned Strings
10342
ca0984bc9d32 7077389: Reflection classes do not build with javac -Xlint:all -Werror
jjg
parents: 5506
diff changeset
   246
    public static synchronized void registerMethodsToFilter(Class<?> containingClass,
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
   247
                                              String ... methodNames) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   248
        methodFilterMap =
90ce3da70b43 Initial load
duke
parents:
diff changeset
   249
            registerFilter(methodFilterMap, containingClass, methodNames);
90ce3da70b43 Initial load
duke
parents:
diff changeset
   250
    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   251
10342
ca0984bc9d32 7077389: Reflection classes do not build with javac -Xlint:all -Werror
jjg
parents: 5506
diff changeset
   252
    private static Map<Class<?>,String[]> registerFilter(Map<Class<?>,String[]> map,
ca0984bc9d32 7077389: Reflection classes do not build with javac -Xlint:all -Werror
jjg
parents: 5506
diff changeset
   253
            Class<?> containingClass, String ... names) {
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
   254
        if (map.get(containingClass) != null) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   255
            throw new IllegalArgumentException
90ce3da70b43 Initial load
duke
parents:
diff changeset
   256
                            ("Filter already registered: " + containingClass);
90ce3da70b43 Initial load
duke
parents:
diff changeset
   257
        }
10342
ca0984bc9d32 7077389: Reflection classes do not build with javac -Xlint:all -Werror
jjg
parents: 5506
diff changeset
   258
        map = new HashMap<Class<?>,String[]>(map);
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
   259
        map.put(containingClass, names);
90ce3da70b43 Initial load
duke
parents:
diff changeset
   260
        return map;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   261
    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   262
10342
ca0984bc9d32 7077389: Reflection classes do not build with javac -Xlint:all -Werror
jjg
parents: 5506
diff changeset
   263
    public static Field[] filterFields(Class<?> containingClass,
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
   264
                                       Field[] fields) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   265
        if (fieldFilterMap == null) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   266
            // Bootstrapping
90ce3da70b43 Initial load
duke
parents:
diff changeset
   267
            return fields;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   268
        }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   269
        return (Field[])filter(fields, fieldFilterMap.get(containingClass));
90ce3da70b43 Initial load
duke
parents:
diff changeset
   270
    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   271
10342
ca0984bc9d32 7077389: Reflection classes do not build with javac -Xlint:all -Werror
jjg
parents: 5506
diff changeset
   272
    public static Method[] filterMethods(Class<?> containingClass, Method[] methods) {
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
   273
        if (methodFilterMap == null) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   274
            // Bootstrapping
90ce3da70b43 Initial load
duke
parents:
diff changeset
   275
            return methods;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   276
        }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   277
        return (Method[])filter(methods, methodFilterMap.get(containingClass));
90ce3da70b43 Initial load
duke
parents:
diff changeset
   278
    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   279
90ce3da70b43 Initial load
duke
parents:
diff changeset
   280
    private static Member[] filter(Member[] members, String[] filteredNames) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   281
        if ((filteredNames == null) || (members.length == 0)) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   282
            return members;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   283
        }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   284
        int numNewMembers = 0;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   285
        for (Member member : members) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   286
            boolean shouldSkip = false;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   287
            for (String filteredName : filteredNames) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   288
                if (member.getName() == filteredName) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   289
                    shouldSkip = true;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   290
                    break;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   291
                }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   292
            }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   293
            if (!shouldSkip) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   294
                ++numNewMembers;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   295
            }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   296
        }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   297
        Member[] newMembers =
90ce3da70b43 Initial load
duke
parents:
diff changeset
   298
            (Member[])Array.newInstance(members[0].getClass(), numNewMembers);
90ce3da70b43 Initial load
duke
parents:
diff changeset
   299
        int destIdx = 0;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   300
        for (Member member : members) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   301
            boolean shouldSkip = false;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   302
            for (String filteredName : filteredNames) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   303
                if (member.getName() == filteredName) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   304
                    shouldSkip = true;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   305
                    break;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   306
                }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   307
            }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   308
            if (!shouldSkip) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   309
                newMembers[destIdx++] = member;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   310
            }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   311
        }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   312
        return newMembers;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   313
    }
16906
44dfee24cb71 8010117: Annotate jdk caller sensitive methods with @sun.reflect.CallerSensitive
mchung
parents: 14342
diff changeset
   314
44dfee24cb71 8010117: Annotate jdk caller sensitive methods with @sun.reflect.CallerSensitive
mchung
parents: 14342
diff changeset
   315
    /**
44dfee24cb71 8010117: Annotate jdk caller sensitive methods with @sun.reflect.CallerSensitive
mchung
parents: 14342
diff changeset
   316
     * Tests if the given method is caller-sensitive and the declaring class
36511
9d0388c6b336 8142968: Module System implementation
alanb
parents: 34882
diff changeset
   317
     * is defined by either the bootstrap class loader or platform class loader.
16906
44dfee24cb71 8010117: Annotate jdk caller sensitive methods with @sun.reflect.CallerSensitive
mchung
parents: 14342
diff changeset
   318
     */
44dfee24cb71 8010117: Annotate jdk caller sensitive methods with @sun.reflect.CallerSensitive
mchung
parents: 14342
diff changeset
   319
    public static boolean isCallerSensitive(Method m) {
44dfee24cb71 8010117: Annotate jdk caller sensitive methods with @sun.reflect.CallerSensitive
mchung
parents: 14342
diff changeset
   320
        final ClassLoader loader = m.getDeclaringClass().getClassLoader();
34882
ce2a8ec851c1 8145544: Move sun.misc.VM to jdk.internal.misc
chegar
parents: 31671
diff changeset
   321
        if (VM.isSystemDomainLoader(loader) || isExtClassLoader(loader))  {
16906
44dfee24cb71 8010117: Annotate jdk caller sensitive methods with @sun.reflect.CallerSensitive
mchung
parents: 14342
diff changeset
   322
            return m.isAnnotationPresent(CallerSensitive.class);
44dfee24cb71 8010117: Annotate jdk caller sensitive methods with @sun.reflect.CallerSensitive
mchung
parents: 14342
diff changeset
   323
        }
44dfee24cb71 8010117: Annotate jdk caller sensitive methods with @sun.reflect.CallerSensitive
mchung
parents: 14342
diff changeset
   324
        return false;
44dfee24cb71 8010117: Annotate jdk caller sensitive methods with @sun.reflect.CallerSensitive
mchung
parents: 14342
diff changeset
   325
    }
44dfee24cb71 8010117: Annotate jdk caller sensitive methods with @sun.reflect.CallerSensitive
mchung
parents: 14342
diff changeset
   326
44dfee24cb71 8010117: Annotate jdk caller sensitive methods with @sun.reflect.CallerSensitive
mchung
parents: 14342
diff changeset
   327
    private static boolean isExtClassLoader(ClassLoader loader) {
44dfee24cb71 8010117: Annotate jdk caller sensitive methods with @sun.reflect.CallerSensitive
mchung
parents: 14342
diff changeset
   328
        ClassLoader cl = ClassLoader.getSystemClassLoader();
44dfee24cb71 8010117: Annotate jdk caller sensitive methods with @sun.reflect.CallerSensitive
mchung
parents: 14342
diff changeset
   329
        while (cl != null) {
44dfee24cb71 8010117: Annotate jdk caller sensitive methods with @sun.reflect.CallerSensitive
mchung
parents: 14342
diff changeset
   330
            if (cl.getParent() == null && cl == loader) {
44dfee24cb71 8010117: Annotate jdk caller sensitive methods with @sun.reflect.CallerSensitive
mchung
parents: 14342
diff changeset
   331
                return true;
44dfee24cb71 8010117: Annotate jdk caller sensitive methods with @sun.reflect.CallerSensitive
mchung
parents: 14342
diff changeset
   332
            }
44dfee24cb71 8010117: Annotate jdk caller sensitive methods with @sun.reflect.CallerSensitive
mchung
parents: 14342
diff changeset
   333
            cl = cl.getParent();
44dfee24cb71 8010117: Annotate jdk caller sensitive methods with @sun.reflect.CallerSensitive
mchung
parents: 14342
diff changeset
   334
        }
44dfee24cb71 8010117: Annotate jdk caller sensitive methods with @sun.reflect.CallerSensitive
mchung
parents: 14342
diff changeset
   335
        return false;
44dfee24cb71 8010117: Annotate jdk caller sensitive methods with @sun.reflect.CallerSensitive
mchung
parents: 14342
diff changeset
   336
    }
36511
9d0388c6b336 8142968: Module System implementation
alanb
parents: 34882
diff changeset
   337
9d0388c6b336 8142968: Module System implementation
alanb
parents: 34882
diff changeset
   338
9d0388c6b336 8142968: Module System implementation
alanb
parents: 34882
diff changeset
   339
    // true to print a stack trace when IAE is thrown
9d0388c6b336 8142968: Module System implementation
alanb
parents: 34882
diff changeset
   340
    private static volatile boolean printStackWhenAccessFails;
9d0388c6b336 8142968: Module System implementation
alanb
parents: 34882
diff changeset
   341
9d0388c6b336 8142968: Module System implementation
alanb
parents: 34882
diff changeset
   342
    // true if printStackWhenAccessFails has been initialized
9d0388c6b336 8142968: Module System implementation
alanb
parents: 34882
diff changeset
   343
    private static volatile boolean printStackWhenAccessFailsSet;
9d0388c6b336 8142968: Module System implementation
alanb
parents: 34882
diff changeset
   344
9d0388c6b336 8142968: Module System implementation
alanb
parents: 34882
diff changeset
   345
    private static void printStackTraceIfNeeded(Throwable e) {
9d0388c6b336 8142968: Module System implementation
alanb
parents: 34882
diff changeset
   346
        if (!printStackWhenAccessFailsSet && VM.initLevel() >= 1) {
9d0388c6b336 8142968: Module System implementation
alanb
parents: 34882
diff changeset
   347
            // can't use method reference here, might be too early in startup
9d0388c6b336 8142968: Module System implementation
alanb
parents: 34882
diff changeset
   348
            PrivilegedAction<Boolean> pa = new PrivilegedAction<Boolean>() {
9d0388c6b336 8142968: Module System implementation
alanb
parents: 34882
diff changeset
   349
                public Boolean run() {
9d0388c6b336 8142968: Module System implementation
alanb
parents: 34882
diff changeset
   350
                    String s;
9d0388c6b336 8142968: Module System implementation
alanb
parents: 34882
diff changeset
   351
                    s = System.getProperty("sun.reflect.debugModuleAccessChecks");
9d0388c6b336 8142968: Module System implementation
alanb
parents: 34882
diff changeset
   352
                    return (s != null && !s.equalsIgnoreCase("false"));
9d0388c6b336 8142968: Module System implementation
alanb
parents: 34882
diff changeset
   353
                }
9d0388c6b336 8142968: Module System implementation
alanb
parents: 34882
diff changeset
   354
            };
9d0388c6b336 8142968: Module System implementation
alanb
parents: 34882
diff changeset
   355
            printStackWhenAccessFails = AccessController.doPrivileged(pa);
9d0388c6b336 8142968: Module System implementation
alanb
parents: 34882
diff changeset
   356
            printStackWhenAccessFailsSet = true;
9d0388c6b336 8142968: Module System implementation
alanb
parents: 34882
diff changeset
   357
        }
9d0388c6b336 8142968: Module System implementation
alanb
parents: 34882
diff changeset
   358
        if (printStackWhenAccessFails) {
9d0388c6b336 8142968: Module System implementation
alanb
parents: 34882
diff changeset
   359
            e.printStackTrace();
9d0388c6b336 8142968: Module System implementation
alanb
parents: 34882
diff changeset
   360
        }
9d0388c6b336 8142968: Module System implementation
alanb
parents: 34882
diff changeset
   361
    }
9d0388c6b336 8142968: Module System implementation
alanb
parents: 34882
diff changeset
   362
9d0388c6b336 8142968: Module System implementation
alanb
parents: 34882
diff changeset
   363
    /**
9d0388c6b336 8142968: Module System implementation
alanb
parents: 34882
diff changeset
   364
     * Throws IllegalAccessException with the an exception message based on
9d0388c6b336 8142968: Module System implementation
alanb
parents: 34882
diff changeset
   365
     * the access that is denied.
9d0388c6b336 8142968: Module System implementation
alanb
parents: 34882
diff changeset
   366
     */
9d0388c6b336 8142968: Module System implementation
alanb
parents: 34882
diff changeset
   367
    private static void throwIllegalAccessException(Class<?> currentClass,
9d0388c6b336 8142968: Module System implementation
alanb
parents: 34882
diff changeset
   368
                                                    Class<?> memberClass,
9d0388c6b336 8142968: Module System implementation
alanb
parents: 34882
diff changeset
   369
                                                    Object target,
9d0388c6b336 8142968: Module System implementation
alanb
parents: 34882
diff changeset
   370
                                                    int modifiers)
9d0388c6b336 8142968: Module System implementation
alanb
parents: 34882
diff changeset
   371
        throws IllegalAccessException
9d0388c6b336 8142968: Module System implementation
alanb
parents: 34882
diff changeset
   372
    {
9d0388c6b336 8142968: Module System implementation
alanb
parents: 34882
diff changeset
   373
        String currentSuffix = "";
9d0388c6b336 8142968: Module System implementation
alanb
parents: 34882
diff changeset
   374
        String memberSuffix = "";
9d0388c6b336 8142968: Module System implementation
alanb
parents: 34882
diff changeset
   375
        Module m1 = currentClass.getModule();
9d0388c6b336 8142968: Module System implementation
alanb
parents: 34882
diff changeset
   376
        if (m1.isNamed())
9d0388c6b336 8142968: Module System implementation
alanb
parents: 34882
diff changeset
   377
            currentSuffix = " (in " + m1 + ")";
9d0388c6b336 8142968: Module System implementation
alanb
parents: 34882
diff changeset
   378
        Module m2 = memberClass.getModule();
9d0388c6b336 8142968: Module System implementation
alanb
parents: 34882
diff changeset
   379
        if (m2.isNamed())
9d0388c6b336 8142968: Module System implementation
alanb
parents: 34882
diff changeset
   380
            memberSuffix = " (in " + m2 + ")";
9d0388c6b336 8142968: Module System implementation
alanb
parents: 34882
diff changeset
   381
9d0388c6b336 8142968: Module System implementation
alanb
parents: 34882
diff changeset
   382
        Class<?> c = memberClass;
9d0388c6b336 8142968: Module System implementation
alanb
parents: 34882
diff changeset
   383
        while (c.isArray()) {
9d0388c6b336 8142968: Module System implementation
alanb
parents: 34882
diff changeset
   384
            c = c.getComponentType();
9d0388c6b336 8142968: Module System implementation
alanb
parents: 34882
diff changeset
   385
        }
9d0388c6b336 8142968: Module System implementation
alanb
parents: 34882
diff changeset
   386
        String memberPackageName = c.getPackageName();
9d0388c6b336 8142968: Module System implementation
alanb
parents: 34882
diff changeset
   387
9d0388c6b336 8142968: Module System implementation
alanb
parents: 34882
diff changeset
   388
        String msg = currentClass + currentSuffix + " cannot access ";
9d0388c6b336 8142968: Module System implementation
alanb
parents: 34882
diff changeset
   389
        if (m2.isExported(memberPackageName, m1)) {
9d0388c6b336 8142968: Module System implementation
alanb
parents: 34882
diff changeset
   390
9d0388c6b336 8142968: Module System implementation
alanb
parents: 34882
diff changeset
   391
            // module access okay so include the modifiers in the message
9d0388c6b336 8142968: Module System implementation
alanb
parents: 34882
diff changeset
   392
            msg += "a member of " + memberClass + memberSuffix +
9d0388c6b336 8142968: Module System implementation
alanb
parents: 34882
diff changeset
   393
                    " with modifiers \"" + Modifier.toString(modifiers) + "\"";
9d0388c6b336 8142968: Module System implementation
alanb
parents: 34882
diff changeset
   394
9d0388c6b336 8142968: Module System implementation
alanb
parents: 34882
diff changeset
   395
        } else {
9d0388c6b336 8142968: Module System implementation
alanb
parents: 34882
diff changeset
   396
            // module access failed
9d0388c6b336 8142968: Module System implementation
alanb
parents: 34882
diff changeset
   397
            msg += memberClass + memberSuffix+ " because "
9d0388c6b336 8142968: Module System implementation
alanb
parents: 34882
diff changeset
   398
                   + m2 + " does not export " + memberPackageName;
9d0388c6b336 8142968: Module System implementation
alanb
parents: 34882
diff changeset
   399
            if (m2.isNamed()) msg += " to " + m1;
9d0388c6b336 8142968: Module System implementation
alanb
parents: 34882
diff changeset
   400
        }
9d0388c6b336 8142968: Module System implementation
alanb
parents: 34882
diff changeset
   401
9d0388c6b336 8142968: Module System implementation
alanb
parents: 34882
diff changeset
   402
        throwIllegalAccessException(msg);
9d0388c6b336 8142968: Module System implementation
alanb
parents: 34882
diff changeset
   403
    }
9d0388c6b336 8142968: Module System implementation
alanb
parents: 34882
diff changeset
   404
9d0388c6b336 8142968: Module System implementation
alanb
parents: 34882
diff changeset
   405
    /**
9d0388c6b336 8142968: Module System implementation
alanb
parents: 34882
diff changeset
   406
     * Throws IllegalAccessException with the given exception message.
9d0388c6b336 8142968: Module System implementation
alanb
parents: 34882
diff changeset
   407
     */
9d0388c6b336 8142968: Module System implementation
alanb
parents: 34882
diff changeset
   408
    public static void throwIllegalAccessException(String msg)
9d0388c6b336 8142968: Module System implementation
alanb
parents: 34882
diff changeset
   409
        throws IllegalAccessException
9d0388c6b336 8142968: Module System implementation
alanb
parents: 34882
diff changeset
   410
    {
9d0388c6b336 8142968: Module System implementation
alanb
parents: 34882
diff changeset
   411
        IllegalAccessException e = new IllegalAccessException(msg);
9d0388c6b336 8142968: Module System implementation
alanb
parents: 34882
diff changeset
   412
        printStackTraceIfNeeded(e);
9d0388c6b336 8142968: Module System implementation
alanb
parents: 34882
diff changeset
   413
        throw e;
9d0388c6b336 8142968: Module System implementation
alanb
parents: 34882
diff changeset
   414
    }
9d0388c6b336 8142968: Module System implementation
alanb
parents: 34882
diff changeset
   415
9d0388c6b336 8142968: Module System implementation
alanb
parents: 34882
diff changeset
   416
    /**
9d0388c6b336 8142968: Module System implementation
alanb
parents: 34882
diff changeset
   417
     * Throws InaccessibleObjectException with the given exception message.
9d0388c6b336 8142968: Module System implementation
alanb
parents: 34882
diff changeset
   418
     */
9d0388c6b336 8142968: Module System implementation
alanb
parents: 34882
diff changeset
   419
    public static void throwInaccessibleObjectException(String msg) {
9d0388c6b336 8142968: Module System implementation
alanb
parents: 34882
diff changeset
   420
        InaccessibleObjectException e = new InaccessibleObjectException(msg);
9d0388c6b336 8142968: Module System implementation
alanb
parents: 34882
diff changeset
   421
        printStackTraceIfNeeded(e);
9d0388c6b336 8142968: Module System implementation
alanb
parents: 34882
diff changeset
   422
        throw e;
9d0388c6b336 8142968: Module System implementation
alanb
parents: 34882
diff changeset
   423
    }
9d0388c6b336 8142968: Module System implementation
alanb
parents: 34882
diff changeset
   424
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
   425
}