Browse Source

small performance improvements for Utils.createRange

pull/42/head
Jochen Berger 11 years ago
parent
commit
2d597f0d7a
  1. 10
      json-path/src/main/java/com/jayway/jsonpath/internal/Utils.java

10
json-path/src/main/java/com/jayway/jsonpath/internal/Utils.java

@ -12,6 +12,7 @@ import java.io.ObjectStreamClass;
import java.io.OutputStream; import java.io.OutputStream;
import java.io.Serializable; import java.io.Serializable;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.Collections;
import java.util.Iterator; import java.util.Iterator;
import java.util.List; import java.util.List;
@ -27,7 +28,13 @@ public final class Utils {
* @return * @return
*/ */
public static List<Integer> createRange(int start, int end) { public static List<Integer> createRange(int start, int end) {
List<Integer> range = new ArrayList<Integer>(); if (end <= start) {
throw new IllegalArgumentException("Cannot create range from " + start + " to " + end + ", end must be greater than start.");
}
if (start == end-1) {
return Collections.emptyList();
}
List<Integer> range = new ArrayList<Integer>(end-start-1);
for (int i = start; i < end; i++) { for (int i = start; i < end; i++) {
range.add(i); range.add(i);
} }
@ -40,7 +47,6 @@ public final class Utils {
if (!iter.hasNext()) { if (!iter.hasNext()) {
return ""; return "";
} }
StringBuilder buffer = new StringBuilder(); StringBuilder buffer = new StringBuilder();
buffer.append(wrap).append(iter.next()).append(wrap); buffer.append(wrap).append(iter.next()).append(wrap);
while (iter.hasNext()) { while (iter.hasNext()) {

Loading…
Cancel
Save