Optimizing XSLT based on input XML document structure description and translating XSLT into equivalent XQuery expressions
First Claim
1. A method comprising:
- receiving a request to transform a set of one or more XML documents based at least in part on an XSLT stylesheet that includes calls to one or more transformation templates, wherein each transformation template specifies how to transform one or more nodes, wherein the one or more nodes include a first node and a descendant node of the first node, wherein the calls to the one or more transformation templates, if evaluated based on the XSLT stylesheet, would use an XSLT template matching process to associate the descendant node in the set of one or more XML documents with a transformation template;
determining, based at least in part on a structural description that constrains the set of one or more XML documents to a hierarchy of nodes that may be present in the set of one or more XML documents, which one or more transformation templates to use to transform the set of one or more XML documents, wherein the hierarchy of nodes includes the first node and the descendant node; and
converting the calls in the XSLT stylesheet that would use the one or more transformation templates into calls to one or more XQuery user-defined functions, and including the calls to the one or more XQuery user-defined functions in a set of one or more XQuery language expressions;
wherein the calls to the one or more XQuery user-defined functions do not use the XSLT template matching process;
wherein the method is performed by one or more computing devices.
1 Assignment
0 Petitions
Accused Products
Abstract
Transformation of a set of XML documents via an XSLT stylesheet is made more efficient by rewriting the stylesheet at compile-time, based on the structural description of the set of XML documents, into an optimized stylesheet containing fewer dynamic template-matching calls than the original stylesheet. This rewritten stylesheet can be further rewritten into a set of XQuery expressions. At compile-time, the particular transformation templates that are appropriate for transforming the particular nodes contained in the set of XML documents are determined, and XSLT calls to the templates are converted to calls to corresponding XQuery user-defined functions. Determination of the appropriate transformation templates may be based on the structural description of the input set of XML documents, such as an XML Schema or Document Type Definition. The data from each template is translated into corresponding XQuery constructors, instructions from the template are translated into XQuery expressions, and the XQuery functions are inlined if possible.
105 Citations
50 Claims
-
1. A method comprising:
-
receiving a request to transform a set of one or more XML documents based at least in part on an XSLT stylesheet that includes calls to one or more transformation templates, wherein each transformation template specifies how to transform one or more nodes, wherein the one or more nodes include a first node and a descendant node of the first node, wherein the calls to the one or more transformation templates, if evaluated based on the XSLT stylesheet, would use an XSLT template matching process to associate the descendant node in the set of one or more XML documents with a transformation template; determining, based at least in part on a structural description that constrains the set of one or more XML documents to a hierarchy of nodes that may be present in the set of one or more XML documents, which one or more transformation templates to use to transform the set of one or more XML documents, wherein the hierarchy of nodes includes the first node and the descendant node; and converting the calls in the XSLT stylesheet that would use the one or more transformation templates into calls to one or more XQuery user-defined functions, and including the calls to the one or more XQuery user-defined functions in a set of one or more XQuery language expressions; wherein the calls to the one or more XQuery user-defined functions do not use the XSLT template matching process; wherein the method is performed by one or more computing devices. - View Dependent Claims (2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, 26, 27, 28, 29, 30, 31)
-
-
32. A non-transitory computer-readable storage medium storing instructions, which, when executed by one or more computing devices, cause the one or more computing devices to perform:
-
receiving a request to transform a set of one or more XML documents based at least in part on an XSLT stylesheet that includes calls to one or more transformation templates, wherein each transformation template specifies how to transform one or more nodes, wherein the one or more nodes include a first node and a descendant node of the first node, wherein the calls to the one or more transformation templates, if evaluated based on the XSLT stylesheet, would use an XSLT template matching process to associate the descendant node in the set of one or more XML documents with a transformation template; determining, based at least in part on a structural description that constrains the set of one or more XML documents to a hierarchy of nodes that may be present in the set of one or more XML documents, which transformation templates to use to transform the set of one or more XML documents, wherein the hierarchy of nodes includes the first node and the descendant node; and converting the calls in the XSLT stylesheet that would use the one or more transformation templates into calls to one or more XQuery user-defined functions, and including the calls to the one or more XQuery user-defined functions in a set of one or more XQuery language expressions; wherein the calls to the one or more XQuery user-defined functions do not use the XSLT template matching process. - View Dependent Claims (33, 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, 44, 45, 46, 47, 48, 49, 50)
-
Specification