~slub.team/goobi-indexserver/3.x

« back to all changes in this revision

Viewing changes to solr/core/src/java/org/apache/solr/search/Sorting.java

  • Committer: Sebastian Meyer
  • Date: 2012-08-03 09:12:40 UTC
  • Revision ID: sebastian.meyer@slub-dresden.de-20120803091240-x6861b0vabq1xror
Remove Lucene and Solr source code and add patches instead
Fix Bug #985487: Auto-suggestion for the search interface

Show diffs side-by-side

added added

removed removed

Lines of Context:
1
 
/**
2
 
 * Licensed to the Apache Software Foundation (ASF) under one or more
3
 
 * contributor license agreements.  See the NOTICE file distributed with
4
 
 * this work for additional information regarding copyright ownership.
5
 
 * The ASF licenses this file to You under the Apache License, Version 2.0
6
 
 * (the "License"); you may not use this file except in compliance with
7
 
 * the License.  You may obtain a copy of the License at
8
 
 *
9
 
 *     http://www.apache.org/licenses/LICENSE-2.0
10
 
 *
11
 
 * Unless required by applicable law or agreed to in writing, software
12
 
 * distributed under the License is distributed on an "AS IS" BASIS,
13
 
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14
 
 * See the License for the specific language governing permissions and
15
 
 * limitations under the License.
16
 
 */
17
 
 
18
 
package org.apache.solr.search;
19
 
 
20
 
import org.apache.lucene.search.*;
21
 
 
22
 
/**
23
 
 * Extra lucene sorting utilities & convenience methods
24
 
 *
25
 
 * @version $Id: Sorting.java 778893 2009-05-26 21:34:53Z yonik $
26
 
 *
27
 
 */
28
 
 
29
 
public class Sorting {
30
 
 
31
 
 
32
 
  /** Returns a {@link SortField} for a string field.
33
 
   *  If nullLast and nullFirst are both false, then default lucene string sorting is used where
34
 
   *  null strings sort first in an ascending sort, and last in a descending sort.
35
 
   *
36
 
   * @param fieldName   the name of the field to sort on
37
 
   * @param reverse     true for a reverse (desc) sort
38
 
   * @param nullLast    true if null should come last, regardless of sort order
39
 
   * @param nullFirst   true if null should come first, regardless of sort order
40
 
   * @return SortField
41
 
   */
42
 
  public static SortField getStringSortField(String fieldName, boolean reverse, boolean nullLast, boolean nullFirst) {
43
 
    if (nullLast) {
44
 
      if (!reverse) return new SortField(fieldName, nullStringLastComparatorSource);
45
 
      else return new SortField(fieldName, SortField.STRING, true);
46
 
    } else if (nullFirst) {
47
 
      if (reverse) return new SortField(fieldName, nullStringLastComparatorSource, true);
48
 
      else return new SortField(fieldName, SortField.STRING, false);
49
 
    } else {
50
 
      return new SortField(fieldName, SortField.STRING, reverse);
51
 
    }
52
 
  }
53
 
 
54
 
 
55
 
  static final FieldComparatorSource nullStringLastComparatorSource = new MissingStringLastComparatorSource(null);
56
 
}
57