SLING-11614 avoid duplicate creation of child node iterator (#37)
diff --git a/src/main/java/org/apache/sling/jcr/resource/internal/helper/jcr/JcrNodeResource.java b/src/main/java/org/apache/sling/jcr/resource/internal/helper/jcr/JcrNodeResource.java
index dba7f67..9371aa5 100644
--- a/src/main/java/org/apache/sling/jcr/resource/internal/helper/jcr/JcrNodeResource.java
+++ b/src/main/java/org/apache/sling/jcr/resource/internal/helper/jcr/JcrNodeResource.java
@@ -25,6 +25,7 @@
import javax.jcr.Item;
import javax.jcr.ItemNotFoundException;
import javax.jcr.Node;
+import javax.jcr.NodeIterator;
import javax.jcr.Property;
import javax.jcr.RepositoryException;
@@ -217,15 +218,13 @@
return null;
}
-
- // ---------- Descendable interface ----------------------------------------
-
@Override
@Nullable Iterator<Resource> listJcrChildren() {
try {
- if (getNode().hasNodes()) {
+ NodeIterator iter = getNode().getNodes();
+ if (iter.hasNext()) {
return new JcrNodeResourceIterator(getResourceResolver(), path, version,
- getNode().getNodes(), this.helper, null);
+ iter, this.helper, null);
}
} catch (final RepositoryException re) {
LOGGER.error("listChildren: Cannot get children of " + this, re);