summaryrefslogtreecommitdiffstats
path: root/predicate-search/src/main/java/com/yahoo/search/predicate/index/BoundsPostingList.java
diff options
context:
space:
mode:
Diffstat (limited to 'predicate-search/src/main/java/com/yahoo/search/predicate/index/BoundsPostingList.java')
-rw-r--r--predicate-search/src/main/java/com/yahoo/search/predicate/index/BoundsPostingList.java49
1 files changed, 49 insertions, 0 deletions
diff --git a/predicate-search/src/main/java/com/yahoo/search/predicate/index/BoundsPostingList.java b/predicate-search/src/main/java/com/yahoo/search/predicate/index/BoundsPostingList.java
new file mode 100644
index 00000000000..d17b6589693
--- /dev/null
+++ b/predicate-search/src/main/java/com/yahoo/search/predicate/index/BoundsPostingList.java
@@ -0,0 +1,49 @@
+// Copyright 2016 Yahoo Inc. Licensed under the terms of the Apache 2.0 license. See LICENSE in the project root.
+package com.yahoo.search.predicate.index;
+
+/**
+ * Wraps a posting stream of IntervalWithBounds objects (for collapsed
+ * fixed tree leaf nodes) into a PostingList.
+ *
+ * @author <a href="mailto:magnarn@yahoo-inc.com">Magnar Nedland</a>
+ * @author bjorncs
+ */
+public class BoundsPostingList extends MultiIntervalPostingList {
+ private final int valueDiff;
+ private final IntervalWithBounds intervalWithBounds = new IntervalWithBounds();
+ private final PredicateIntervalStore store;
+ private int currentInterval;
+
+ /**
+ * @param valueDiff Difference from the collapsed leaf node's actual value.
+ */
+ public BoundsPostingList(PredicateIntervalStore store, int[] docIds, int[] dataRefs, long subquery, int valueDiff) {
+ super(docIds, dataRefs, subquery);
+ this.valueDiff = valueDiff;
+ this.store = store;
+ }
+
+ @Override
+ protected boolean prepareIntervals(int dataRef) {
+ intervalWithBounds.setIntervalArray(store.get(dataRef), 0);
+ return nextInterval();
+ }
+
+ @Override
+ public boolean nextInterval() {
+ while (intervalWithBounds.hasValue()) {
+ if (intervalWithBounds.contains(valueDiff)) {
+ this.currentInterval = intervalWithBounds.getInterval();
+ intervalWithBounds.nextValue();
+ return true;
+ }
+ intervalWithBounds.nextValue();
+ }
+ return false;
+ }
+
+ @Override
+ public int getInterval() {
+ return currentInterval;
+ }
+}