All Downloads are FREE. Search and download functionalities are using the official Maven repository.

META-INF.modules.java.desktop.classes.javax.swing.ClientPropertyKey Maven / Gradle / Ivy

/*
 * Copyright (c) 2006, 2012, 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 javax.swing;

import sun.awt.AWTAccessor;

/**
 * An enumeration for keys used as client properties within the Swing
 * implementation.
 * 

* This enum holds only a small subset of the keys currently used within Swing, * but we may move more of them here in the future. *

* Adding an item to, and using, this class instead of {@code String} for * client properties protects against conflicts with developer-set client * properties. Using this class also avoids a problem with {@code StringBuilder} * and {@code StringBuffer} keys, whereby the keys are not recognized upon * deserialization. *

* When a client property value associated with one of these keys does not * implement {@code Serializable}, the result during serialization depends * on how the key is defined here. Historically, client properties with values * not implementing {@code Serializable} have simply been dropped and left out * of the serialized representation. To define keys with such behavior in this * enum, provide a value of {@code false} for the {@code reportValueNotSerializable} * property. When migrating existing properties to this enum, one may wish to * consider using this by default, to preserve backward compatibility. *

* To instead have a {@code NotSerializableException} thrown when a * {@code non-Serializable} property is encountered, provide the value of * {@code true} for the {@code reportValueNotSerializable} property. This * is useful when the property represents something that the developer * needs to know about when it cannot be serialized. * * @author Shannon Hickey */ enum ClientPropertyKey { /** * Key used by JComponent for storing InputVerifier. */ JComponent_INPUT_VERIFIER(true), /** * Key used by JComponent for storing TransferHandler. */ JComponent_TRANSFER_HANDLER(true), /** * Key used by JComponent for storing AncestorNotifier. */ JComponent_ANCESTOR_NOTIFIER(true), /** * Key used by PopupFactory to force heavy weight popups for a * component. */ PopupFactory_FORCE_HEAVYWEIGHT_POPUP(true); /** * Whether or not a {@code NotSerializableException} should be thrown * during serialization, when the value associated with this key does * not implement {@code Serializable}. */ private final boolean reportValueNotSerializable; static { AWTAccessor.setClientPropertyKeyAccessor( new AWTAccessor.ClientPropertyKeyAccessor() { public Object getJComponent_TRANSFER_HANDLER() { return JComponent_TRANSFER_HANDLER; } }); } /** * Constructs a key with the {@code reportValueNotSerializable} property * set to {@code false}. */ private ClientPropertyKey() { this(false); } /** * Constructs a key with the {@code reportValueNotSerializable} property * set to the given value. */ private ClientPropertyKey(boolean reportValueNotSerializable) { this.reportValueNotSerializable = reportValueNotSerializable; } /** * Returns whether or not a {@code NotSerializableException} should be thrown * during serialization, when the value associated with this key does * not implement {@code Serializable}. */ public boolean getReportValueNotSerializable() { return reportValueNotSerializable; } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy