1 /*
   2  * Copyright (c) 2001, 2019, 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 jdk.internal.access;
  27 
  28 import java.lang.reflect.*;
  29 import jdk.internal.reflect.*;
  30 
  31 /** An interface which gives privileged packages Java-level access to
  32     internals of java.lang.reflect. */
  33 
  34 public interface JavaLangReflectAccess {
  35     /** Creates a new java.lang.reflect.Field. Access checks as per
  36         java.lang.reflect.AccessibleObject are not overridden. */
  37     public Field newField(Class<?> declaringClass,
  38                           String name,
  39                           Class<?> type,
  40                           int modifiers,
  41                           int slot,
  42                           String signature,
  43                           byte[] annotations);
  44 
  45     /** Creates a new java.lang.reflect.Method. Access checks as per
  46       java.lang.reflect.AccessibleObject are not overridden. */
  47     public Method newMethod(Class<?> declaringClass,
  48                             String name,
  49                             Class<?>[] parameterTypes,
  50                             Class<?> returnType,
  51                             Class<?>[] checkedExceptions,
  52                             int modifiers,
  53                             int slot,
  54                             String signature,
  55                             byte[] annotations,
  56                             byte[] parameterAnnotations,
  57                             byte[] annotationDefault);
  58 
  59     /** Creates a new java.lang.reflect.Constructor. Access checks as
  60       per java.lang.reflect.AccessibleObject are not overridden. */
  61     public <T> Constructor<T> newConstructor(Class<T> declaringClass,
  62                                              Class<?>[] parameterTypes,
  63                                              Class<?>[] checkedExceptions,
  64                                              int modifiers,
  65                                              int slot,
  66                                              String signature,
  67                                              byte[] annotations,
  68                                              byte[] parameterAnnotations);
  69 
  70     /** Gets the MethodAccessor object for a java.lang.reflect.Method */
  71     public MethodAccessor getMethodAccessor(Method m);
  72 
  73     /** Sets the MethodAccessor object for a java.lang.reflect.Method */
  74     public void setMethodAccessor(Method m, MethodAccessor accessor);
  75 
  76     /** Gets the ConstructorAccessor object for a
  77         java.lang.reflect.Constructor */
  78     public ConstructorAccessor getConstructorAccessor(Constructor<?> c);
  79 
  80     /** Sets the ConstructorAccessor object for a
  81         java.lang.reflect.Constructor */
  82     public void setConstructorAccessor(Constructor<?> c,
  83                                        ConstructorAccessor accessor);
  84 
  85     /** Gets the byte[] that encodes TypeAnnotations on an Executable. */
  86     public byte[] getExecutableTypeAnnotationBytes(Executable ex);
  87 
  88     /** Gets the "slot" field from a Constructor (used for serialization) */
  89     public int getConstructorSlot(Constructor<?> c);
  90 
  91     /** Gets the "signature" field from a Constructor (used for serialization) */
  92     public String getConstructorSignature(Constructor<?> c);
  93 
  94     /** Gets the "annotations" field from a Constructor (used for serialization) */
  95     public byte[] getConstructorAnnotations(Constructor<?> c);
  96 
  97     /** Gets the "parameterAnnotations" field from a Constructor (used for serialization) */
  98     public byte[] getConstructorParameterAnnotations(Constructor<?> c);
  99 
 100     /** Gets the shared array of parameter types of an Executable. */
 101     public Class<?>[] getExecutableSharedParameterTypes(Executable ex);
 102 
 103     //
 104     // Copying routines, needed to quickly fabricate new Field,
 105     // Method, and Constructor objects from templates
 106     //
 107 
 108     /** Makes a "child" copy of a Method */
 109     public Method      copyMethod(Method arg);
 110 
 111     /** Makes a copy of this non-root a Method */
 112     public Method      leafCopyMethod(Method arg);
 113 
 114     /** Makes a "child" copy of a Field */
 115     public Field       copyField(Field arg);
 116 
 117     /** Makes a "child" copy of a Constructor */
 118     public <T> Constructor<T> copyConstructor(Constructor<T> arg);
 119 
 120     /** Gets the root of the given AccessibleObject object; null if arg is the root */
 121     public <T extends AccessibleObject> T getRoot(T obj);
 122 
 123     /** Returns a new instance created by the given constructor with access check */
 124     public <T> T newInstance(Constructor<T> ctor, Object[] args, Class<?> caller)
 125         throws IllegalAccessException, InstantiationException, InvocationTargetException;
 126 }