This page contains archive information about past Saxon releases. For information on the most recent releases, see Latest releases.
To download older commercial products (Saxon-EE and Saxon-PE) see Earlier releases. For older releases of the open-source product Saxon-HE visit the Saxon-Archive GitHub repository.
Saxon 10.9 maintenance release for Java and .NET, released 16 February 2023.
Saxon 10.8 maintenance release for Java and .NET, released 15 March 2022.
Saxon 10.7 maintenance release for Java and .NET, released 1 March 2022.
Saxon 10.6 maintenance release for Java and .NET, released 16 September 2021.
Saxon 10.5 maintenance release for Java and .NET, released 14 April 2021.
Saxon 10.3 maintenance release for Java and .NET, released 28 October 2020. With this release, we are now recommending Saxon 10 as the most stable and reliable release for production use.
Saxon 10.2 maintenance release for Java, and first release for .NET, released 26 August 2020.
Saxon 10.1 maintenance release for Java, released 14 May 2020.
Saxon 10.0, the first release in this series for Java, released 16 March 2020.
10 feels like a special number, and marks something of a milestone, although to be honest it's only called 10 because it happens to be the 31st major release since 7.0 came out back in 2002. Think of it as the culmination of 18 years' work, think of it as the dawn of a new era, or just think of it as Saxonica carrying on doing what we're good at.
As always there's a minutely detailed list of changes in the Change history section of the documentation, but to save you time, here are the "top ten" highlights that we think will be most popular:
Higher order functions and xsl:evaluate are now available in Saxon-HE.
An interactive command-line utility named Gizmo is available for ad-hoc querying and updating of documents.
A new API is provided for easy and efficient tree construction, based on modern API design ideas using fluent and immutable objects. These complement the stream-based API introduced in 9.9 for tree navigation.
XSLT and XPath provide an optional switch to allow unprefixed names to ignore
namespaces, so the path /a/b/c
matches elements with local names "a",
"b", and "c" regardless of namespace. Ideal for ad-hoc queries where namespaces just
get in the way, as well as queries on single-namespace documents.
HTML serialization now generates HTML5 by default (support for html-version="4" is retained if explicitly requested).
Saxon now integrates with the new date-and-time handling features in Java 8,
including a new extension function saxon:parse-dateTime()
that builds on Java date parsing capabilities.
Many new extension functions are available, most of them taking advantage of the
power of higher-order functions. For example,
saxon:replace-with("Chapter 13", "[0-9]+", function($x){number($x)+1})
returns "Chapter 14".
Saxon 10 includes experimental implementations of a number of powerful new XSLT and XPath features, which Saxonica has put forward for inclusion in a new version 4.0 of the standards. These include tuple types, named item types, streamlined syntax for inline functions and conditional instructions, XSLT instructions to handle arrays, and enhancements to XSLT patterns to make JSON transformation much easier. These features are only available if explicitly enabled.
A number of extensions to XML Schema 1.1 are provided: list data types can be constrained to be distinct and/or ordered, and can use a separator other than whitespace; elements in a sequence can also be constrained to appear in ascending or descending order.
As always, there has been significant internal re-engineering to keep the code
performant and maintainable. A significant change is in the way namespaces are
represented both in the tree model (the NodeInfo
interface) and in the
push pipeline (the Receiver
interface): both now deliver namespace maps
representing complete sets of namespace bindings, rather than individual namespace
declarations and undeclarations. The main benefit is that copying of trees with many
namespaces is significantly faster.
For further details, see the Saxon 10 feature matrix.
Saxon 10 requires Java 8 or higher. (A .NET version is available from 10.2.) Saxon 10 can export compiled stylesheets in the form of SEF files suitable for reading either by Saxon 10, or by Saxon-JS 2; SEF files cannot be used with earlier releases.
Saxon 9.9.1.8 maintenance release for Java and .NET, released 22 October 2020.
Saxon 9.9.1.7 maintenance release for Java and .NET, released 4 March 2020.
Saxon 9.9.1.6 maintenance release for Java and .NET, released 6 December 2019.
Saxon 9.9.1.5 maintenance release for Java and .NET, released 5 September 2019.
Saxon 9.9.1.4 maintenance release for Java and .NET, released 28 June 2019.
Saxon 9.9.1.3 maintenance release for Java and .NET, released 15 May 2019.
Saxon 9.9.1.2 maintenance release for Java and .NET, released 12 March 2019.
Saxon 9.9.1.1 maintenance release for Java, and first release for .NET, released 21 January 2019.
Saxon 9.9.0.2 maintenance release for Java, released 7 November 2018.
Saxon 9.9.0.1, the first release in this series for Java, released 27 September 2018.
Saxon 9.9 is the first major release for 15 months. For the first time, there are no new W3C standards to chase, though we've inevitably found a few forgotten corners where conformance work was needed. On the whole though, this release has given us an opportunity to think about what users need other than W3C conformance. There's a long list of enhancements in the change log at Change history, but here are what we consider the top ten:
There's a significant extension of the s9api interface to provide XDM tree navigation.
Under the
hood, this takes advantage of Java 8 streams. As an alternative to using XPath expressions
such as
XdmValue selectedBooks = xpath.evaluate("//book[author='" + key + "']", doc);
you can now
write doc.select(descendant("book").where(eq(child("author"), key)).asXdmValue();
There's a usability benefit because you're only using one language (Java) rather than two (Java+XPath), and there's a performance benefit because it cuts out the expensive XPath parsing stage. It also reduces the risk of injection attacks, and is likely to detect more programming errors at compile time. To make this work, we're now requiring a baseline of Java 8.
Tuple types extend the XPath type system to provide better type checking of complex
data structures.
If you're representing employee data as a map, then instead of declaring it as map(xs:string, item()*)
,
you can now declare it as tuple(empNr: xs:string, dob: xs:date, name: element(personalName))
. The result
is more readable code, better type checking (meaning faster debugging), and better
performance. The
extension has been implemented in such a way that it can be used without compromising
the portability of
your code to other XSLT 3.0 processors.
Arrays, like maps, now have an internal implementation that means updates to individual entries in the array don't require the whole array to be copied, giving substantial performance improvements for applications that use arrays heavily.
Improvements have been implemented to the TinyTree data structure to further reduce memory usage, and to enable zero-cost copying of subtrees from one tree to another in the course of a transformation.
A number of powerful new extension instructions and functions are provided to enable
easier query and
update of the trees of maps and arrays that typically arise when processing JSON input.
For example, the
instruction <saxon:deep-update root="json-doc('empData.json')" select="?*[?customer='Jones']?orders"
action="array:append($order)"/>
reads and parses a JSON file, adds a new order for a selected
customer, and returns a data structure representing the modified data set, which can
then be serialized
using the JSON output method.
Streamed accumulators, as defined in the XSLT 3.0 Recommendation, are extended with
a new feature: by
annotating an accumulator rule with the attribute saxon:capture="yes"
, an entire element from the source
document can be captured as the value of the accumulator. For example this can be
used to capture the
header section at the start of a document and make it available for reference while
the rest of the
document is processed using pure streaming.
The updating primitives of the XQuery Update specification are now available for use in XSLT via Saxon-defined extension instructions. These make many simple updates (such as "delete all comments") easier to express and faster in execution, without sacrificing the declarative nature of the XSLT language. For a future release we are thinking about new data structures that make such updates very efficient, avoiding the need to copy all the data in the source document that has not changed.
The XPath lookup operator "?" has been exploited to provide easier call-out from XSLT
and XQuery to
Java code. For example, if the variable $connection
holds a SQL database connection obtained using the
sql:connect()
extension function, then the expression $connection?isClosed()
calls the Java method
isClosed
defined on the underlying connection object.
The ability for an XSLT stylesheet to produce "raw" output (for example, a sequence
of integers
rather than an XML document), as envisaged in the XSLT 3.0 specification, is now much
better supported
in the Saxon API. A new RawDestination
is available to define the destination of a
transformation. Internally, there has been a significant tidying-up of the interface
between the
transformation engine and a destination such as a Serializer
.
There have been further improvements to diagnostics on type errors. This applies especially
when
passing complex data structures between templates and functions using maps. In general,
instead of
telling you that the expected type was X but the supplied value V was an instance
of Y, the message now
tells you in what way V fails to conform to the type X: for example, if X is map{xs:string, node()}
and
V contains an entry whose key is of type xs:untypedAtomic, then the error message
in 9.8 would tell you
that V is an instance of map{xs:anyAtomicType, node()}
, while 9.9 will tell you that V is not an
instance of map{xs:string, node()}
because it contains a key whose type is xs:untypedAtomic and whose
value is (say) "Idaho".
For further details, see the Saxon 9.9 feature matrix.
Saxon 9.8.0.15 maintenance release for Java and .NET, released 6 November 2018.
Saxon 9.8.0.14 maintenance release for Java and .NET, released 25 July 2018.
Saxon 9.8.0.12 maintenance release for Java and .NET, released 9 May 2018.
Saxon 9.8.0.11 maintenance release for Java and .NET, released 19 March 2018.
Saxon 9.8.0.10 maintenance release for Java and .NET, released 16 March 2018.
Saxon 9.8.0.8 maintenance release for Java and .NET, released 5 February 2018.
Saxon 9.8.0.7 maintenance release for Java and .NET, released 20 December 2017.
Saxon 9.8.0.6 maintenance release for Java and .NET, released 30 October 2017.
Saxon 9.8.0.5 maintenance release for Java and .NET, released 5 October 2017.
Saxon 9.8.0.4 maintenance release for Java and .NET, released 16 August 2017.
Saxon 9.8.0.3 maintenance release for Java and .NET, released 6 July 2017.
Saxon 9.8.0.2 maintenance release for Java and .NET, released 21 June 2017.
Saxon 9.8.0.1, the first release in this series for Java and .NET, released 8 June 2017.
For further details, see the Saxon 9.8 feature matrix.
Saxon 9.7.0.21 maintenance release for Java and .NET, released 5 December 2017.
Saxon 9.7.0.20 maintenance release for Java and .NET, released 28 July 2017.
Saxon 9.7.0.19 maintenance release for Java and .NET, released 7 July 2017.
Saxon 9.7.0.18 maintenance release for Java and .NET, released 5 April 2017.
Saxon 9.7.0.15 maintenance release for Java and .NET, released 7 February 2017.
Saxon 9.7.0.14 maintenance release for Java and .NET, released 2 December 2016.
Saxon 9.7.0.13 maintenance release for Java and .NET, released 28 November 2016.
Saxon 9.7.0.12 maintenance release for Java and .NET, released 22 November 2016.
Saxon 9.7.0.11 maintenance release for Java and .NET, released 2 November 2016.
Saxon 9.7.0.10 maintenance release for Java and .NET, released 21 October 2016.
Saxon 9.7.0.8 maintenance release for Java and .NET, released 1 September 2016.
Saxon 9.7.0.7 maintenance release for Java and .NET, released 15 July 2016.
Saxon 9.7.0.6 maintenance release for Java and .NET, released 17 June 2016.
Saxon 9.7.0.5 maintenance release for Java and .NET, released 12 May 2016.
Saxon 9.7.0.4 maintenance release for Java and .NET, released 11 March 2016.
Saxon 9.7.0.3 maintenance release for Java, released 18 February 2016.
Saxon 9.7.0.2 maintenance release for Java, released 19 January 2016.
The first release in this series, Saxon 9.7.0.1 for Java, was issued 27 November 2015.
random-number-generator()
, and parse-ietf-date()
. For further details, see the Saxon 9.7 feature matrix.
Saxon 9.6.0.10 maintenance release for Java and .NET, released 2 December 2016.
Saxon 9.6.0.9 maintenance release for Java and .NET, released 26 May 2016.
Saxon 9.6.0.8 maintenance release for Java and .NET, released 10 December 2015.
Saxon 9.6.0.7 maintenance release for Java and .NET, released 5 August 2015.
Saxon 9.6.0.6 maintenance release for Java and .NET, released 5 June 2015.
Saxon 9.6.0.5 maintenance release for Java and .NET, released 27 March 2015.
Saxon 9.6.0.4 maintenance release for Java and .NET, released 14 January 2015.
Saxon 9.6.0.3 maintenance release for Java and .NET, released 2 December 2014.
Saxon 9.6.0.2 maintenance release for Java and .NET, released 13 November 2014.
The first release in this series, Saxon 9.6.0.1 for Java, was issued 2 October 2014.
For further details, see the Saxon 9.6 feature matrix.
Saxon 9.5.1.10 maintenance release for Java and .NET, released 15 April 2015.
Saxon 9.5.1.8 maintenance release for Java and .NET, released 31 October 2014.
Saxon 9.5.1.6 maintenance release for Java and .NET, released 10 July 2014.
The first release in this series, 9.5.0.1, was issued 16 April 2013.
Saxon/C 1.2.1 maintenance release for C/C++, PHP and Python, released 28 October 2019.
Saxon/C 1.2.0, the first release in this series for the C/C++, PHP and Python programming languages, built from Saxon 9.9.1.5, released 16 October 2019.
APIs are available to run XSLT 3.0, XQuery 3.1, XPath 3.1, and Schema Validation from C/C++, PHP or Python applications. Saxon/C 1.2.0 is built from the Saxon 9.9 Java product using the Excelsior JET Enterprise tool (version 15.3 MP1).
Saxon/C is available in the standard Saxon range of editions: the open-source product Saxon-HE/C, and the commercial products Saxon-PE/C and Saxon-EE/C. Separate downloads are available to run on Linux, Mac OS X and Windows.
Saxon/C 1.1.3 Windows only maintenance release (to fix a Windows specific bug 4192) released on 11 April 2019.
Saxon/C 1.1.2 maintenance release for C/C++/PHP platforms, built from Saxon 9.8.0.15, released 21 February 2019.
Saxon/C 1.1.0, the first release in this series for C/C++/PHP platforms, built from Saxon 9.8.0.4, released 27 September 2017.
APIs are available to run XSLT 3.0, XQuery 3.1, XPath 3.1, and Schema Validation from C/C++ or PHP applications. Saxon/C 1.1.2 is built from the Saxon 9.8 Java product using the Excelsior JET tool (version 15.3 MP1).
Saxon-C is available in the standard Saxon range of editions: the open-source product Saxon-HE/C, and the commercial products Saxon-PE/C and Saxon-EE/C.
Saxon/C 1.0.2 maintenance release for C/C++ platforms, released 5 August 2016.
Saxon/C 1.0.1 maintenance release for C/C++ platforms, released 7 April 2016.
Saxon/C 1.0.0 first major release for C/C++ platforms, released 5 February 2016.
APIs are available to run XSLT 2.0/3.0, XQuery 1.0/3.0, XPath 2.0/3.0 and Schema Validation from C/C++ or PHP applications. Saxon/C 1.0 is built from the Saxon 9.6.0.9 Java product using the Excelsior JET tool (version 11 MP3).
Saxon-C 1.0 is available in the standard Saxon range of editions: the open-source product Saxon-HE/C, and the commercial products Saxon-PE/C and Saxon-EE/C.
Saxon-JS 1.2.0 maintenance release 5 October 2018.
Saxon-JS 1.1.0 maintenance release 9 May 2018.
Saxon-JS 1.0.2 maintenance release 5 October 2017.
Saxon-JS 1.0.1 maintenance release 21 July 2017.
Saxon-JS 1.0 first full release 7 February 2017.
Saxon-JS 1 allows execution of XSLT 3.0 stylesheets in the browser. It is a run-time only product; you first need to compile the stylesheet using Saxon-EE (9.7.0.15 or later). The compiled form (called a "stylesheet export file") is an XML document in a Saxon-specific format, so you can prepare the stylesheet on a development workstation and then deploy it anywhere on the web.
Saxon-JS is a replacement for Saxon-CE. It shares with Saxon-CE the ability to write interactive applications, where template rules with modes such as "ixsl:onclick" respond to user interaction. Unlike Saxon-CE, it's a new product written in pure JavaScript, which makes it much smaller and more manageable.
Saxon-JS at its first release has almost complete coverage of XPath 3.1 (including maps, arrays, and JSON), plus support for many XSLT 3.0 features such as try/catch and text value templates. To keep it small, it omits most optional features including schema awareness, streaming, and higher order functions.
For further information see Saxon-JS 1.x.
Note: Saxon-CE is no longer in development. As of 2017, the product has been superseded by Saxon-JS, the XSLT 3.0 run-time in JavaScript.
Saxon-CE 1.1 is open-source, released 22 February 2013.
Saxon Client Edition achieved its first production release 1.0 in June 2012, marking the culmination of effort in porting and then wrapping the Saxon XSLT 2.0 processor core into a product fit and ready for the browser, in the era of HTML5 and the dynamic web.
Saxon-CE features interactive event-driven templates and works in any modern browser with JavaScript enabled - including mobile devices.
In February 2013 Saxonica announced that the product would be made open-source, in the hope that this would enable the technology to become mainstream, allowing every developer to produce the same kind of quality interactive applications that pioneer users of the 1.0 release have shown to be possible.
For further information see Saxon-CE.