javax.management.modelmbean
Class DescriptorSupportjava.lang.Object | +--javax.management.modelmbean.DescriptorSupport
- public class DescriptorSupport
- extends java.lang.Object
- implements Descriptor, java.lang.Cloneable
This class represents the metadata set for a ModelMBean element. A descriptor is part of the ModelMBeanInfo, ModelMBeanNotificationInfo, ModelMBeanAttributeInfo, ModelMBeanConstructorInfo, and ModelMBeanParameterInfo.
A descriptor consists of a collection of fields. Each field is in fieldname=fieldvalue format. Field names are not case sensitive, case will be preserved on field values.
All field names and values are not predefined. New fields can be defined and added by any program. Some fields have been predefined for consistency of implmentation and support by the ModelMBeanInfo ModelMBean*Info, and ModelMBean classes.
- Version:
- 1.17
- Author:
- Max Parlione, Massimo Tarquini, Marco De Gregorio, Eliseba Costantini
- See Also:
- Serialized Form
Field Summary java.lang.String currClass
Constructor Summary
DescriptorSupport()
Descriptor default constructor.DescriptorSupport(DescriptorSupport inDescr)
Descriptor constructor taking a Descriptor as parameter.DescriptorSupport(int initNumFields)
Descriptor constructor.DescriptorSupport(java.lang.String inStr)
Descriptor constructor taking an XML String.DescriptorSupport(java.lang.String[] fields)
Constructor taking fields in the fieldName=fieldValue format.DescriptorSupport(java.lang.String[] fieldNames, java.lang.Object[] fieldValues)
Constructor taking field names and field values.
Method Summary
java.lang.Object clone()
Returns a new Descriptor which is a duplicate of the Descriptor.java.lang.String[] getFieldNames()
Returns all the fields names in the descriptor.java.lang.String[] getFields()
Returns all the fields in the descriptor Specified by: getFields in interface Descriptorjava.lang.Object getFieldValue(java.lang.String inFieldName)
Returns the string value for a specific fieldname Specified by:(We can't find a way to write 'Specified by' to generate a javadoc) getFieldValue in interface Descriptorjava.lang.Object[] getFieldValues(java.lang.String[] fieldNames)
Returns all the field values in the descriptor as an array of Objects.boolean isValid()
Returns true if fieldValues are checked to be sure they are legal for the fieldNames.void removeField(java.lang.String fieldName)
Removes a field from the descriptor Specified by: removeField in interface Descriptorvoid setField(java.lang.String inFieldName, java.lang.Object fieldValue)
Sets the string value for a specific fieldname.void setFields(java.lang.String[] fieldNames, java.lang.Object[] fieldValues)
Sets all Fields in the list to the new value in with the same index in the fieldValue array.java.lang.String toString()
Overrides: toString in class java.lang.Objectjava.lang.String toXMLString()
Methods inherited from class java.lang.Object equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, wait
Field Detail
currClass
public java.lang.String currClass
Constructor Detail
DescriptorSupport
public DescriptorSupport()
- Descriptor default constructor. Default initial descriptor size is 20. It will grow as needed.
DescriptorSupport
public DescriptorSupport(int initNumFields) throws MBeanException, RuntimeOperationsException
- Descriptor constructor. Takes as parameter the initial capacity of the Map that stores the descriptor fields. Capacity will grow as needed.
Parameters:
initNumFields
- The initial capacity of the Map that stores the descriptor fields.
Throws:
- RuntimeOperationsException - for illegal value for maxNumFields ( <= 0)
DescriptorSupport
public DescriptorSupport(DescriptorSupport inDescr)
- Descriptor constructor taking a Descriptor as parameter. Creates a new descriptor initialized to the values of the descriptor passed in parameter.
Parameters:
inDesc
- the descriptor to be used to initialize the constructed descriptor. If it is null or contains no descriptor fields, an empty Descriptor will be created.
Throws:
- RuntimeOperationsException - for illegal value for inDescr. inDescr cannot be null. If the descriptor fails for any reason, this exception will be thrown.
DescriptorSupport
public DescriptorSupport(java.lang.String inStr) throws MBeanException, RuntimeOperationsException, XMLParseException
- Descriptor constructor taking an XML String. This method is part of this implementation and not required by the JMX Specification.
Parameters:
inStr
- An XML-formatted string used to populate this Descriptor The format will be: (INCOMPLETE)
DescriptorSupport
public DescriptorSupport(java.lang.String[] fieldNames, java.lang.Object[] fieldValues) throws RuntimeOperationsException
- Constructor taking field names and field values. The array and array elements cannot be null.
Parameters:
fieldNames
- String array of field names. No elements of this array can be null.fieldValues
- Object array of the corresponding field values. Elements of the array can be null. The fieldValue must be valid for the fieldName. Note: array sizes of parameters should match. If both arrays are null or empty, then an empty descriptor is created. No exception is thrown.
Throws:
- RuntimeOperationsException - for illegal value for field Names or field Values. The array lengths must be equal. If the descriptor construction fails for any reason, this exception will be thrown.
DescriptorSupport
public DescriptorSupport(java.lang.String[] fields)
- Constructor taking fields in the fieldName=fieldValue format.
Parameters:
fields
- String array of with each element containing a field name and value. If this array is null or empty, then the default constructor will be executed. Null strings or empty strings will be ignored. Note: each string should be of the form fieldName=fieldValue, with no imbedded blanks or other punctuation.
Throws:
- RuntimeOperationsException - for illegal value for field Names or field Values. The field must contain an "=". "=fieldValue", "fieldName", and "fieldValue" are illegal. FieldName cannot be null. "fieldName=" will cause the value to be null. If the descriptor construction fails for any reason, this exception will be thrown.
Method Detail
getFieldValue
public java.lang.Object getFieldValue(java.lang.String inFieldName) throws RuntimeOperationsException
- Returns the string value for a specific fieldname Specified by:(We can't find a way to write 'Specified by' to generate a javadoc) getFieldValue in interface Descriptor
- Specified by:
- getFieldValue in interface Descriptor
Parameters:
fieldName
- The field name in question;if not found, null is returned.
Returns:
- String Field value
Throws:
- RuntimeOperationsException - for illegal value (null or empty string) for field Names.
setField
public void setField(java.lang.String inFieldName, java.lang.Object fieldValue) throws RuntimeOperationsException
- Sets the string value for a specific fieldname. The value must be valid for the field. If the field does not exist, it is added. if it does exist, the value is replaced. Specified by: setField in interface Descriptor
- Specified by:
- setField in interface Descriptor
Parameters:
- String - fieldName The field name to be set. Must not be null or empty string.
- String - fieldValue The field value to be set for the field name. Can be null.
Throws:
- RuntimeOperationsException - for illegal value for field Names.
getFields
public java.lang.String[] getFields()
- Returns all the fields in the descriptor Specified by: getFields in interface Descriptor
- Specified by:
- getFields in interface Descriptor
Returns:
- String array of fields in the format fieldName=fieldValue. If there are no fields in the descriptor, then String[0] is returned. If a fieldValue is an object then the toString() method is called on it and its returned value is used as the value for the field enclosed in parens.
Throws:
- RuntimeOperationsException - for illegal value for field Names or Values
getFieldNames
public java.lang.String[] getFieldNames()
- Returns all the fields names in the descriptor. Specified by: getFieldNames in interface Descriptor
- Specified by:
- getFieldNames in interface Descriptor
Returns:
- String array of fields names. If the descriptor is empty, you will get an empty array.
getFieldValues
public java.lang.Object[] getFieldValues(java.lang.String[] fieldNames)
- Returns all the field values in the descriptor as an array of Objects. The retuned values are in the same order as the fieldNames String array parameter. Specified by: getFieldValues in interface Descriptor
- Specified by:
- getFieldValues in interface Descriptor
Parameters:
fieldNames
- String array of the names of the fields that the values should be returned for. If the array is empty then an empty array will be returned. If the array is 'null' then all values will be returned. If a field name in the array does not exist, then null is returned for the matching array element being returned.
Returns:
- Object array of field values. If the descriptor is empty, you will get an empty array.
setFields
public void setFields(java.lang.String[] fieldNames, java.lang.Object[] fieldValues) throws RuntimeOperationsException
- Sets all Fields in the list to the new value in with the same index in the fieldValue array. Array sizes must match. The field value will be validated before it is set. If it is not valid, then an exception will be thrown. If the arrays are empty, then no change will take effect. Specified by: setFields in interface Descriptor
- Specified by:
- setFields in interface Descriptor
Parameters:
fieldNames
- String array of field names. The array and array elements cannot be null.fieldValues
- Object array of the corresponding field values. The array cannot be null. Elements of the array can be null.
Throws:
- RuntimeOperationsException - for illegal value for field Names or field Values. Niether can be null. The array lengths must be equal. If the descriptor construction fails for any reason, this exception will be thrown.
clone
public java.lang.Object clone() throws RuntimeOperationsException
- Returns a new Descriptor which is a duplicate of the Descriptor. Specified by: clone in interface Descriptor Overrides: clone in class java.lang.Object
- Specified by:
- clone in interface Descriptor
- Overrides:
- clone in class java.lang.Object
Throws:
- RuntimeOperationsException - for illegal value for field Names or field Values. If the descriptor construction fails for any reason, this exception will be thrown.
removeField
public void removeField(java.lang.String fieldName)
- Removes a field from the descriptor Specified by: removeField in interface Descriptor
- Specified by:
- removeField in interface Descriptor
Parameters:
fieldName
- String name of the field to be removed. If the field is not found no exception is thrown.
isValid
public boolean isValid() throws RuntimeOperationsException
- Returns true if fieldValues are checked to be sure they are legal for the fieldNames. This implementation returns false if: name or descriptorType fields are null class, role, getMethod and setMethod, if defined, must not be null persistPeriod, currencyTimeLimit, lastUpdatedTimeStamp, lastReturnedTimeStamp must numerics greater than -1. iterable, log, export must be t, f, true, or false visibility must be between 1 and 4 severity must be betwen 0 and 5 persistPolicy must be OnUpdate,OnTimer, NoMoreOftenThan,Always,or Never is must not be case sensitive. Specified by: isValid in interface Descriptor
- Specified by:
- isValid in interface Descriptor
Throws:
- RuntimeOperationsException - If the validity checking fails for any reason, this exception will be thrown.
toXMLString
public java.lang.String toXMLString()
Returns:
- an XML String representing the descriptor. The XML string will be formatted for each field with " NAME=name VALUE=fieldValue TYPE=String|Object|ClassName>" The format will be: RuntimeOperationsException - for illegal value for field Names or field Values. If the XML formated string construction fails for any reason, this exception will be thrown.
toString
public java.lang.String toString()
- Overrides: toString in class java.lang.Object
- Overrides:
- toString in class java.lang.Object
Returns:
- a human readable string representing the descriptor The string will be in the format of "fieldName=fieldValue,fieldName2=fieldValue2,..."
Throws:
- RuntimeOperationsException - for illegal value for field Names or field Values. If the descriptor string fails for any reason, this exception will be thrown.