Changes specific to .NET
The XsltExecutable object has a new Explain() method that gives a diagnostic representation of the compiled code (as an XML document).
The Equals() and GetHashCode() methods on XdmNode are now defined so that two XdmNode instances are
equal if and only if they represent the same node (that is, they reflect the XPath "is" operator).
The XPathCompiler object now has the ability to maintain a cache of compiled XPath expressions. If this feature is enabled, any attempt to compile
an expression first causes a lookup in the cache to see whether the same expression has already been compiled. The cache is cleared
if any changes to the static context are made (for example, changing the namespace declarations in force).
The XPathCompiler object has two new convenience methods, Evaluate() and EvaluateSingle(), allowing
an expression to be compiled and executed with a single call. This works especially well when the compiler is also caching compiled expressions.
The error handling in the XPath API has been improved so that static and dynamic errors occurring during XPath
evaluation now result in a Saxon.Api.StaticError or Saxon.Api.DynamicError being thrown,
rather than exposing the underlying Java exceptions.
The XQueryEvaluator has a new method CallFunction that allows any user-declared function within the
compiled query to be called directly from the Java application. This in effect enables the creation of a query library containing
multiple functions that can be invoked from the calling application. Note that to compile a query, it must still have a "main query"
to satisfy the syntax rules of the XQuery language.
There is a new overload of DocumentBuilder.Build() that allows the XML document to be supplied from a TextReader
rather than a stream (including a StringReader, which makes it easier to build from XML held as a string literal).