aboutsummaryrefslogtreecommitdiff
path: root/contexts/data/lib/closure-library/closure/goog/dom/pattern/childmatches.js
diff options
context:
space:
mode:
Diffstat (limited to 'contexts/data/lib/closure-library/closure/goog/dom/pattern/childmatches.js')
-rw-r--r--contexts/data/lib/closure-library/closure/goog/dom/pattern/childmatches.js154
1 files changed, 0 insertions, 154 deletions
diff --git a/contexts/data/lib/closure-library/closure/goog/dom/pattern/childmatches.js b/contexts/data/lib/closure-library/closure/goog/dom/pattern/childmatches.js
deleted file mode 100644
index 72f1b51..0000000
--- a/contexts/data/lib/closure-library/closure/goog/dom/pattern/childmatches.js
+++ /dev/null
@@ -1,154 +0,0 @@
-// Copyright 2007 The Closure Library Authors. All Rights Reserved.
-//
-// Licensed under the Apache License, Version 2.0 (the "License");
-// you may not use this file except in compliance with the License.
-// You may obtain a copy of the License at
-//
-// http://www.apache.org/licenses/LICENSE-2.0
-//
-// Unless required by applicable law or agreed to in writing, software
-// distributed under the License is distributed on an "AS-IS" BASIS,
-// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
-// See the License for the specific language governing permissions and
-// limitations under the License.
-
-/**
- * @fileoverview DOM pattern to match any children of a tag, and
- * specifically collect those that match a child pattern.
- *
- * @author robbyw@google.com (Robby Walker)
- */
-
-goog.provide('goog.dom.pattern.ChildMatches');
-
-goog.require('goog.dom.pattern.AllChildren');
-goog.require('goog.dom.pattern.MatchType');
-
-
-
-/**
- * Pattern object that matches any nodes at or below the current tree depth.
- *
- * @param {goog.dom.pattern.AbstractPattern} childPattern Pattern to collect
- * child matches of.
- * @param {number=} opt_minimumMatches Enforce a minimum nuber of matches.
- * Defaults to 0.
- * @constructor
- * @extends {goog.dom.pattern.AllChildren}
- */
-goog.dom.pattern.ChildMatches = function(childPattern, opt_minimumMatches) {
- this.childPattern_ = childPattern;
- this.matches = [];
- this.minimumMatches_ = opt_minimumMatches || 0;
- goog.dom.pattern.AllChildren.call(this);
-};
-goog.inherits(goog.dom.pattern.ChildMatches, goog.dom.pattern.AllChildren);
-
-
-/**
- * Array of matched child nodes.
- *
- * @type {Array.<Node>}
- */
-goog.dom.pattern.ChildMatches.prototype.matches;
-
-
-/**
- * Minimum number of matches.
- *
- * @type {number}
- * @private
- */
-goog.dom.pattern.ChildMatches.prototype.minimumMatches_ = 0;
-
-
-/**
- * The child pattern to collect matches from.
- *
- * @type {goog.dom.pattern.AbstractPattern}
- * @private
- */
-goog.dom.pattern.ChildMatches.prototype.childPattern_;
-
-
-/**
- * Whether the pattern has recently matched or failed to match and will need to
- * be reset when starting a new round of matches.
- *
- * @type {boolean}
- * @private
- */
-goog.dom.pattern.ChildMatches.prototype.needsReset_ = false;
-
-
-/**
- * Test whether the given token is on the same level.
- *
- * @param {Node} token Token to match against.
- * @param {goog.dom.TagWalkType} type The type of token.
- * @return {goog.dom.pattern.MatchType} {@code MATCHING} if the token is on the
- * same level or deeper and {@code BACKTRACK_MATCH} if not.
- * @override
- */
-goog.dom.pattern.ChildMatches.prototype.matchToken = function(token, type) {
- // Defer resets so we maintain our matches array until the last possible time.
- if (this.needsReset_) {
- this.reset();
- }
-
- // Call the super-method to ensure we stay in the child tree.
- var status =
- goog.dom.pattern.AllChildren.prototype.matchToken.apply(this, arguments);
-
- switch (status) {
- case goog.dom.pattern.MatchType.MATCHING:
- var backtrack = false;
-
- switch (this.childPattern_.matchToken(token, type)) {
- case goog.dom.pattern.MatchType.BACKTRACK_MATCH:
- backtrack = true;
- case goog.dom.pattern.MatchType.MATCH:
- // Collect the match.
- this.matches.push(this.childPattern_.matchedNode);
- break;
-
- default:
- // Keep trying if we haven't hit a terminal state.
- break;
- }
-
- if (backtrack) {
- // The only interesting result is a MATCH, since BACKTRACK_MATCH means
- // we are hitting an infinite loop on something like a Repeat(0).
- if (this.childPattern_.matchToken(token, type) ==
- goog.dom.pattern.MatchType.MATCH) {
- this.matches.push(this.childPattern_.matchedNode);
- }
- }
- return goog.dom.pattern.MatchType.MATCHING;
-
- case goog.dom.pattern.MatchType.BACKTRACK_MATCH:
- // TODO(robbyw): this should return something like BACKTRACK_NO_MATCH
- // when we don't meet our minimum.
- this.needsReset_ = true;
- return (this.matches.length >= this.minimumMatches_) ?
- goog.dom.pattern.MatchType.BACKTRACK_MATCH :
- goog.dom.pattern.MatchType.NO_MATCH;
-
- default:
- this.needsReset_ = true;
- return status;
- }
-};
-
-
-/**
- * Reset any internal state this pattern keeps.
- * @override
- */
-goog.dom.pattern.ChildMatches.prototype.reset = function() {
- this.needsReset_ = false;
- this.matches.length = 0;
- this.childPattern_.reset();
- goog.dom.pattern.AllChildren.prototype.reset.call(this);
-};