/usr/share/perl5/Tk/waitVariableX.pm is in libtk-splashscreen-perl 1.0-3.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 | $Tk::waitVariableX::VERSION = '1.0';
package Tk::waitVariableX;
use Carp;
use Exporter;
use base qw/Exporter/;
@EXPORT = qw/waitVariableX/;
use strict;
sub waitVariableX {
use Tie::Watch;
my ($parent, $millis) = (shift, shift); # @_ has list of var refs
croak "waitVariableX: no milliseconds." unless defined $millis;
my ($callback, $st, $tid, @watch, $why);
if (ref $millis eq 'ARRAY') {
$callback = Tk::Callback->new($millis->[1]);
$millis = $millis->[0];
}
$st = sub {my $argv = $_[0]->Args('-store'); $why = $argv->[0]};
foreach my $vref (@_) {
push @watch,
Tie::Watch->new(-variable => $vref, -store => [$st, $vref]);
}
$tid = $parent->after($millis => sub {$why = 0}) unless $millis == 0;
$parent->waitVariable(\$why); # wait for timer or watchpoint(s)
$_->Unwatch foreach @watch;
$parent->afterCancel($tid);
$callback->Call($why) if defined $callback;
return $why; # why we stopped waiting: 0 or $vref
} # end waitVariableX
1;
__END__
=head1 NAME
Tk::waitVariableX - a waitVariable with extensions.
=head1 SYNOPSIS
use Tk::waitVariableX;
$splash->waitVariableX( [$millis, $destroy_splashscreen], \$v1, \$v2} );
=head1 DESCRIPTION
This subroutine waits for a list of variables, with a timeout - the
subroutine returns when one of the variables changes value or the timeout
expires, whichever occurs first.
Although the millisecond parameter is required, it may be zero, which
effects no timeout. The milliscond paramter may also be an array of
two elements, the first the millisecond value, and the second a
normal Per/Tk callback. The callback is invoked just before
waitVariableX returns.
Callback format is patterned after the Perl/Tk scheme: supply either a
code reference, or, supply an array reference and pass the callback
code reference in the first element of the array, followed by callback
arguments.
=head1 COPYRIGHT
Copyright (C) 2000 - 2002 Stephen O. Lidie. All rights reserved.
This program is free software; you can redistribute it and/or modify it under
the same terms as Perl itself.
=cut
|