- my $query = $this->{query};
- $this->irspy()->log("irspy_test", $conn->option("host"),
- " searching for '$query'");
- $this->{rs} = $conn->search_pqf($query);
- # Wow -- that's it.
+ $conn->connect($conn->option("host"));
+
+ my $qtype = $this->{qtype};
+ my $qstr = $this->{qstr};
+ $this->irspy()->log("irspy_task", $conn->option("host"),
+ " searching for '$qtype:$qstr'");
+ die "task $this has resultset?!" if defined $this->{rs};
+
+ my $query;
+ if ($qtype eq "pqf") {
+ $query = new ZOOM::Query::PQF($qstr);
+ } elsif ($qtype eq "cql") {
+ $query = new ZOOM::Query::CQL($qstr);
+ } else {
+ die "Huh?!";
+ }
+
+ ### Note well that when this task runs, it creates a result-set
+ # object which MUST BE DESTROYED in order to prevent large-scale
+ # memory leakage. So when creating a Task::Search, it is the
+ # APPLICATION'S RESPONSIBILITY to ensure that the callback
+ # invoked on success OR FAILURE makes arrangements for the set
+ # to be destroyed.
+ eval {
+ $this->{rs} = $conn->search($query);
+ }; if ($@) {
+ die "remote search '$query' had error: '$@'";
+ }
+
+ warn "no ZOOM-C level events queued by $this"
+ if $conn->is_idle();
+
+ $this->set_options();
+}
+
+# Unique to Task::Search, used only for logging
+sub render_query {
+ my $this = shift();
+ return $this->{qtype} . ":" . $this->{qstr}