diff options
author | Jean-Christophe Lariviere <jclariviere@arcbees.com> | 2014-12-12 11:01:00 -0500 |
---|---|---|
committer | Jean-Christophe Lariviere <jclariviere@arcbees.com> | 2014-12-12 11:01:00 -0500 |
commit | b363dcea923226179d067f987c462d89da3733fa (patch) | |
tree | bd908177db93f64a88bd1c7302533c4f14a87321 | |
parent | be0e45c7fe64132f5155c8ae06431d768a4e7f0b (diff) | |
download | gwtquery-b363dcea923226179d067f987c462d89da3733fa.tar.gz gwtquery-b363dcea923226179d067f987c462d89da3733fa.zip |
Code review fixes
-rw-r--r-- | gwtquery-core/src/main/java/com/google/gwt/query/client/GQuery.java | 35 |
1 files changed, 20 insertions, 15 deletions
diff --git a/gwtquery-core/src/main/java/com/google/gwt/query/client/GQuery.java b/gwtquery-core/src/main/java/com/google/gwt/query/client/GQuery.java index a589f3d5..261991c2 100644 --- a/gwtquery-core/src/main/java/com/google/gwt/query/client/GQuery.java +++ b/gwtquery-core/src/main/java/com/google/gwt/query/client/GQuery.java @@ -3377,35 +3377,40 @@ public class GQuery implements Lazy<GQuery, LazyGQuery> { * Get the ancestors of each element in the current set of matched elements, up to but not * including the element matched by the selector. */ - public GQuery parentsUntil(String selector) { - JsNodeArray result = JsNodeArray.create(); - for (Element e : elements) { - Node par = e.getParentNode(); - while (par != null && par != document) { - if (selector != null && $(par).is(selector)) { - break; - } - result.addNode(par); - par = par.getParentNode(); + public GQuery parentsUntil(final String selector) { + return parentsUntil(new Predicate(){ + @Override + public boolean f(Element e, int index) { + return $(e).is(selector); } - } - return new GQuery(unique(result)).setPreviousObject(this); + }); } /** * Get the ancestors of each element in the current set of matched elements, up to but not - * including the element matched by the selector. + * including the node. */ - public GQuery parentsUntil(Node selector) { + public GQuery parentsUntil(final Node node) { + return parentsUntil(new Predicate() { + @Override + public boolean f(Element e, int index) { + return e == node; + } + }); + } + + private GQuery parentsUntil(Predicate predicate) { JsNodeArray result = JsNodeArray.create(); for (Element e : elements) { + int i = 0; Node par = e.getParentNode(); while (par != null && par != document) { - if (selector != null && par == selector) { + if (!predicate.f(par, i)) { break; } result.addNode(par); par = par.getParentNode(); + i++; } } return new GQuery(unique(result)).setPreviousObject(this); |