8 |
=cut |
=cut |
9 |
|
|
10 |
package Grep::Action::Search; |
package Grep::Action::Search; |
11 |
use base qw/Grep::Action::SearchItem/; |
|
12 |
|
use Grep::Search; |
13 |
|
|
14 |
use Data::Dump qw/dump/; |
use Data::Dump qw/dump/; |
15 |
use Time::HiRes qw/time/; |
use Time::HiRes qw/time/; |
16 |
|
|
17 |
|
use Jifty::Param::Schema; |
18 |
|
use Jifty::Action schema { |
19 |
|
|
20 |
|
param q => |
21 |
|
type is 'text', |
22 |
|
label is 'Search for', |
23 |
|
hint is 'enter few words to search for'; |
24 |
|
|
25 |
|
param item_fragment => |
26 |
|
label is 'Display format', |
27 |
|
render as 'select', |
28 |
|
available are qw/long short title/; |
29 |
|
|
30 |
|
param max => |
31 |
|
label is 'Number or results', |
32 |
|
render as 'select', |
33 |
|
available are qw/10 20 50 100/; |
34 |
|
default is '20'; |
35 |
|
|
36 |
|
}; |
37 |
|
|
38 |
=head2 take_action |
=head2 take_action |
39 |
|
|
40 |
=cut |
=cut |
42 |
sub take_action { |
sub take_action { |
43 |
my $self = shift; |
my $self = shift; |
44 |
|
|
45 |
$self->SUPER::take_action( @_ ); |
my $q = $self->argument_value('q'); |
46 |
|
|
47 |
my $coll = $self->result->content('search'); |
return $self->result->error("Need search query") unless ($q); |
48 |
|
|
49 |
Jifty->log->error('result not collection but ', dump( $coll )) |
my $search = Grep::Search->new(); |
|
unless ( $coll->isa('Jifty::Collection') ); |
|
50 |
|
|
51 |
if ($coll->count > 0) { |
my $coll = $search->collection( $q ) || |
52 |
$self->result->message( 'Found ' . $coll->count . ' results' ); |
return $self->result->error("No results"); |
53 |
|
|
54 |
warn "### about to fork!"; |
$self->log->fatal('result not collection but ', dump( $coll )) |
55 |
|
if ( !$coll || !$coll->isa('Jifty::Collection') ); |
56 |
|
|
57 |
if (fork) { |
my $hits = $search->hits; |
|
my $t = $coll->count; |
|
|
warn "### sleeping $t s..."; |
|
|
sleep $t; |
|
|
Grep::Event::Result->new({ coll => $coll, item_fragment => 'title' })->publish; |
|
|
exit 0; |
|
|
} |
|
58 |
|
|
59 |
|
if ($hits > 0) { |
60 |
|
$self->result->message( "Found $hits results for '$q'" ); |
61 |
} else { |
} else { |
62 |
$self->result->error('No local results found, wait for remote results to arrive...'); |
$self->result->error('No local results, try remote feeds...'); |
63 |
} |
} |
64 |
|
|
65 |
|
$self->result->content( search => $coll ); |
66 |
|
|
67 |
return $coll; |
return $coll; |
68 |
} |
} |
69 |
|
|