NAME
OpenGuides::SuperSearch - Search form generation and processing for OpenGuides.
DESCRIPTION
Does search stuff for OpenGuides. Distributed and installed as part of the OpenGuides project, not intended for independent installation. This documentation is probably only useful to OpenGuides developers.
SYNOPSIS
use CGI;
use Config::Tiny;
use OpenGuides::SuperSearch;
my $config = Config::Tiny->read( "wiki.conf" );
my $search = OpenGuides::SuperSearch->new( config => $config );
my %vars = CGI::Vars();
$search->run( vars => \%vars );
METHODS
- new
-
my $config = Config::Tiny->read( "wiki.conf" ); my $search = OpenGuides::SuperSearch->new( config => $config );
- wiki
-
my $wiki = $search->wiki;
An accessor; returns the underlying CGI::Wiki object.
- config
-
my $config = $search->config;
An accessor; returns the underlying Config::Tiny object.
- run
-
my %vars = CGI::Vars(); $search->run( vars => \%vars, return_output => 1, # defaults to 0 return_tt_vars => 1, # defaults to 0 );
The
return_output
parameter is optional. If supplied and true, the stuff that would normally be printed to STDOUT will be returned as a string instead.The
return_tt_vars
parameter is also optional. If supplied and true, the template is not processed and the variables that would have been passed to it are returned as a hash. This parameter takes precedence overreturn_output
.These two parameters exist to make testing easier; you probably don't want to use them in production.
INPUT
- word
-
a single word will be matched as-is. For example, a search on
escalator
will return all pages containing the word "escalator".
- AND searches
-
A list of words with no punctuation will be ANDed, for example:
restaurant vegetarian
will return all pages containing both the word "restaurant" and the word "vegetarian".
- OR searches
-
A list of words separated by commas (and optional spaces) will be ORed, for example:
restaurant, cafe
will return all pages containing either the word "restaurant" or the word "cafe".
- phrase searches
-
Enclose phrases in double quotes, for example:
"meat pie"
will return all pages that contain the exact phrase "meat pie" - not pages that only contain, for example, "apple pie and meat sausage".
OUTPUT
Results will be put into some form of relevance ordering. These are the rules we have tests for so far (and hence the only rules that can be relied on):
A match on page title will score higher than a match on page category or locale.
A match on page category or locale will score higher than a match on page content.
Two matches in the title beats one match in the title and one in the content.
AUTHOR
The OpenGuides Project (openguides-dev@openguides.org)
COPYRIGHT
Copyright (C) 2003-4 The OpenGuides Project. All Rights Reserved.
The OpenGuides distribution is free software; you can redistribute it and/or modify it under the same terms as Perl itself.
SEE ALSO
1 POD Error
The following errors were encountered while parsing the POD:
- Around line 625:
You forgot a '=back' before '=head1'