mirror of https://github.com/apache/lucene.git
SOLR-6407: SortingResponseWriter String sorting broken on single segment indexes
git-svn-id: https://svn.apache.org/repos/asf/lucene/dev/trunk@1620029 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
parent
7d5cc2444b
commit
81d38f9a90
|
@ -444,6 +444,10 @@ public class SortingResponseWriter implements QueryResponseWriter {
|
||||||
}
|
}
|
||||||
return docId+docBase < sd.docId+sd.docBase;
|
return docId+docBase < sd.docId+sd.docBase;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public String toString() {
|
||||||
|
return "";
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
class SingleValueSortDoc extends SortDoc {
|
class SingleValueSortDoc extends SortDoc {
|
||||||
|
@ -496,6 +500,10 @@ public class SortingResponseWriter implements QueryResponseWriter {
|
||||||
SingleValueSortDoc sd = (SingleValueSortDoc)o;
|
SingleValueSortDoc sd = (SingleValueSortDoc)o;
|
||||||
return value1.compareTo(sd.value1);
|
return value1.compareTo(sd.value1);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public String toString() {
|
||||||
|
return docId+":"+value1.toString();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
class DoubleValueSortDoc extends SingleValueSortDoc {
|
class DoubleValueSortDoc extends SingleValueSortDoc {
|
||||||
|
@ -1088,8 +1096,10 @@ public class SortingResponseWriter implements QueryResponseWriter {
|
||||||
|
|
||||||
public StringValue(SortedDocValues vals, String field, IntComp comp) {
|
public StringValue(SortedDocValues vals, String field, IntComp comp) {
|
||||||
this.vals = vals;
|
this.vals = vals;
|
||||||
|
if(vals instanceof MultiDocValues.MultiSortedDocValues) {
|
||||||
this.segmentVals = ((MultiDocValues.MultiSortedDocValues) vals).values;
|
this.segmentVals = ((MultiDocValues.MultiSortedDocValues) vals).values;
|
||||||
this.ordinalMap = ((MultiDocValues.MultiSortedDocValues) vals).mapping;
|
this.ordinalMap = ((MultiDocValues.MultiSortedDocValues) vals).mapping;
|
||||||
|
}
|
||||||
this.field = field;
|
this.field = field;
|
||||||
this.comp = comp;
|
this.comp = comp;
|
||||||
this.currentOrd = comp.resetValue();
|
this.currentOrd = comp.resetValue();
|
||||||
|
@ -1104,7 +1114,11 @@ public class SortingResponseWriter implements QueryResponseWriter {
|
||||||
if(ord < 0) {
|
if(ord < 0) {
|
||||||
currentOrd = -1;
|
currentOrd = -1;
|
||||||
} else {
|
} else {
|
||||||
|
if(globalOrds != null) {
|
||||||
currentOrd = (int)globalOrds.get(ord);
|
currentOrd = (int)globalOrds.get(ord);
|
||||||
|
} else {
|
||||||
|
currentOrd = ord;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1115,8 +1129,12 @@ public class SortingResponseWriter implements QueryResponseWriter {
|
||||||
|
|
||||||
public void setNextReader(AtomicReaderContext context) {
|
public void setNextReader(AtomicReaderContext context) {
|
||||||
segment = context.ord;
|
segment = context.ord;
|
||||||
|
if(ordinalMap != null) {
|
||||||
globalOrds = ordinalMap.getGlobalOrds(segment);
|
globalOrds = ordinalMap.getGlobalOrds(segment);
|
||||||
currentVals = segmentVals[segment];
|
currentVals = segmentVals[segment];
|
||||||
|
} else {
|
||||||
|
currentVals = vals;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public void reset() {
|
public void reset() {
|
||||||
|
@ -1127,6 +1145,10 @@ public class SortingResponseWriter implements QueryResponseWriter {
|
||||||
StringValue sv = (StringValue)o;
|
StringValue sv = (StringValue)o;
|
||||||
return comp.compare(currentOrd, sv.currentOrd);
|
return comp.compare(currentOrd, sv.currentOrd);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public String toString() {
|
||||||
|
return Integer.toString(this.currentOrd);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
protected abstract class FieldWriter {
|
protected abstract class FieldWriter {
|
||||||
|
|
Loading…
Reference in New Issue