|On this page||On other pages|
|What is SAXON?
Conditions of Use|
Changes in this release
Using XSL Stylesheets
XPath Expression syntax
Java API Overview
Please note: a copy of the documentation on this site is also included in the download file. On occasions the on-line version may be more up-to-date. The download file also includes full API documentation, which is not present on the web site: see the doc/api directory.
Version 6.5.3 clears 28 bugs found in Saxon 6.5.2 in the sixteen months since it became available. This version of Saxon implements XSLT 1.0 and XPath 1.0. It is unrelated to Saxon version 7.x, which implements many facilities from the working draft XSLT 2.0 and XPath 2.0 specifications. See here for details.
It is likely that this will be the last release in the Saxon 6.5.x branch. The product has proved highly stable (only twelve user-reported bugs after 45,000 downloads), and if there are any remaining bugs it is likely that they will affect very few users. All new development now takes place on the 7.x branch.
A list of known limitations in this release is being maintained. These are minor non-conformances with the W3C specifications which are unlikely to be fixed.
The SAXON package is a collection of tools for processing XML documents. The main components are:
So you can use SAXON by writing XSLT stylesheets, by writing Java applications, or by any combination of the two.
If you are only interested in running the XSLT interpreter, on a Windows platform, you might want to try Instant SAXON. At 400 Kb, this is a much smaller download; it excludes source code and API documentation. (The main benefit of Instant Saxon when it was introduced was that it ran with the Microsoft Java VM, which at that time was pre-installed with every version of Windows. With Windows XP, the Java VM is no longer installed as standard, which means it is just as easy to install the full Saxon product, along with the most recent Java SDK from Sun.)
SAXON provides a set of services that are particularly useful when converting XML data into other formats. The output format may be XML, or HTML, or some other format such as comma separated values, EDI messages, or data in a relational database.
SAXON implements the XSLT 1.0 recommendation, including XPath 1.0, in its entirety. SAXON also provides some XSLT 1.1 features, in particular:
In addition, Saxon provides an extensive library of extension elements and extension functions, all implemented in conformance with the XSLT 1.0 standard to ensure that portable stylesheets can be written. These include the EXSLT extension libraries common, sets, math, dates-and-times, and functions. Many of these extensions were pioneered in Saxon and have since become available in other products.
Saxon also includes a number of powerful extension functions that go beyond EXSLT. Most of these rely on the concept of "stored expressions" as an additional data-type: this allows an XPath expression to be constructed at run-time from a string, and allows an expression to be passed as an argument to a function (which in effect provides higher-order functions). This allows:
As a Java class library, SAXON gives you the ability to use the XSLT rule-based approach to document processing, but with the flexibility of the full Java language. You can declare handler classes to match particular patterns in the document, and can process arbitrary sets of nodes selected using XPath expressions. This provides a high-level query capability which you can mix with purely navigational access.
SAXON is essentially a one-man project: I have done almost all the development myself, except for a small number of routines which I "borrowed" from other open source products, and a few add-ons contributed by users.
I originally wrote SAXON to support an internal project in ICL, and ICL continued to sponsor development of SAXON until my departure from the company in January 2001. However, it was never a supported ICL product. My current employers, Software AG, are continuing to sponsor the development of SAXON, but again without making it a corporate product. There is no remaining connection with ICL, though the historic connection is reflected in package names and URLs. The software is available entirely without support or warranty, and with no commitments to any future releases.
The name SAXON was chosen because originally it was a layer on top of SAX. Also, it uses the Ælfred parser (among others); Ælfred of course was a Saxon king...
I have been asked to point out that the product has no connection with a company called SAXON Software.
Please read the Conditions of Use.
Saxon comes with no warranty and no formal technical support service.
If you have questions, however, you can usually get an answer by raising them on the Saxon discussion list at http://lists.sourceforge.net/lists/listinfo/saxon-help.
Once registered, you can post messages to email@example.com.
If you hit something that looks like a bug, please check the known errors on the Saxon project pages at SourceForge. Also check the list archives.
If the query relates to the XSLT/XPath language rather than Saxon itself, it is better to use the XSL-list: check first that the query isn't already covered in the FAQ. Another useful site for XSLT information is www.xslinfo.com
Existing users please see the file changes.html for details of incompatible changes in this release.
The full SAXON distribution includes source and object code, documentation, and sample applications.
Object code is issued as a JAR file, saxon.jar, which you must include on your class path.
Saxon 6.5.3 includes a built-in XML parser, but you can use it with a different XML parser if you wish. To do this from the command line, specify the required parser using the -x or -y options; from the Java API, set the name of the parser class as an attribute of the TransformerFactory object.
User documentation, covering both the XSLT and Java interfaces, is included in the download in the form of extensive javadoc specifications. Be sure to read the package summaries, which give an overview in the form of a user guide. In addition there is an introductory overview.
The following software must be installed separately, it is not included with the SAXON download.
SAXON comes with a bundled XML parser, a modified copy of the Ælfred parser, adapted to notify comments to the application. SAXON has been tested successfully in the past with Xerces, Lark, SUN Project X, Crimson, Oracle XML, xerces, xml4j, and xp. Use of a SAX2-compliant parser is preferred, as SAX1 does not allow XML comments to be passed to the application. However, SAXON works with either. All the relevant classes must be installed on your Java CLASSPATH.
An interactive debugger for Saxon has been written by Edwin Glaser. It is still at an early stage of development. The software can be downloaded from http://tbug.sourceforge.net. It is issued in tar/gzip format, but it can be unpacked on a Windows machine using WinZIP.
Because Saxon is run from the command line, you might find it useful (under Microsoft Windows) to have a text editor with better command-line support than the standard DOS window. I use Programmer's File Editor (PFE), a free product available from a number of download sites, listed here. and also UltraEdit, shareware available from www.ultraedit.com
An index of all current versions of Saxon is on the home page at http://saxon.sourceforge.net/. Older versions can be loaded from the SourceForge download page.
Michael H. Kay
12 September 2003