graphql.execution.instrumentation.dataloader.LevelMap Maven / Gradle / Ivy
package graphql.execution.instrumentation.dataloader;
import graphql.Internal;
import java.util.Arrays;
/**
* This data structure tracks the number of expected calls on a given level
*/
@Internal
public class LevelMap {
// A reasonable default that guarantees no additional allocations for most use cases.
private static final int DEFAULT_INITIAL_SIZE = 16;
// this array is mutable in both size and contents.
private int[] countsByLevel;
public LevelMap(int initialSize) {
if (initialSize < 0) {
throw new IllegalArgumentException("negative size " + initialSize);
}
countsByLevel = new int[initialSize];
}
public LevelMap() {
this(DEFAULT_INITIAL_SIZE);
}
public int get(int level) {
if (level < 0) {
throw new IllegalArgumentException("negative level " + level);
}
if (level + 1 > countsByLevel.length) {
throw new IllegalArgumentException("unknown level " + level);
}
return countsByLevel[level];
}
public void increment(int level, int by) {
mutatePreconditions(level);
countsByLevel[level] += by;
}
public void set(int level, int newValue) {
mutatePreconditions(level);
countsByLevel[level] = newValue;
}
private void mutatePreconditions(int level) {
if (level < 0) {
throw new IllegalArgumentException("negative level " + level);
}
if (level + 1 > countsByLevel.length) {
int newSize = level == 0 ? 1 : level * 2;
countsByLevel = Arrays.copyOf(countsByLevel, newSize);
}
}
@Override
public String toString() {
StringBuilder result = new StringBuilder();
result.append("IntMap[");
for (int i = 0; i < countsByLevel.length; i++) {
result.append("level=").append(i).append(",count=").append(countsByLevel[i]).append(" ");
}
result.append("]");
return result.toString();
}
public void clear() {
Arrays.fill(countsByLevel, 0);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy