| /** |
| * @license |
| * The MIT License |
| * |
| * Copyright (c) 2007 Cybozu Labs, Inc. |
| * Copyright (c) 2012 Google Inc. |
| * |
| * Permission is hereby granted, free of charge, to any person obtaining a copy |
| * of this software and associated documentation files (the "Software"), to |
| * deal in the Software without restriction, including without limitation the |
| * rights to use, copy, modify, merge, publish, distribute, sublicense, and/or |
| * sell copies of the Software, and to permit persons to whom the Software is |
| * furnished to do so, subject to the following conditions: |
| * |
| * The above copyright notice and this permission notice shall be included in |
| * all copies or substantial portions of the Software. |
| * |
| * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR |
| * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, |
| * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE |
| * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER |
| * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING |
| * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS |
| * IN THE SOFTWARE. |
| */ |
| |
| /** |
| * @fileoverview An abstract class representing basic expressions. |
| * @author [email protected] (Michael Zhou) |
| */ |
| |
| goog.provide('wgxpath.Expr'); |
| |
| goog.require('wgxpath.NodeSet'); |
| |
| |
| |
| /** |
| * Abstract constructor for an XPath expression. |
| * |
| * @param {!wgxpath.DataType} dataType The data type that the expression |
| * will be evaluated into. |
| * @constructor |
| */ |
| wgxpath.Expr = function(dataType) { |
| |
| /** |
| * @type {!wgxpath.DataType} |
| * @private |
| */ |
| this.dataType_ = dataType; |
| |
| /** |
| * @type {boolean} |
| * @private |
| */ |
| this.needContextPosition_ = false; |
| |
| /** |
| * @type {boolean} |
| * @private |
| */ |
| this.needContextNode_ = false; |
| |
| /** |
| * @type {?{name: string, valueExpr: wgxpath.Expr}} |
| * @private |
| */ |
| this.quickAttr_ = null; |
| }; |
| |
| |
| /** |
| * Indentation method for pretty printing. |
| * |
| * @param {*} obj The object to return a string representation for. |
| * @return {string} The string prepended with newline and two spaces. |
| */ |
| wgxpath.Expr.indent = function(obj) { |
| return '\n ' + obj.toString().split('\n').join('\n '); |
| }; |
| |
| |
| /** |
| * Evaluates the expression. |
| * |
| * @param {!wgxpath.Context} ctx The context to evaluate the expression in. |
| * @return {!(string|boolean|number|wgxpath.NodeSet)} The evaluation result. |
| */ |
| wgxpath.Expr.prototype.evaluate = goog.abstractMethod; |
| |
| |
| /** |
| * @override |
| */ |
| wgxpath.Expr.prototype.toString = goog.abstractMethod; |
| |
| |
| /** |
| * Returns the data type of the expression. |
| * |
| * @return {!wgxpath.DataType} The data type that the expression |
| * will be evaluated into. |
| */ |
| wgxpath.Expr.prototype.getDataType = function() { |
| return this.dataType_; |
| }; |
| |
| |
| /** |
| * Returns whether the expression needs context position to be evaluated. |
| * |
| * @return {boolean} Whether context position is needed. |
| */ |
| wgxpath.Expr.prototype.doesNeedContextPosition = function() { |
| return this.needContextPosition_; |
| }; |
| |
| |
| /** |
| * Sets whether the expression needs context position to be evaluated. |
| * |
| * @param {boolean} flag Whether context position is needed. |
| */ |
| wgxpath.Expr.prototype.setNeedContextPosition = function(flag) { |
| this.needContextPosition_ = flag; |
| }; |
| |
| |
| /** |
| * Returns whether the expression needs context node to be evaluated. |
| * |
| * @return {boolean} Whether context node is needed. |
| */ |
| wgxpath.Expr.prototype.doesNeedContextNode = function() { |
| return this.needContextNode_; |
| }; |
| |
| |
| /** |
| * Sets whether the expression needs context node to be evaluated. |
| * |
| * @param {boolean} flag Whether context node is needed. |
| */ |
| wgxpath.Expr.prototype.setNeedContextNode = function(flag) { |
| this.needContextNode_ = flag; |
| }; |
| |
| |
| /** |
| * Returns the quick attribute information, if exists. |
| * |
| * @return {?{name: string, valueExpr: wgxpath.Expr}} The attribute |
| * information. |
| */ |
| wgxpath.Expr.prototype.getQuickAttr = function() { |
| return this.quickAttr_; |
| }; |
| |
| |
| /** |
| * Sets up the quick attribute info. |
| * |
| * @param {?{name: string, valueExpr: wgxpath.Expr}} attrInfo The attribute |
| * information. |
| */ |
| wgxpath.Expr.prototype.setQuickAttr = function(attrInfo) { |
| this.quickAttr_ = attrInfo; |
| }; |
| |
| |
| /** |
| * Evaluate and interpret the result as a number. |
| * |
| * @param {!wgxpath.Context} ctx The context to evaluate the expression in. |
| * @return {number} The evaluated number value. |
| */ |
| wgxpath.Expr.prototype.asNumber = function(ctx) { |
| var exrs = this.evaluate(ctx); |
| if (exrs instanceof wgxpath.NodeSet) { |
| return exrs.number(); |
| } |
| return +exrs; |
| }; |
| |
| |
| /** |
| * Evaluate and interpret the result as a string. |
| * |
| * @param {!wgxpath.Context} ctx The context to evaluate the expression in. |
| * @return {string} The evaluated string. |
| */ |
| wgxpath.Expr.prototype.asString = function(ctx) { |
| var exrs = this.evaluate(ctx); |
| if (exrs instanceof wgxpath.NodeSet) { |
| return exrs.string(); |
| } |
| return '' + exrs; |
| }; |
| |
| |
| /** |
| * Evaluate and interpret the result as a boolean value. |
| * |
| * @param {!wgxpath.Context} ctx The context to evaluate the expression in. |
| * @return {boolean} The evaluated boolean value. |
| */ |
| wgxpath.Expr.prototype.asBool = function(ctx) { |
| var exrs = this.evaluate(ctx); |
| if (exrs instanceof wgxpath.NodeSet) { |
| return !!exrs.getLength(); |
| } |
| return !!exrs; |
| }; |