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

ajava.beans.beancontext.BeanContextChild Maven / Gradle / Ivy

Go to download

Adapted (moved from java.beans to ajava.beans) OpenJDK8 javabeans for Android. It's used by A-Jetty (Jetty 9.2 adapted for Android.)

There is a newer version: 1.0.2
Show newest version
/*
 * Copyright (c) 1997, 2013, 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 ajava.beans.beancontext;

import ajava.beans.PropertyChangeListener;
import ajava.beans.VetoableChangeListener;
import ajava.beans.PropertyVetoException;

import ajava.beans.beancontext.BeanContext;

/**
 * 

* JavaBeans wishing to be nested within, and obtain a reference to their * execution environment, or context, as defined by the BeanContext * sub-interface shall implement this interface. *

*

* Conformant BeanContexts shall as a side effect of adding a BeanContextChild * object shall pass a reference to itself via the setBeanContext() method of * this interface. *

*

* Note that a BeanContextChild may refuse a change in state by throwing * PropertyVetoedException in response. *

*

* In order for persistence mechanisms to function properly on BeanContextChild * instances across a broad variety of scenarios, implementing classes of this * interface are required to define as transient, any or all fields, or * instance variables, that may contain, or represent, references to the * nesting BeanContext instance or other resources obtained * from the BeanContext via any unspecified mechanisms. *

* * @author Laurence P. G. Cable * @since 1.2 * * @see ajava.beans.beancontext.BeanContext * @see ajava.beans.PropertyChangeEvent * @see ajava.beans.PropertyChangeListener * @see ajava.beans.PropertyVetoException * @see ajava.beans.VetoableChangeListener */ public interface BeanContextChild { /** *

* Objects that implement this interface, * shall fire a ajava.beans.PropertyChangeEvent, with parameters: * * propertyName "beanContext", oldValue (the previous nesting * BeanContext instance, or null), * newValue (the current nesting * BeanContext instance, or null). *

* A change in the value of the nesting BeanContext property of this * BeanContextChild may be vetoed by throwing the appropriate exception. *

* @param bc The BeanContext with which * to associate this BeanContextChild. * @throws PropertyVetoException if the * addition of the specified BeanContext is refused. */ void setBeanContext(BeanContext bc) throws PropertyVetoException; /** * Gets the BeanContext associated * with this BeanContextChild. * @return the BeanContext associated * with this BeanContextChild. */ BeanContext getBeanContext(); /** * Adds a PropertyChangeListener * to this BeanContextChild * in order to receive a PropertyChangeEvent * whenever the specified property has changed. * @param name the name of the property to listen on * @param pcl the PropertyChangeListener to add */ void addPropertyChangeListener(String name, PropertyChangeListener pcl); /** * Removes a PropertyChangeListener from this * BeanContextChild so that it no longer * receives PropertyChangeEvents when the * specified property is changed. * * @param name the name of the property that was listened on * @param pcl the PropertyChangeListener to remove */ void removePropertyChangeListener(String name, PropertyChangeListener pcl); /** * Adds a VetoableChangeListener to * this BeanContextChild * to receive events whenever the specified property changes. * @param name the name of the property to listen on * @param vcl the VetoableChangeListener to add */ void addVetoableChangeListener(String name, VetoableChangeListener vcl); /** * Removes a VetoableChangeListener from this * BeanContextChild so that it no longer receives * events when the specified property changes. * @param name the name of the property that was listened on. * @param vcl the VetoableChangeListener to remove. */ void removeVetoableChangeListener(String name, VetoableChangeListener vcl); }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy