1 /*
2 * Copyright (c) 2021, 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.reflect;
27
28 import java.lang.invoke.MethodHandle;
29 import java.lang.invoke.MethodType;
30 import java.lang.reflect.Field;
31 import java.lang.reflect.Modifier;
32
33 class MethodHandleByteFieldAccessorImpl extends MethodHandleFieldAccessorImpl {
34 static FieldAccessorImpl fieldAccessor(Field field, MethodHandle getter, MethodHandle setter, boolean isReadOnly) {
35 boolean isStatic = Modifier.isStatic(field.getModifiers());
36 if (isStatic) {
37 getter = getter.asType(MethodType.methodType(byte.class));
38 if (setter != null) {
39 setter = setter.asType(MethodType.methodType(void.class, byte.class));
40 }
41 } else {
42 getter = getter.asType(MethodType.methodType(byte.class, Object.class));
43 if (setter != null) {
44 setter = setter.asType(MethodType.methodType(void.class, Object.class, byte.class));
45 }
46 }
47 return new MethodHandleByteFieldAccessorImpl(field, getter, setter, isReadOnly, isStatic);
48 }
49
50 MethodHandleByteFieldAccessorImpl(Field field, MethodHandle getter, MethodHandle setter, boolean isReadOnly, boolean isStatic) {
51 super(field, getter, setter, isReadOnly, isStatic);
52 }
53
54 public Object get(Object obj) throws IllegalArgumentException {
55 return Byte.valueOf(getByte(obj));
56 }
57
58 public boolean getBoolean(Object obj) throws IllegalArgumentException {
59 throw newGetBooleanIllegalArgumentException();
60 }
61
62 public byte getByte(Object obj) throws IllegalArgumentException {
63 try {
64 if (isStatic()) {
65 return (byte) getter.invokeExact();
66 } else {
67 return (byte) getter.invokeExact(obj);
68 }
69 } catch (IllegalArgumentException|NullPointerException e) {
70 throw e;
71 } catch (ClassCastException e) {
72 throw newGetIllegalArgumentException(obj);
73 } catch (Throwable e) {
74 throw new InternalError(e);
75 }
76 }
77
78 public char getChar(Object obj) throws IllegalArgumentException {
79 throw newGetCharIllegalArgumentException();
80 }
81
82 public short getShort(Object obj) throws IllegalArgumentException {
83 return getByte(obj);
84 }
85
86 public int getInt(Object obj) throws IllegalArgumentException {
87 return getByte(obj);
88 }
89
90 public long getLong(Object obj) throws IllegalArgumentException {
91 return getByte(obj);
92 }
93
94 public float getFloat(Object obj) throws IllegalArgumentException {
95 return getByte(obj);
96 }
97
98 public double getDouble(Object obj) throws IllegalArgumentException {
99 return getByte(obj);
100 }
101
102 public void set(Object obj, Object value)
103 throws IllegalArgumentException, IllegalAccessException
104 {
105 ensureObj(obj);
106 if (isReadOnly()) {
107 throwFinalFieldIllegalAccessException(value);
108 }
109
110 if (value == null) {
111 throwSetIllegalArgumentException(value);
112 }
113
114 if (value instanceof Byte b) {
115 setByte(obj, b.byteValue());
116 } else {
117 throwSetIllegalArgumentException(value);
118 }
119 }
120
121 public void setBoolean(Object obj, boolean z)
122 throws IllegalArgumentException, IllegalAccessException
123 {
124 throwSetIllegalArgumentException(z);
125 }
126
127 public void setByte(Object obj, byte b)
128 throws IllegalArgumentException, IllegalAccessException
129 {
130 if (isReadOnly()) {
131 ensureObj(obj); // throw NPE if obj is null on instance field
132 throwFinalFieldIllegalAccessException(b);
133 }
134 try {
135 if (isStatic()) {
136 setter.invokeExact(b);
137 } else {
138 setter.invokeExact(obj, b);
139 }
140 } catch (IllegalArgumentException|NullPointerException e) {
141 throw e;
142 } catch (ClassCastException e) {
143 // receiver is of invalid type
144 throw newSetIllegalArgumentException(obj);
145 } catch (Throwable e) {
146 throw new InternalError(e);
147 }
148 }
149
150 public void setChar(Object obj, char c)
151 throws IllegalArgumentException, IllegalAccessException
152 {
153 throwSetIllegalArgumentException(c);
154 }
155
156 public void setShort(Object obj, short s)
157 throws IllegalArgumentException, IllegalAccessException
158 {
159 throwSetIllegalArgumentException(s);
160 }
161
162 public void setInt(Object obj, int i)
163 throws IllegalArgumentException, IllegalAccessException
164 {
165 throwSetIllegalArgumentException(i);
166 }
167
168 public void setLong(Object obj, long l)
169 throws IllegalArgumentException, IllegalAccessException
170 {
171 throwSetIllegalArgumentException(l);
172 }
173
174 public void setFloat(Object obj, float f)
175 throws IllegalArgumentException, IllegalAccessException
176 {
177 throwSetIllegalArgumentException(f);
178 }
179
180 public void setDouble(Object obj, double d)
181 throws IllegalArgumentException, IllegalAccessException
182 {
183 throwSetIllegalArgumentException(d);
184 }
185 }