/* * Copyright (c) 2021, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it * under the terms of the GNU General Public License version 2 only, as * published by the Free Software Foundation. Oracle designates this * particular file as subject to the "Classpath" exception as provided * by Oracle in the LICENSE file that accompanied this code. * * This code is distributed in the hope that it will be useful, but WITHOUT * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License * version 2 for more details (a copy is included in the LICENSE file that * accompanied this code). * * You should have received a copy of the GNU General Public License version * 2 along with this work; if not, write to the Free Software Foundation, * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. * * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA * or visit www.oracle.com if you need additional information or have any * questions. */ package jdk.internal.reflect; import java.lang.invoke.MethodHandle; import java.lang.invoke.MethodType; import java.lang.reflect.Field; import java.lang.reflect.Modifier; class MethodHandleDoubleFieldAccessorImpl extends MethodHandleFieldAccessorImpl { static FieldAccessorImpl fieldAccessor(Field field, MethodHandle getter, MethodHandle setter, boolean isReadOnly) { boolean isStatic = Modifier.isStatic(field.getModifiers()); if (isStatic) { getter = getter.asType(MethodType.methodType(double.class)); if (setter != null) { setter = setter.asType(MethodType.methodType(void.class, double.class)); } } else { getter = getter.asType(MethodType.methodType(double.class, Object.class)); if (setter != null) { setter = setter.asType(MethodType.methodType(void.class, Object.class, double.class)); } } return new MethodHandleDoubleFieldAccessorImpl(field, getter, setter, isReadOnly, isStatic); } MethodHandleDoubleFieldAccessorImpl(Field field, MethodHandle getter, MethodHandle setter, boolean isReadOnly, boolean isStatic) { super(field, getter, setter, isReadOnly, isStatic); } public Object get(Object obj) throws IllegalArgumentException { return Double.valueOf(getDouble(obj)); } public boolean getBoolean(Object obj) throws IllegalArgumentException { throw newGetBooleanIllegalArgumentException(); } public byte getByte(Object obj) throws IllegalArgumentException { throw newGetByteIllegalArgumentException(); } public char getChar(Object obj) throws IllegalArgumentException { throw newGetCharIllegalArgumentException(); } public short getShort(Object obj) throws IllegalArgumentException { throw newGetShortIllegalArgumentException(); } public int getInt(Object obj) throws IllegalArgumentException { throw newGetIntIllegalArgumentException(); } public long getLong(Object obj) throws IllegalArgumentException { throw newGetLongIllegalArgumentException(); } public float getFloat(Object obj) throws IllegalArgumentException { throw newGetFloatIllegalArgumentException(); } public double getDouble(Object obj) throws IllegalArgumentException { try { if (isStatic()) { return (double) getter.invokeExact(); } else { return (double) getter.invokeExact(obj); } } catch (IllegalArgumentException|NullPointerException e) { throw e; } catch (ClassCastException e) { throw newGetIllegalArgumentException(obj); } catch (Throwable e) { throw new InternalError(e); } } public void set(Object obj, Object value) throws IllegalArgumentException, IllegalAccessException { ensureObj(obj); if (isReadOnly()) { throwFinalFieldIllegalAccessException(value); } if (value == null) { throwSetIllegalArgumentException(value); } if (value instanceof Byte b) { setDouble(obj, b.byteValue()); } else if (value instanceof Short s) { setDouble(obj, s.shortValue()); } else if (value instanceof Character c) { setDouble(obj, c.charValue()); } else if (value instanceof Integer i) { setDouble(obj, i.intValue()); } else if (value instanceof Long l) { setDouble(obj, l.longValue()); } else if (value instanceof Float f) { setDouble(obj, f.floatValue()); } else if (value instanceof Double d) { setDouble(obj, d.doubleValue()); } else { throwSetIllegalArgumentException(value); } } public void setBoolean(Object obj, boolean z) throws IllegalArgumentException, IllegalAccessException { throwSetIllegalArgumentException(z); } public void setByte(Object obj, byte b) throws IllegalArgumentException, IllegalAccessException { setDouble(obj, b); } public void setChar(Object obj, char c) throws IllegalArgumentException, IllegalAccessException { setDouble(obj, c); } public void setShort(Object obj, short s) throws IllegalArgumentException, IllegalAccessException { setDouble(obj, s); } public void setInt(Object obj, int i) throws IllegalArgumentException, IllegalAccessException { setDouble(obj, i); } public void setLong(Object obj, long l) throws IllegalArgumentException, IllegalAccessException { setDouble(obj, l); } public void setFloat(Object obj, float f) throws IllegalArgumentException, IllegalAccessException { setDouble(obj, f); } public void setDouble(Object obj, double d) throws IllegalArgumentException, IllegalAccessException { if (isReadOnly()) { ensureObj(obj); // throw NPE if obj is null on instance field throwFinalFieldIllegalAccessException(d); } try { if (isStatic()) { setter.invokeExact(d); } else { setter.invokeExact(obj, d); } } catch (IllegalArgumentException|NullPointerException e) { throw e; } catch (ClassCastException e) { // receiver is of invalid type throw newSetIllegalArgumentException(obj); } catch (Throwable e) { throw new InternalError(e); } } }