Package net.sf.saxon.functions
Class DeepEqual
- java.lang.Object
- 
- net.sf.saxon.functions.AbstractFunction
- 
- net.sf.saxon.functions.SystemFunction
- 
- net.sf.saxon.functions.CollatingFunctionFixed
- 
- net.sf.saxon.functions.DeepEqual
 
 
 
 
- 
- All Implemented Interfaces:
- Callable,- StatefulSystemFunction,- Function,- GroundedValue,- Item,- Sequence
 
 public class DeepEqual extends CollatingFunctionFixed XSLT 2.0 deep-equal() function, where the collation is already known. Supports deep comparison of two sequences (of nodes and/or atomic values) optionally using a collation
- 
- 
Field SummaryFields Modifier and Type Field Description static intCOMPARE_ANNOTATIONSFlag indicating that elements and attributes must have the same type annotation to be considered deep-equalstatic intCOMPARE_ID_FLAGSFlag indicating that the is-id and is-idref flags are to be comparedstatic intCOMPARE_STRING_VALUESFlag indicating that elements and attributes should always be compared according to their string value, not their typed valuestatic intEXCLUDE_VARIETYFlag indicating that the variety of the type of a node is to be ignored (for example, a mixed content node can compare equal to an element-only content nodestatic intEXCLUDE_WHITESPACE_TEXT_NODESFlag indicating that whitespace text nodes are ignored when comparing element nodesstatic intINCLUDE_COMMENTSFlag indicating that comment children are taken into account when comparing element or document nodesstatic intINCLUDE_NAMESPACESFlag indicating that two elements should only be considered equal if they have the same in-scope namespacesstatic intINCLUDE_PREFIXESFlag indicating that two element or attribute nodes are considered equal only if their names use the same namespace prefixstatic intINCLUDE_PROCESSING_INSTRUCTIONSFlag indicating that processing instruction nodes are taken into account when comparing element or document nodesstatic intJOIN_ADJACENT_TEXT_NODESFlag indicating that adjacent text nodes in the top-level sequence are to be mergedstatic intWARNING_IF_FALSEFlag indicating that a warning message explaining the reason why the sequences were deemed non-equal should be sent to the ErrorListener
 - 
Constructor SummaryConstructors Constructor Description DeepEqual()
 - 
Method SummaryAll Methods Static Methods Instance Methods Concrete Methods Modifier and Type Method Description BooleanValuecall(XPathContext context, Sequence[] arguments)Execute a dynamic call to the functionstatic booleandeepEqual(SequenceIterator op1, SequenceIterator op2, AtomicComparer comparer, XPathContext context, int flags)Determine when two sequences are deep-equalstatic booleandeepEquals(NodeInfo n1, NodeInfo n2, AtomicComparer comparer, XPathContext context, int flags)java.lang.StringgetStreamerName()Get a name that identifies the class that can be used to evaluate this function in streaming mode, that is, supplying one item or event at a time as it is delivered by the parser.- 
Methods inherited from class net.sf.saxon.functions.CollatingFunctionFixedcopy, exportAttributes, getAtomicComparer, getPreAllocatedAtomicComparer, getStringCollator, importAttributes, isSubstringMatchingFunction, preAllocateComparer, setCollationName, setRetainedStaticContext
 - 
Methods inherited from class net.sf.saxon.functions.SystemFunctiondependsOnContextItem, dynamicCall, equals, export, exportAdditionalArguments, fixArguments, getArity, getCardinality, getCompilerName, getContextNode, getDescription, getDetails, getErrorCodeForTypeErrors, getFunctionItemType, getFunctionName, getIntegerBounds, getNetCost, getOperandRoles, getRequiredType, getResultItemType, getResultItemType, getRetainedStaticContext, getSpecialProperties, getStaticBaseUriString, isTrustedResultType, makeCall, makeFunction, makeFunctionCall, makeOptimizedFunctionCall, resultIfEmpty, setArity, setDetails, supplyTypeInformation, toShortString, toString, typeCheckCaller
 - 
Methods inherited from class net.sf.saxon.functions.AbstractFunctionatomize, deepEquals, effectiveBooleanValue, getAnnotations, getStringValue, getStringValueCS, isArray, isMap, makeNewContext, simplify, typeCheck
 - 
Methods inherited from class java.lang.Objectclone, finalize, getClass, hashCode, notify, notifyAll, wait, wait, wait
 - 
Methods inherited from interface net.sf.saxon.om.GroundedValueasIterable, concatenate, containsNode, materialize
 - 
Methods inherited from interface net.sf.saxon.om.ItemgetLength, head, isStreamed, itemAt, iterate, reduce, subsequence
 - 
Methods inherited from interface net.sf.saxon.om.SequencemakeRepeatable
 
- 
 
- 
- 
- 
Field Detail- 
INCLUDE_NAMESPACESpublic static final int INCLUDE_NAMESPACES Flag indicating that two elements should only be considered equal if they have the same in-scope namespaces- See Also:
- Constant Field Values
 
 - 
INCLUDE_PREFIXESpublic static final int INCLUDE_PREFIXES Flag indicating that two element or attribute nodes are considered equal only if their names use the same namespace prefix- See Also:
- Constant Field Values
 
 - 
INCLUDE_COMMENTSpublic static final int INCLUDE_COMMENTS Flag indicating that comment children are taken into account when comparing element or document nodes- See Also:
- Constant Field Values
 
 - 
INCLUDE_PROCESSING_INSTRUCTIONSpublic static final int INCLUDE_PROCESSING_INSTRUCTIONS Flag indicating that processing instruction nodes are taken into account when comparing element or document nodes- See Also:
- Constant Field Values
 
 - 
EXCLUDE_WHITESPACE_TEXT_NODESpublic static final int EXCLUDE_WHITESPACE_TEXT_NODES Flag indicating that whitespace text nodes are ignored when comparing element nodes- See Also:
- Constant Field Values
 
 - 
COMPARE_STRING_VALUESpublic static final int COMPARE_STRING_VALUES Flag indicating that elements and attributes should always be compared according to their string value, not their typed value- See Also:
- Constant Field Values
 
 - 
COMPARE_ANNOTATIONSpublic static final int COMPARE_ANNOTATIONS Flag indicating that elements and attributes must have the same type annotation to be considered deep-equal- See Also:
- Constant Field Values
 
 - 
WARNING_IF_FALSEpublic static final int WARNING_IF_FALSE Flag indicating that a warning message explaining the reason why the sequences were deemed non-equal should be sent to the ErrorListener- See Also:
- Constant Field Values
 
 - 
JOIN_ADJACENT_TEXT_NODESpublic static final int JOIN_ADJACENT_TEXT_NODES Flag indicating that adjacent text nodes in the top-level sequence are to be merged- See Also:
- Constant Field Values
 
 - 
COMPARE_ID_FLAGSpublic static final int COMPARE_ID_FLAGS Flag indicating that the is-id and is-idref flags are to be compared- See Also:
- Constant Field Values
 
 - 
EXCLUDE_VARIETYpublic static final int EXCLUDE_VARIETY Flag indicating that the variety of the type of a node is to be ignored (for example, a mixed content node can compare equal to an element-only content node- See Also:
- Constant Field Values
 
 
- 
 - 
Method Detail- 
deepEqualpublic static boolean deepEqual(SequenceIterator op1, SequenceIterator op2, AtomicComparer comparer, XPathContext context, int flags) throws XPathException Determine when two sequences are deep-equal- Parameters:
- op1- the first sequence
- op2- the second sequence
- comparer- the comparer to be used
- context- the XPathContext item
- flags- bit-significant integer giving comparison options. Always zero for standard F+O deep-equals comparison.
- Returns:
- true if the sequences are deep-equal
- Throws:
- XPathException- if either sequence contains a function item
 
 - 
deepEqualspublic static boolean deepEquals(NodeInfo n1, NodeInfo n2, AtomicComparer comparer, XPathContext context, int flags) throws XPathException - Throws:
- XPathException
 
 - 
callpublic BooleanValue call(XPathContext context, Sequence[] arguments) throws XPathException Execute a dynamic call to the function- Parameters:
- context- the dynamic evaluation context
- arguments- the values of the arguments, supplied as Sequences.
- Returns:
- the result of the evaluation, in the form of a Sequence. It is the responsibility of the callee to ensure that the type of result conforms to the expected result type.
- Throws:
- XPathException- (should not happen)
 
 - 
getStreamerNamepublic java.lang.String getStreamerName() Description copied from class:SystemFunctionGet a name that identifies the class that can be used to evaluate this function in streaming mode, that is, supplying one item or event at a time as it is delivered by the parser. Special streaming support is generally available in Saxon-EE for all system functions that take a sequence as their argument.- Overrides:
- getStreamerNamein class- SystemFunction
- Returns:
- a name that identifies a class that supports streamed evaluation of this system
 function, or null if no such class is available. The mapping of names to classes is
 defined in the Saxon-EE class StreamerMap. In non-streaming Saxon editions (HE and PE) the method always returns null.
 
 
- 
 
-