public class ObjectValue extends AtomicValue
typeLabelINDETERMINATE_ORDERINGEMPTY_VALUE_ARRAY| Constructor and Description |
|---|
ObjectValue()
Default constructor for use in subclasses
|
ObjectValue(java.lang.Object object)
Constructor
|
ObjectValue(java.lang.Object object,
ExternalObjectType type)
Constructor
|
| Modifier and Type | Method and Description |
|---|---|
ConversionResult |
convertPrimitive(BuiltInAtomicType requiredType,
boolean validate,
ConversionRules rules)
Convert to target data type
|
AtomicValue |
copyAsSubType(AtomicType typeLabel)
Create a copy of this atomic value, with a different type label
|
java.lang.String |
displayTypeName()
Display the type name for use in error messages
|
boolean |
effectiveBooleanValue()
Get the effective boolean value of the value
|
boolean |
equals(java.lang.Object other)
Determine if two ObjectValues are equal
|
ItemType |
getItemType(TypeHierarchy th)
Determine the data type of the items in the expression, if possible
|
java.lang.Object |
getObject()
Get the encapsulated object
|
java.lang.CharSequence |
getPrimitiveStringValue()
Get the value as a String
|
BuiltInAtomicType |
getPrimitiveType()
Determine the primitive type of the value.
|
java.lang.Comparable |
getSchemaComparable()
Get a Comparable value that implements the XML Schema ordering comparison semantics for this value.
|
java.lang.Object |
getXPathComparable(boolean ordered,
StringCollator collator,
XPathContext context)
Get an object value that implements the XPath equality and ordering comparison semantics for this value.
|
int |
hashCode() |
void |
setValue(java.lang.Object value)
Set the value in this object value
|
asAtomic, checkPermittedContents, convert, convert, convert, getCardinality, getComponent, getLength, getStringValue, getStringValueCS, getTypedValue, getTypeLabel, isIdentical, isNaN, itemAt, iterate, process, setTypeLabel, subsequence, toStringasItem, asItem, asIterator, asValue, convertToJava, fromItem, getCanonicalLexicalRepresentation, getIterator, iterate, reducepublic ObjectValue()
public ObjectValue(java.lang.Object object)
object - the object to be encapsulatedpublic ObjectValue(java.lang.Object object,
ExternalObjectType type)
object - the object to be encapsulatedtype - the type of the external objectpublic void setValue(java.lang.Object value)
value - the external value to be wrappedpublic AtomicValue copyAsSubType(AtomicType typeLabel)
copyAsSubType in class AtomicValuetypeLabel - the type label of the new copy. The caller is responsible for checking that
the value actually conforms to this type.public BuiltInAtomicType getPrimitiveType()
getPrimitiveType in class AtomicValuepublic ItemType getItemType(TypeHierarchy th)
getItemType in class AtomicValueth - The TypeHierarchy.public java.lang.String displayTypeName()
public ConversionResult convertPrimitive(BuiltInAtomicType requiredType, boolean validate, ConversionRules rules)
convertPrimitive in class AtomicValuerequiredType - the required atomic type. This must either be a primitive type, or a built-in
type derived from the same primitive type as this atomic value.validate - true if validation is required. If set to false, the caller guarantees that
the value is valid for the target data type, and that further validation
is therefore not required.
Note that a validation failure may be reported even if validation was not requested.public java.lang.CharSequence getPrimitiveStringValue()
getPrimitiveStringValue in class AtomicValuepublic boolean effectiveBooleanValue()
throws XPathException
effectiveBooleanValue in class AtomicValueXPathException - if any dynamic error occurs evaluating the
expressionpublic java.lang.Object getObject()
public java.lang.Comparable getSchemaComparable()
AtomicValueIn the case of data types that are partially ordered, the returned Comparable extends the standard
semantics of the compareTo() method by returning the value Value.INDETERMINATE_ORDERING when there
is no defined order relationship between two given values. This value is also returned when two values
of different types are compared.
getSchemaComparable in class AtomicValuepublic java.lang.Object getXPathComparable(boolean ordered,
StringCollator collator,
XPathContext context)
getXPathComparable in class AtomicValueordered - true if an ordered comparison is required. In this case the result is null if the
type is unordered; in other cases the returned value will be a Comparable.collator - context - the XPath dynamic evaluation context, used in cases where the comparison is context
sensitive @return an Object whose equals() and hashCode() methods implement the XPath comparison semanticspublic boolean equals(java.lang.Object other)
equals in class AtomicValueother - the other valuejava.lang.ClassCastException - if they are not comparable