1*795d594fSAndroid Build Coastguard Worker /* 2*795d594fSAndroid Build Coastguard Worker * Copyright (C) 2024 The Android Open Source Project 3*795d594fSAndroid Build Coastguard Worker * 4*795d594fSAndroid Build Coastguard Worker * Licensed under the Apache License, Version 2.0 (the "License"); 5*795d594fSAndroid Build Coastguard Worker * you may not use this file except in compliance with the License. 6*795d594fSAndroid Build Coastguard Worker * You may obtain a copy of the License at 7*795d594fSAndroid Build Coastguard Worker * 8*795d594fSAndroid Build Coastguard Worker * http://www.apache.org/licenses/LICENSE-2.0 9*795d594fSAndroid Build Coastguard Worker * 10*795d594fSAndroid Build Coastguard Worker * Unless required by applicable law or agreed to in writing, software 11*795d594fSAndroid Build Coastguard Worker * distributed under the License is distributed on an "AS IS" BASIS, 12*795d594fSAndroid Build Coastguard Worker * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 13*795d594fSAndroid Build Coastguard Worker * See the License for the specific language governing permissions and 14*795d594fSAndroid Build Coastguard Worker * limitations under the License. 15*795d594fSAndroid Build Coastguard Worker */ 16*795d594fSAndroid Build Coastguard Worker 17*795d594fSAndroid Build Coastguard Worker package annotations; 18*795d594fSAndroid Build Coastguard Worker 19*795d594fSAndroid Build Coastguard Worker import java.lang.annotation.ElementType; 20*795d594fSAndroid Build Coastguard Worker import java.lang.annotation.Retention; 21*795d594fSAndroid Build Coastguard Worker import java.lang.annotation.RetentionPolicy; 22*795d594fSAndroid Build Coastguard Worker import java.lang.annotation.Target; 23*795d594fSAndroid Build Coastguard Worker 24*795d594fSAndroid Build Coastguard Worker /** 25*795d594fSAndroid Build Coastguard Worker * This annotation can be set on method to specify that if this method 26*795d594fSAndroid Build Coastguard Worker * is statically invoked then the invocation is replaced by a 27*795d594fSAndroid Build Coastguard Worker * load-constant bytecode with the MethodHandle constant described by 28*795d594fSAndroid Build Coastguard Worker * the annotation. 29*795d594fSAndroid Build Coastguard Worker */ 30*795d594fSAndroid Build Coastguard Worker @Retention(RetentionPolicy.RUNTIME) 31*795d594fSAndroid Build Coastguard Worker @Target(ElementType.METHOD) 32*795d594fSAndroid Build Coastguard Worker public @interface ConstantMethodHandle { 33*795d594fSAndroid Build Coastguard Worker /* Method handle kinds */ 34*795d594fSAndroid Build Coastguard Worker public static final int STATIC_PUT = 0; 35*795d594fSAndroid Build Coastguard Worker public static final int STATIC_GET = 1; 36*795d594fSAndroid Build Coastguard Worker public static final int INSTANCE_PUT = 2; 37*795d594fSAndroid Build Coastguard Worker public static final int INSTANCE_GET = 3; 38*795d594fSAndroid Build Coastguard Worker public static final int INVOKE_STATIC = 4; 39*795d594fSAndroid Build Coastguard Worker public static final int INVOKE_VIRTUAL = 5; 40*795d594fSAndroid Build Coastguard Worker public static final int INVOKE_SPECIAL = 6; 41*795d594fSAndroid Build Coastguard Worker public static final int NEW_INVOKE_SPECIAL = 7; 42*795d594fSAndroid Build Coastguard Worker public static final int INVOKE_INTERFACE = 8; 43*795d594fSAndroid Build Coastguard Worker 44*795d594fSAndroid Build Coastguard Worker /** Kind of method handle. */ kind()45*795d594fSAndroid Build Coastguard Worker int kind(); 46*795d594fSAndroid Build Coastguard Worker 47*795d594fSAndroid Build Coastguard Worker /** Class name owning the field or method. */ owner()48*795d594fSAndroid Build Coastguard Worker String owner(); 49*795d594fSAndroid Build Coastguard Worker 50*795d594fSAndroid Build Coastguard Worker /** The field or method name addressed by the MethodHandle. */ fieldOrMethodName()51*795d594fSAndroid Build Coastguard Worker String fieldOrMethodName(); 52*795d594fSAndroid Build Coastguard Worker 53*795d594fSAndroid Build Coastguard Worker /** Descriptor for the field (type) or method (method-type) */ descriptor()54*795d594fSAndroid Build Coastguard Worker String descriptor(); 55*795d594fSAndroid Build Coastguard Worker 56*795d594fSAndroid Build Coastguard Worker /** Whether the owner is an interface. */ ownerIsInterface()57*795d594fSAndroid Build Coastguard Worker boolean ownerIsInterface() default false; 58*795d594fSAndroid Build Coastguard Worker } 59