blob: d9a3316683302715a8fe02796379a5cdba632f58 [file] [log] [blame]
/**
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership.
* The ASF licenses this file to You under the Apache License, Version 2.0
* (the "License"); you may not use this file except in compliance with
* the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package org.apache.solr.search;
import org.apache.lucene.search.*;
import org.apache.lucene.index.IndexReader;
import java.io.IOException;
/**
* A {@link SortComparatorSource} for strings that orders null values after non-null values.
* Based on FieldSortedHitQueue.comparatorString
* <p>
*
* @version $Id$
*
*/
// move to apache package and make public if it is accepted as a patch
public class MissingStringLastComparatorSource implements SortComparatorSource {
public static final String bigString="\uffff\uffff\uffff\uffff\uffff\uffff\uffff\uffffNULL_VAL";
private final String missingValueProxy;
public MissingStringLastComparatorSource() {
this(bigString);
}
/**
* Returns the value used to sort the given document. The
* object returned must implement the java.io.Serializable
* interface. This is used by multisearchers to determine how to collate results from their searchers.
* @see FieldDoc
* @param i Document
* @return Serializable object
*/
/** Creates a {@link SortComparatorSource} that uses <tt>missingValueProxy</tt> as the value to return from ScoreDocComparator.sortValue()
* which is only used my multisearchers to determine how to collate results from their searchers.
*
* @param missingValueProxy The value returned when sortValue() is called for a document missing the sort field.
* This value is *not* normally used for sorting, but used to create
*/
public MissingStringLastComparatorSource(String missingValueProxy) {
this.missingValueProxy=missingValueProxy;
}
public ScoreDocComparator newComparator(final IndexReader reader,
final String fieldname)
throws IOException {
final String field = fieldname.intern();
final FieldCache.StringIndex index =
FieldCache.DEFAULT.getStringIndex (reader, field);
// :HACK:
// final String lastString =
// (index.lookup[index.lookup.length-1]+"X").intern();
//
// Note: basing lastStringValue on the StringIndex won't work
// with a multisearcher.
return new ScoreDocComparator () {
public final int compare (final ScoreDoc i, final ScoreDoc j) {
final int fi = index.order[i.doc];
final int fj = index.order[j.doc];
// 0 is the magic position of null
/**** alternate logic
if (fi < fj && fi != 0) return -1;
if (fj < fi && fj != 0) return 1;
if (fi==fj) return 0;
return fi==0 ? 1 : -1;
****/
if (fi==fj) return 0;
if (fi==0) return 1;
if (fj==0) return -1;
return fi < fj ? -1 : 1;
}
public Comparable sortValue (final ScoreDoc i) {
int f = index.order[i.doc];
return (0 == f) ? missingValueProxy : index.lookup[f];
}
public int sortType() {
return SortField.CUSTOM;
}
};
}
}