aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorJean-Christophe Lariviere <jclariviere@arcbees.com>2014-12-12 11:01:00 -0500
committerJean-Christophe Lariviere <jclariviere@arcbees.com>2014-12-12 11:01:00 -0500
commitb363dcea923226179d067f987c462d89da3733fa (patch)
treebd908177db93f64a88bd1c7302533c4f14a87321
parentbe0e45c7fe64132f5155c8ae06431d768a4e7f0b (diff)
downloadgwtquery-b363dcea923226179d067f987c462d89da3733fa.tar.gz
gwtquery-b363dcea923226179d067f987c462d89da3733fa.zip
Code review fixes
-rw-r--r--gwtquery-core/src/main/java/com/google/gwt/query/client/GQuery.java35
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);