FileDocCategorySizeDatePackage
MonitoredAttributeBase.javaAPI DocJava SE 5 API2790Fri Aug 26 14:54:38 BST 2005com.sun.corba.se.spi.monitoring

MonitoredAttributeBase.java

/*
 * @(#)MonitoredAttributeBase.java	1.3 03/12/19
 * 
 * Copyright 2004 Sun Microsystems, Inc. All rights reserved.
 * SUN PROPRIETARY/CONFIDENTIAL. Use is subject to license terms.
 */
package com.sun.corba.se.spi.monitoring;

import java.util.*;

/**
 * <p>
 *
 * @author Hemanth Puttaswamy
 * </p>
 * <p>
 *  A Convenient class provided to help users extend and implement only 
 *  getValue(), if there is no need to clear the state and the attribute is not 
 *  writable.
 * 
 * </p>
 */
public abstract class MonitoredAttributeBase implements MonitoredAttribute {
    String name;
    MonitoredAttributeInfo attributeInfo;
    /**
     * Constructor.
     */
    public MonitoredAttributeBase( String name, MonitoredAttributeInfo info ) {
        this.name = name;
        this.attributeInfo = info;
    }

    
    /**
     * A Package Private Constructor for internal use only.
     */
    MonitoredAttributeBase( String name ) {
        this.name = name;
    }


    /**
     * A Package Private convenience method for setting MonitoredAttributeInfo
     * for this Monitored Attribute.
     */
    void setMonitoredAttributeInfo( MonitoredAttributeInfo info ) {
        this.attributeInfo = info;
    }

    /**
     *  If the concrete class decides not to provide the implementation of this
     *  method, then it's OK. Some of the  examples where we may decide to not 
     *  provide the implementation is the connection state. Irrespective of 
     *  the call to clearState, the connection state will be showing the 
     *  currect state of the connection.
     *  NOTE: This method is only used to clear the Monitored Attribute state, 
     *  not the real state of the system itself. 
     */
    public void clearState( ) {
    }

    /**
     *  This method should be implemented by the concrete class.
     */
    public abstract Object getValue( );

    /**
     *  This method should be implemented by the concrete class only if the 
     *  attribute is writable. If the attribute is not writable and if this 
     *  method called, it will result in an IllegalStateException.
     */ 
    public void setValue( Object value ) {
        if( !attributeInfo.isWritable() ) {
            throw new IllegalStateException( 
                "The Attribute " + name + " is not Writable..." );
        }
        throw new IllegalStateException( 
            "The method implementation is not provided for the attribute " + 
            name );
    }

    
    /**
     *  Gets the MonitoredAttributeInfo for the attribute.
     */
    public MonitoredAttributeInfo getAttributeInfo( ) {
        return attributeInfo;
    }

    /**
     * Gets the name of the attribute.
     */
    public String getName( ) {
        return name;
    } 
} // end MonitoredAttributeBase