blob: 0738b5d06b966b041ef37c75e62cf91fbe65e1e1 [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.
*/
parcel Lucy;
/** Specify a custom sort order for search results.
*
* By default, searches return results in order of relevance; SortSpec allows
* you to indicate an alternate order via an array of
* L<SortRules|Lucy::Search::SortRule>.
*
* Fields you wish to sort against must be <code>sortable</code>.
*
* For a stable sort (important when paging through results), add a
* sort-by-doc rule as the last SortRule.
*/
class Lucy::Search::SortSpec inherits Lucy::Object::Obj {
VArray *rules;
public inert SortSpec*
new(VArray *rules);
/**
* @param rules An array of SortRules.
*/
public inert SortSpec*
init(SortSpec *self, VArray *rules);
public incremented SortSpec*
Deserialize(SortSpec *self, InStream *instream);
public void
Serialize(SortSpec *self, OutStream *outstream);
VArray*
Get_Rules(SortSpec *self);
public void
Destroy(SortSpec *self);
}