Edit C:\Program Files\Java\jdk1.8.0_121\javafx\beans\property\adapter\ReadOnlyJavaBeanFloatProperty.java
/* * Copyright (c) 2011, 2015, Oracle and/or its affiliates. All rights reserved. * ORACLE PROPRIETARY/CONFIDENTIAL. Use is subject to license terms. * * * * * * * * * * * * * * * * * * * * */ package javafx.beans.property.adapter; import com.sun.javafx.property.adapter.Disposer; import com.sun.javafx.property.adapter.ReadOnlyPropertyDescriptor; import javafx.beans.property.ReadOnlyFloatPropertyBase; import java.lang.reflect.InvocationTargetException; import java.lang.reflect.UndeclaredThrowableException; import java.security.AccessController; import java.security.AccessControlContext; import java.security.PrivilegedAction; import sun.reflect.misc.MethodUtil; /** * A {@code ReadOnlyJavaBeanFloatProperty} provides an adapter between a regular * read only Java Bean property of type {@code float} or {@code Float} and a JavaFX * {@code ReadOnlyFloatProperty}. It cannot be created directly, but a * {@link ReadOnlyJavaBeanFloatPropertyBuilder} has to be used. * <p> * As a minimum, the Java Bean must implement a getter for the * property. If the getter of an instance of this class is called, the property of * the Java Bean is returned. If the Java Bean property is bound (i.e. it supports * PropertyChangeListeners), this {@code ReadOnlyJavaBeanFloatProperty} will be * aware of changes in the Java Bean. Otherwise it can be notified about * changes by calling {@link #fireValueChangedEvent()}. * * @see javafx.beans.property.ReadOnlyFloatProperty * @see ReadOnlyJavaBeanFloatPropertyBuilder * @since JavaFX 2.1 */ public final class ReadOnlyJavaBeanFloatProperty extends ReadOnlyFloatPropertyBase implements ReadOnlyJavaBeanProperty<Number> { private final ReadOnlyPropertyDescriptor descriptor; private final ReadOnlyPropertyDescriptor.ReadOnlyListener<Number> listener; private final AccessControlContext acc = AccessController.getContext(); ReadOnlyJavaBeanFloatProperty(ReadOnlyPropertyDescriptor descriptor, Object bean) { this.descriptor = descriptor; this.listener = descriptor.new ReadOnlyListener<Number>(bean, this); descriptor.addListener(listener); Disposer.addRecord(this, new DescriptorListenerCleaner(descriptor, listener)); } /** * {@inheritDoc} * * @throws UndeclaredThrowableException if calling the getter of the Java Bean * property throws an {@code IllegalAccessException} or an * {@code InvocationTargetException}. */ @Override public float get() { return AccessController.doPrivileged((PrivilegedAction<Float>) () -> { try { return ((Number)MethodUtil.invoke( descriptor.getGetter(), getBean(), (Object[])null)).floatValue(); } catch (IllegalAccessException e) { throw new UndeclaredThrowableException(e); } catch (InvocationTargetException e) { throw new UndeclaredThrowableException(e); } }, acc); } /** * {@inheritDoc} */ @Override public Object getBean() { return listener.getBean(); } /** * {@inheritDoc} */ @Override public String getName() { return descriptor.getName(); } /** * {@inheritDoc} */ @Override public void fireValueChangedEvent() { super.fireValueChangedEvent(); } /** * {@inheritDoc} */ @Override public void dispose() { descriptor.removeListener(listener); } }
Ms-Dos/Windows
Unix
Write backup
jsp File Browser version 1.2 by
www.vonloesch.de