Package com.saxonica.ee.schema
Class PreprocessFacet
- java.lang.Object
- 
- com.saxonica.ee.schema.Facet
- 
- com.saxonica.ee.schema.PreprocessFacet
 
 
- 
 public class PreprocessFacet extends Facet Represents the preprocess facet on a schema-defined simple type. This is a pre-lexical facet defined as a Saxon extension to XML Schema 1.1: it allows an XPath expression to be used to convert the value as written (after whitespace normalization) to a different form, which is then validated using the constraining facets. For example the preprocessing action translate($value, ',', '.') allows the input value 3,14159 to be converted to 3.14159 which then validates as a double.
- 
- 
Constructor SummaryConstructors Constructor Description PreprocessFacet()PreprocessFacet(Assertion action, Assertion reverseAction)
 - 
Method SummaryAll Methods Instance Methods Concrete Methods Modifier and Type Method Description voidcheckFacetRestriction(UserSimpleType type, SimpleType base, SchemaCompiler compiler)Check that this facet is legal when used on a type derived by restrictionAssertiongetAction()Get the XPath expression representing the action performed by this facet, represented as an Assertion objectFunctiongetFacetAsFunctionItem()Get a function item that represents this Facet schema component.java.lang.StringgetName()Returns the name of this FacetAssertiongetReverseAction()Get the XPath expression representing the reverse action performed by this facet, represented as an Assertion objectjava.lang.StringgetValue()Returns the lexical representation of this facetbooleanisConstraining()Ask whether this is a constraining facet (as distinct from a pre-lexical facet)java.lang.CharSequencepostprocess(java.lang.CharSequence input)Apply the postprocessing defined by this facetjava.lang.CharSequencepreprocess(java.lang.CharSequence input)Apply the preprocessing defined by this facetvoidserializeFacet(SchemaModelSerializer serializer)Serialize this facet when externalizing the schema component modelvoidsetAction(Assertion action)Set the XPath expression representing the action performed by this facet, represented as an Assertion objectvoidsetReverseAction(Assertion action)Set the XPath expression representing the reverse action performed by this facet, represented as an Assertion objectbooleantestAtomicValue(AtomicValue value)Test whether an atomic value conforms to this facet- 
Methods inherited from class com.saxonica.ee.schema.FacetgetConstraintName, getMessage, getWhitespaceAction, isFacetName, isFixed, isNewlyIntroduced, makeFacet, setFixed, setMessage, testLength, testListValue, toLong
 
- 
 
- 
- 
- 
Method Detail- 
isConstrainingpublic boolean isConstraining() Ask whether this is a constraining facet (as distinct from a pre-lexical facet)- Overrides:
- isConstrainingin class- Facet
- Returns:
- true if this is a constraining facet
 
 - 
getNamepublic java.lang.String getName() Description copied from class:FacetReturns the name of this Facet
 - 
getValuepublic java.lang.String getValue() Returns the lexical representation of this facet
 - 
getActionpublic Assertion getAction() Get the XPath expression representing the action performed by this facet, represented as an Assertion object
 - 
getReverseActionpublic Assertion getReverseAction() Get the XPath expression representing the reverse action performed by this facet, represented as an Assertion object
 - 
setActionpublic void setAction(Assertion action) Set the XPath expression representing the action performed by this facet, represented as an Assertion object
 - 
setReverseActionpublic void setReverseAction(Assertion action) Set the XPath expression representing the reverse action performed by this facet, represented as an Assertion object
 - 
checkFacetRestrictionpublic void checkFacetRestriction(UserSimpleType type, SimpleType base, SchemaCompiler compiler) throws SchemaException, ValidationException Check that this facet is legal when used on a type derived by restriction- Overrides:
- checkFacetRestrictionin class- Facet
- Parameters:
- base- the type from which the restricted type is derived
- compiler-
- type- the type on which the facet is defined
- Throws:
- SchemaException- if the facet is not legal
- ValidationException- if a value is found that does not conform to the facet
 
 - 
preprocesspublic java.lang.CharSequence preprocess(java.lang.CharSequence input) throws ValidationExceptionApply the preprocessing defined by this facet- Parameters:
- input- the lexical value, after whitespace normalization, to be converted
- Returns:
- the value after preprocessing using the XPath expression defined in this facet
- Throws:
- ValidationException
 
 - 
postprocesspublic java.lang.CharSequence postprocess(java.lang.CharSequence input) throws ValidationExceptionApply the postprocessing defined by this facet- Parameters:
- input- the lexical value to be converted
- Returns:
- the value after postprocessing using the reverse XPath expression defined in this facet
- Throws:
- ValidationException
 
 - 
testAtomicValuepublic boolean testAtomicValue(AtomicValue value) Test whether an atomic value conforms to this facet- Specified by:
- testAtomicValuein class- Facet
- Parameters:
- value- the value to be tested
- Returns:
- true if the value conforms; false if it doesn't conform, or if the test fails
 
 - 
serializeFacetpublic void serializeFacet(SchemaModelSerializer serializer) throws XPathException Description copied from class:FacetSerialize this facet when externalizing the schema component model- Overrides:
- serializeFacetin class- Facet
- Parameters:
- serializer- receives the content for serialization
- Throws:
- XPathException- if an error occurs writing the value to the output
 
 - 
getFacetAsFunctionItempublic Function getFacetAsFunctionItem() Description copied from class:FacetGet a function item that represents this Facet schema component.- Specified by:
- getFacetAsFunctionItemin class- Facet
 
 
- 
 
-