X-Git-Url: http://git.indexdata.com/?p=irspy-moved-to-github.git;a=blobdiff_plain;f=lib%2FZOOM%2FIRSpy%2FTask.pm;h=1bdd8e43ca8cff14e007a5cc0ce7fb9ed116ea20;hp=e39e18400188c85e738d28f4cd2ad67782a27497;hb=7ab42fd97d4e0726e483f3685e77ad5f6db9f743;hpb=744326399dd931fc8e5360ffa0493f641b91e970 diff --git a/lib/ZOOM/IRSpy/Task.pm b/lib/ZOOM/IRSpy/Task.pm index e39e184..1bdd8e4 100644 --- a/lib/ZOOM/IRSpy/Task.pm +++ b/lib/ZOOM/IRSpy/Task.pm @@ -1,4 +1,4 @@ -# $Id: Task.pm,v 1.2 2006-10-12 14:36:34 mike Exp $ +# $Id: Task.pm,v 1.4 2006-10-25 13:34:56 mike Exp $ package ZOOM::IRSpy::Task; @@ -32,13 +32,14 @@ pointer to the next task to be performed after this. sub new { my $class = shift(); - my($conn, $udata, %cb) = @_; + my($conn, $udata, $options, %cb) = @_; return bless { irspy => $conn->{irspy}, conn => $conn, - cb => \%cb, udata => $udata, + options => $options, + cb => \%cb, timeRegistered => time(), }, $class; } @@ -64,6 +65,19 @@ sub run { die "can't run base-class task $this"; } +sub set_options { + my $this = shift(); + + foreach my $key (sort keys %{ $this->{options} }) { + my $value = $this->{options}->{$key}; + $value = "" if !defined $value; + $this->conn()->log("irspy_debug", "$this setting option '$key' -> ", + defined $value ? "'$value'" : "undefined"); + $this->{options}->{$key} = $this->conn()->option($key, $value); + #Net::Z3950::ZOOM::connection_option_set($this->conn()->_conn(), $key, $value); + } +} + sub render { my $this = shift(); return "[base-class] " . ref($this);