saxon:as

This attribute may be set on most XSLT elements that have an as attribute (xsl:variable, xsl:param, xsl:with-param, xsl:function, xsl:template: but not currently xsl:accumulator) to declare an additional more specific type for a value.

For example:

<xsl:param name="options" as="map(xs:string, xs:anyAtomicType*)" saxon:as="tuple(validate as xs:boolean, duplicates as xs:boolean, limit as xs:integer, codes as xs:string*)" xmlns:saxon="http://saxon.sf.net/" select="map{'validate': true(), 'duplicates': false(), 'limit': 17, 'codes': ('USD', 'GBP', 'EUR')}"/><xsl:variable name="sqlConnection" saxon:as="javatype:java.sql.Connection" xmlns:saxon="http://saxon.sf.net/" xmlns:javatype="http://saxon.sf.net/java-type" select="..."/><xsl:param name="when" required="yes" as="xs:anyAtomicType" saxon:as="union(xs:date, xs:time, xs:dateTime)" xmlns:saxon="http://saxon.sf.net/">

If both the as and saxon:as attributes are present, then the type given in the saxon:as attribute must be a subtype of the type given in the as attribute.

The saxon:as attribute will be ignored by a conformant XSLT processor that does not recognize the Saxon namespace. The attribute therefore allows type information to be specified for use by Saxon, which will be ignored by other XSLT processors (this applies to XSLT 1.0 and 2.0 processors as well as XSLT 3.0 processors). It therefore allows stylesheets to take advantage of Saxon extensions to the sequence type syntax (notably, tuple types, union types, and type aliases; see Syntax extensions) without sacrificing stylesheet portability.

The saxon:as attribute can also be defined on the xsl:mode element. Used here, it provides a default for the as or saxon:as attribute of all template rules defined in this mode.