X-Git-Url: http://git.indexdata.com/?p=irspy-moved-to-github.git;a=blobdiff_plain;f=lib%2FZOOM%2FIRSpy%2FTask%2FSearch.pm;h=397dbeee29037f713464b3350024ea645ae5c6a1;hp=91af576f939ee20085a7fd5e71734daacd17884d;hb=d10f84ac6684a1f483629de18d720bb8a8d6bd56;hpb=87370c2294cb2759bf4459ff1bf79992f9a8d07c diff --git a/lib/ZOOM/IRSpy/Task/Search.pm b/lib/ZOOM/IRSpy/Task/Search.pm index 91af576..397dbee 100644 --- a/lib/ZOOM/IRSpy/Task/Search.pm +++ b/lib/ZOOM/IRSpy/Task/Search.pm @@ -1,4 +1,4 @@ -# $Id: Search.pm,v 1.11 2007-03-09 08:57:34 mike Exp $ +# $Id: Search.pm,v 1.13 2007-03-14 11:56:35 mike Exp $ package ZOOM::IRSpy::Task::Search; @@ -44,7 +44,14 @@ sub run { my $query = $this->{query}; $this->irspy()->log("irspy_task", $conn->option("host"), " searching for '$query'"); - $this->{rs}->destroy() if defined $this->{rs}; + die "task $this has resultset?!" if defined $this->{rs}; + + ### 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. $this->{rs} = $conn->search_pqf($query); warn "no ZOOM-C level events queued by $this" if $conn->is_idle();