public class UnsignedIntType extends LongType
java.lang.Long
.
See http://www.w3.org/TR/xmlschema-2/#unsignedInt for the spec
We don't have language support for unsigned datatypes, so things are not so easy.
UnsignedIntType uses a LongType as a base implementation, for the convenience and
faster performance.Modifier and Type | Field and Description |
---|---|
static UnsignedIntType |
theInstance |
ERR_DUPLICATE_FACET, ERR_EMPTY_UNION, ERR_ENUMERATION, ERR_ENUMERATION_WITH_ARG, ERR_FACET_MUST_BE_NON_NEGATIVE_INTEGER, ERR_FACET_MUST_BE_POSITIVE_INTEGER, ERR_INAPPROPRIATE_FOR_TYPE, ERR_INCONSISTENT_FACETS_1, ERR_INCONSISTENT_FACETS_2, ERR_INVALID_BASE_TYPE, ERR_INVALID_ITEMTYPE, ERR_INVALID_MEMBER_TYPE, ERR_INVALID_VALUE_FOR_THIS_TYPE, ERR_INVALID_WHITESPACE_VALUE, ERR_LENGTH, ERR_LOOSENED_FACET, ERR_MAXLENGTH, ERR_MINLENGTH, ERR_NOT_APPLICABLE_FACET, ERR_OUT_OF_RANGE, ERR_OVERRIDING_FIXED_FACET, ERR_PARSE_ERROR, ERR_PATTERN_1, ERR_PATTERN_MANY, ERR_SCALE_IS_GREATER_THAN_PRECISION, ERR_TOO_MUCH_PRECISION, ERR_TOO_MUCH_SCALE, ERR_X_AND_Y_ARE_EXCLUSIVE, serializedValueChecker, whiteSpace
EQUAL, GREATER, LESS, UNDECIDABLE
APPLICABLE, DERIVATION_BY_LIST, DERIVATION_BY_RESTRICTION, DERIVATION_BY_UNION, FACET_ENUMERATION, FACET_FRACTIONDIGITS, FACET_LENGTH, FACET_MAXEXCLUSIVE, FACET_MAXINCLUSIVE, FACET_MAXLENGTH, FACET_MINEXCLUSIVE, FACET_MININCLUSIVE, FACET_MINLENGTH, FACET_PATTERN, FACET_TOTALDIGITS, FACET_WHITESPACE, FIXED, NOT_ALLOWED, VARIETY_ATOMIC, VARIETY_LIST, VARIETY_UNION, XMLSCHEMA_NSURI
Modifier and Type | Method and Description |
---|---|
Object |
_createValue(String lexicalValue,
org.relaxng.datatype.ValidationContext context)
converts a whitespace-processed lexical value into the corresponding value object
|
protected boolean |
checkFormat(String content,
org.relaxng.datatype.ValidationContext context) |
int |
compare(Object o1,
Object o2)
compare to value types and decides its order relation
|
String |
convertToLexicalValue(Object value,
SerializationContext context)
converts value object back to the corresponding value in the lexical space.
|
protected static XSDatatypeImpl |
createRangeFacet(XSDatatypeImpl baseType,
Number min,
Number max)
Apply a range facet.
|
XSDatatype |
getBaseType()
gets the base type of this type.
|
DataTypeWithFacet |
getFacetObject(String facetName)
gets the facet object that restricts the specified facet
|
int |
isFacetApplicable(String facetName)
returns if the specified facet is applicable to this datatype.
|
protected static String |
removeOptionalPlus(String s)
removes leading optional '+' sign.
|
getJavaObjectType, load, save
displayName, getVariety, readResolve
_checkValid, _createJavaObject, getConcreteType, isFinal, serializeJavaObject
checkValid, createJavaObject, createStreamingValidator, createValue, getAncestorBuiltinType, getApplicableFacetNames, getIdType, getName, getNamespaceUri, isAlwaysValid, isContextDependent, isDerivedTypeOf, isDerivedTypeOf, isValid, localize, localize, localize, localize, localize, needValueCheck, sameValue, valueHashCode
public static final UnsignedIntType theInstance
public final XSDatatype getBaseType()
XSDatatype
This method is intended to capture the semantics of the base type definition property of the simple type component, but there is an important difference.
Specifically, if you derive a type D from another type B, then calling D.getBaseType() does not necessarily return B. Instead, it may return an intermediate object (that represents a facet). Calling the getBaseType method recursively will eventually return B.
getBaseType
in interface XSDatatype
getBaseType
in class LongType
public Object _createValue(String lexicalValue, org.relaxng.datatype.ValidationContext context)
XSDatatypeImpl
_createValue
in class LongType
public final int isFacetApplicable(String facetName)
XSDatatype
isFacetApplicable
in interface XSDatatype
public DataTypeWithFacet getFacetObject(String facetName)
XSDatatypeImpl
getFacetObject
in interface XSDatatype
getFacetObject
in class XSDatatypeImpl
protected final boolean checkFormat(String content, org.relaxng.datatype.ValidationContext context)
checkFormat
in class XSDatatypeImpl
public String convertToLexicalValue(Object value, SerializationContext context)
XSDatatype
This method does the reverse operation of the createValue method. The returned string is not necessarily the canonical representation. Also note that the implementation may accept invalid values without throwing IllegalArgumentException. To make sure that the result is actually a valid representation, call the isValid method.
Be careful not to confuse this method with
The serializeJavaObject method, which is defined in
the DatabindableDatatype
method.
convertToLexicalValue
in interface XSDatatype
context
- Context information that will be possibly used for the conversion.
Currently, this object is used only by QName, but may be extended
in the future.public final int compare(Object o1, Object o2)
Comparator
compare
in interface Comparator
protected static String removeOptionalPlus(String s)
protected static XSDatatypeImpl createRangeFacet(XSDatatypeImpl baseType, Number min, Number max)
Copyright © 2016 Oracle Corporation. All rights reserved.