Next: Record Header, Up: Records [Contents]
Introducing, effectively, a new type system into XSLT should be done cautiously and faithfully —it should work with the language, not sneak klugily around it. The main considerations are:
Each of these properties will be addressed as they are introduced in the sections that follow. But the fundamental concept that needs to be considered before even beginning an implementation is the viability of sequences.
Sequences are generally performant: when you execute an XPath expression on a document yielding multiple matches, each item is returned as part of a sequence. These sequences could potentially yield tens of thousands (if not more) of results. You can then refine those results using further XPath expressions, looping constructs, template applications, and functions. This is important when we consider records, since records could be of arbitrary length, recursively.
A record, then, is nothing more than a slice of a sequence —it must have a defined length to state how many items within the sequence “belong” to the record, but it otherwise does not need to define much else, since XSLT’s type system handles most of that work for us.1
Consider some record named Rect that contains two fields A and B, both of type Point, where the record Point contains two fields x and y. Let x and y be represented by xs:integer; we could represent two rectangles using the following numbers:
The goal of a record implementation is to determine how we represent each of the records in Figure 2.2, where those items could exist in a sequence of any other arbitrary items. The implementation will involve adding additional items into the sequence in order to provide the needed context.
Note: records are implemented without the use of Hoxsl’s higher-order functions; those functions are backed by records, so we’d have a bit of a chicken-and-egg problem.
Remember: the original goal was to stay as far away from data manipulation as possible.
Next: Record Header, Up: Records [Contents]