NAME

Lucy::Search::SortRule - Element of a SortSpec.

SYNOPSIS

my $sort_spec = Lucy::Search::SortSpec->new(
    rules => [
        Lucy::Search::SortRule->new( field => 'date' ),
        Lucy::Search::SortRule->new( type  => 'doc_id' ),
    ],
);

DESCRIPTION

SortRules are the building blocks used to assemble SortSpecs; each SortRule defines a single level of sorting. For example, sorting first by “category” then by score requires a SortSpec with two SortRule elements.

CONSTRUCTORS

new

my $by_title   = Lucy::Search::SortRule->new( field => 'title' );
my $by_score   = Lucy::Search::SortRule->new( type  => 'score' );
my $by_doc_id  = Lucy::Search::SortRule->new( type  => 'doc_id' );
my $reverse_date = Lucy::Search::SortRule->new(
    field   => 'date',
    reverse => 1,
);

Create a new SortRule.

  • type - Indicate whether to sort by score, field, etc. (The default is to sort by a field.)

  • field - The name of a sortable field.

  • reverse - If true, reverse the order of the sort for this rule.

METHODS

get_field

my $string = $sort_rule->get_field();

Accessor for “field” member.

get_type

my $int = $sort_rule->get_type();

Accessor for “type” member.

get_reverse

my $bool = $sort_rule->get_reverse();

Accessor for “reverse” member.

INHERITANCE

Lucy::Search::SortRule isa Clownfish::Obj.