1 // Copyright 2014 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
6 * @fileoverview A collection of JavaScript utilities used to simplify working
11 goog
.provide('cvox.XpathUtil');
15 * Utilities for simplifying working with xpaths
18 cvox
.XpathUtil = function() {
23 * Mapping for some default namespaces.
27 cvox
.XpathUtil
.nameSpaces_
= {
28 'xhtml' : 'http://www.w3.org/1999/xhtml',
29 'mathml': 'http://www.w3.org/1998/Math/MathML'
34 * Resolve some default name spaces.
35 * @param {string} prefix Namespace prefix.
36 * @return {string} The corresponding namespace URI.
38 cvox
.XpathUtil
.resolveNameSpace = function(prefix
) {
39 return cvox
.XpathUtil
.nameSpaces_
[prefix
] || null;
44 * Given an XPath expression and rootNode, it returns an array of children nodes
45 * that match. The code for this function was taken from Mihai Parparita's GMail
46 * Macros Greasemonkey Script.
47 * http://gmail-greasemonkey.googlecode.com/svn/trunk/scripts/gmail-new-macros.user.js
48 * @param {string} expression The XPath expression to evaluate.
49 * @param {Node} rootNode The HTML node to start evaluating the XPath from.
50 * @return {Array} The array of children nodes that match.
52 cvox
.XpathUtil
.evalXPath = function(expression
, rootNode
) {
54 var xpathIterator
= rootNode
.ownerDocument
.evaluate(
57 cvox
.XpathUtil
.resolveNameSpace
,
58 XPathResult
.ORDERED_NODE_ITERATOR_TYPE
,
59 null); // no existing results
64 // Convert result to JS array
65 for (var xpathNode
= xpathIterator
.iterateNext();
67 xpathNode
= xpathIterator
.iterateNext()) {
68 results
.push(xpathNode
);
74 * Given a rootNode, it returns an array of all its leaf nodes.
75 * @param {Node} rootNode The node to get the leaf nodes from.
76 * @return {Array} The array of leaf nodes for the given rootNode.
78 cvox
.XpathUtil
.getLeafNodes = function(rootNode
) {
80 var xpathIterator
= rootNode
.ownerDocument
.evaluate(
83 null, // no namespace resolver
84 XPathResult
.ORDERED_NODE_ITERATOR_TYPE
,
85 null); // no existing results
90 // Convert result to JS array
91 for (var xpathNode
= xpathIterator
.iterateNext();
93 xpathNode
= xpathIterator
.iterateNext()) {
94 results
.push(xpathNode
);
100 * Returns whether or not xpath is supported.
101 * @return {boolean} True if xpath is supported.
103 cvox
.XpathUtil
.xpathSupported = function() {
104 if (typeof(XPathResult
) == 'undefined') {
112 * Given an XPath expression and rootNode, it evaluates the XPath expression as
113 * a boolean type and returns the result.
114 * @param {string} expression The XPath expression to evaluate.
115 * @param {Node} rootNode The HTML node to start evaluating the XPath from.
116 * @return {boolean} The result of evaluating the xpath expression.
118 cvox
.XpathUtil
.evaluateBoolean = function(expression
, rootNode
) {
120 var xpathResult
= rootNode
.ownerDocument
.evaluate(
123 cvox
.XpathUtil
.resolveNameSpace
,
124 XPathResult
.BOOLEAN_TYPE
,
125 null); // no existing results
129 return xpathResult
.booleanValue
;
134 * Given an XPath expression and rootNode, it evaluates the XPath expression as
135 * a string type and returns the result.
136 * @param {string} expression The XPath expression to evaluate.
137 * @param {Node} rootNode The HTML node to start evaluating the XPath from.
138 * @return {string} The result of evaluating the Xpath expression.
140 cvox
.XpathUtil
.evaluateString = function(expression
, rootNode
) {
142 var xpathResult
= rootNode
.ownerDocument
.evaluate(
145 cvox
.XpathUtil
.resolveNameSpace
,
146 XPathResult
.STRING_TYPE
,
147 null); // no existing results
151 return xpathResult
.stringValue
;