src.com.ibm.as400.vaccess.VSystemPool Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of jt400 Show documentation
Show all versions of jt400 Show documentation
The Open Source version of the IBM Toolbox for Java
///////////////////////////////////////////////////////////////////////////////
//
// JTOpen (IBM Toolbox for Java - OSS version)
//
// Filename: VSystemPool.java
//
// The source code contained herein is licensed under the IBM Public License
// Version 1.0, which has been approved by the Open Source Initiative.
// Copyright (C) 1997-2000 International Business Machines Corporation and
// others. All rights reserved.
//
///////////////////////////////////////////////////////////////////////////////
package com.ibm.as400.vaccess;
import com.ibm.as400.access.AS400;
import com.ibm.as400.access.Trace;
import com.ibm.as400.access.SystemPool;
import com.ibm.as400.access.SystemStatus;
import javax.swing.Icon;
import javax.swing.SwingConstants;
import javax.swing.table.DefaultTableColumnModel;
import javax.swing.table.TableCellRenderer;
import javax.swing.table.TableColumn;
import javax.swing.table.TableColumnModel;
import javax.swing.tree.TreeNode;
import java.beans.PropertyChangeListener;
import java.beans.PropertyVetoException;
import java.beans.VetoableChangeListener;
import java.io.IOException;
import java.io.ObjectInputStream;
import java.io.Serializable;
import java.util.Enumeration;
/**
* The VSystemPool class defines the representation of system pool on a
* system for use in various models and panes in this package.
*
* Most errors are reported as ErrorEvents rather than throwing exceptions.
* Users should listen for ErrorEvents in order to diagnose and recover
* from error conditions.
*
*
VSystemPool objects generate the following events:
*
* - ErrorEvent
*
- VObjectEvent
*
- WorkingEvent
*
@deprecated Use Java Swing instead, along with the classes in package com.ibm.as400.access
**/
public class VSystemPool
implements VObject, Serializable
{
private static final String copyright = "Copyright (C) 1997-2000 International Business Machines Corporation and others.";
private static final Icon icon16_ = ResourceLoader.getIcon("VSystemPool16.gif");
private static final Icon icon32_ = ResourceLoader.getIcon("VSystemPool32.gif");
/**
The property identifier for the system pool identifier.
**/
public static String IDENTIFIER_PROPERTY = "System pool";
/**
The property identifier for the pool size.
**/
public static String POOL_SIZE_PROPERTY = "Pool size";
/**
The property identifier for the reserved size.
**/
public static String RESERVED_SIZE_PROPERTY = "Reserved size";
private SystemPool systemPool_ = null;
private transient VAction[] actions_;
transient private VPropertiesPane propertiesPane_;
// Event support.
transient private ErrorEventSupport errorEventSupport_;
transient private PropertyChangeSupport propertyChangeSupport_;
transient private VetoableChangeSupport vetoableChangeSupport_;
transient private VObjectEventSupport objectEventSupport_;
transient private WorkingEventSupport workingEventSupport_;
// The variable representing if the modify action is allowed.
private boolean allowModify_ = false;
/**
* Constructs a VSystemPool object.
**/
public VSystemPool ()
{
systemPool_ = null;
initializeTransient ();
}
/**
* Constructs a VSystemPool object.
*
* @param systemPool The SystemPool object.
**/
public VSystemPool (SystemPool systemPool)
{
if (systemPool == null)
throw new NullPointerException ("systemPool");
systemPool_ = systemPool;
systemPool_.setCaching(true); //@B1A
initializeTransient ();
}
/**
* Adds a listener to be notified when an error occurs.
*
* @param listener The listener.
**/
public void addErrorListener (ErrorListener listener)
{
errorEventSupport_.addErrorListener (listener);
}
/**
* Adds a listener to be notified when the value of any bound property
* changes.
*
* @param listener The listener.
**/
public void addPropertyChangeListener (PropertyChangeListener listener)
{
propertyChangeSupport_.addPropertyChangeListener (listener);
}
/**
* Adds a listener to be notified when the value of any constrained
* property changes.
*
* @param listener The listener.
**/
public void addVetoableChangeListener (VetoableChangeListener listener)
{
vetoableChangeSupport_.addVetoableChangeListener (listener);
}
/**
* Adds a listener to be notified when a VObject is changed, created,
* or deleted.
*
* @param listener The listener.
**/
public void addVObjectListener (VObjectListener listener)
{
objectEventSupport_.addVObjectListener (listener);
}
/**
* Adds a listener to be notified when work starts and stops
* on potentially long-running operations.
*
* @param listener The listener.
**/
public void addWorkingListener (WorkingListener listener)
{
workingEventSupport_.addWorkingListener (listener);
}
/**
* Invoked when an error has occurred.
*
* @param event The error event.
**/
public void errorOccurred (ErrorEvent event)
{
errorEventSupport_.errorOccurred(event);
}
/**
* Returns the list of actions that can be performed.
*
* @return Always null. There are no actions.
**/
public VAction[] getActions ()
{
return actions_;
}
/**
* Returns the default action.
*
* @return Always null. There is no default action.
**/
public VAction getDefaultAction ()
{
return null;
}
/**
* Returns the icon.
*
* @param size The icon's size, either 16 or 32. If any other value
* is given, a default one will be returned.
* @param open This parameter has no effect.
* @return The icon.
**/
public Icon getIcon (int size, boolean open)
{
if (size == 32)
return icon32_;
else
return icon16_;
}
/**
* Returns the properties pane.
*
* @return The properties pane.
**/
public VPropertiesPane getPropertiesPane ()
{
return propertiesPane_;
}
/**
* Returns a property value.
*
* @param propertyIdentifier The property identifier.
* @return The property value, or null if the property identifier
* is not recognized.
**/
public Object getPropertyValue (Object propertyIdentifier)
{
try //@B1A
{
// Get the name.
if (propertyIdentifier==NAME_PROPERTY)
return this;
else if(propertyIdentifier==DESCRIPTION_PROPERTY)
{
return systemPool_.getDescription();
}
else if(propertyIdentifier==IDENTIFIER_PROPERTY)
{
return Integer.toString(systemPool_.getPoolIdentifier());
}
else if(propertyIdentifier==POOL_SIZE_PROPERTY)
{
return Integer.toString(systemPool_.getPoolSize());
}
else if(propertyIdentifier==RESERVED_SIZE_PROPERTY)
{
return Integer.toString(systemPool_.getReservedSize());
}
else
return null; // By default, return null.
}
catch(Exception e) //@B1A
{
Trace.log(Trace.ERROR, "Unable to getPropertyValue for VSystemPool.", e); //@B1A
errorEventSupport_.fireError(e); //@B1A
return null;
}
}
/**
* Returns the system in which the system pool information resides.
*
* @return The system in which the system pool information resides.
**/
public AS400 getSystem ()
{
return systemPool_.getSystem();
}
/**
* Returns the systemPool.
*
* @return The systemPool, or null if it has not been set.
**/
public SystemPool getSystemPool ()
{
return systemPool_;
}
/**
* Returns the text which is the system pool name.
*
* @return The text which is the system pool name.
**/
public String getText ()
{
if (systemPool_ != null)
return systemPool_.getPoolName ();
else
return "";
}
/**
* Initializes the transient data.
**/
private void initializeTransient ()
{
// Initialize the event support.
errorEventSupport_ = new ErrorEventSupport (this);
objectEventSupport_ = new VObjectEventSupport (this);
propertyChangeSupport_ = new PropertyChangeSupport (this);
vetoableChangeSupport_ = new VetoableChangeSupport (this);
workingEventSupport_ = new WorkingEventSupport (this);
// Initialize the properties pane.
propertiesPane_ = new SystemPoolPropertiesPane (this, systemPool_);
propertiesPane_.addErrorListener (errorEventSupport_);
propertiesPane_.addVObjectListener (objectEventSupport_);
propertiesPane_.addWorkingListener (workingEventSupport_);
actions_ = new VAction[1];
actions_[0]= new VSystemPoolModifyAction(this,systemPool_);
actions_[0].addErrorListener(((ErrorListener)errorEventSupport_));
actions_[0].addWorkingListener(((WorkingListener)workingEventSupport_));
}
/**
* Returns true if the modify action is allowed, false otherwise.
*
* @return true if the modify action is allowed, false otherwise.
**/
public boolean isAllowModify()
{
return allowModify_;
}
/**
* Loads information about the object from the system.
**/
public void load ()
{
if (systemPool_ != null) systemPool_.refreshCache(); //@B1A
}
/**
* Restores the state of the object from an input stream.
* This is used when deserializing an object.
*
* @param in The input stream.
**/
private void readObject (ObjectInputStream in)
throws IOException, ClassNotFoundException
{
in.defaultReadObject ();
initializeTransient ();
}
/**
* Removes an error listener.
*
* @param listener The listener.
**/
public void removeErrorListener (ErrorListener listener)
{
errorEventSupport_.removeErrorListener (listener);
}
/**
* Removes a property change listener.
*
* @param listener The listener.
**/
public void removePropertyChangeListener (PropertyChangeListener listener)
{
propertyChangeSupport_.removePropertyChangeListener (listener);
}
/**
* Removes a vetoable change listener.
*
* @param listener The listener.
**/
public void removeVetoableChangeListener(VetoableChangeListener listener)
{
vetoableChangeSupport_.removeVetoableChangeListener (listener);
}
/**
* Removes a VObjectListener.
*
* @param listener The listener.
**/
public void removeVObjectListener (VObjectListener listener)
{
objectEventSupport_.removeVObjectListener (listener);
}
/**
* Removes a working listener.
*
* @param listener The listener.
**/
public void removeWorkingListener (WorkingListener listener)
{
workingEventSupport_.removeWorkingListener (listener);
}
/**
* Set the state of modify action.
*
* @param allowModify The boolean value.
**/
public void setAllowModify(boolean allowModify)
{
allowModify_ = allowModify;
for(int i=0; i
© 2015 - 2025 Weber Informatics LLC | Privacy Policy