SEARCH
NEW RPMS
DIRECTORIES
ABOUT
FAQ
VARIOUS
BLOG

 
 

perl-Sys-AlarmCall rpm build for : openSUSE Tumbleweed. For other distributions click perl-Sys-AlarmCall.

Name : perl-Sys-AlarmCall
Version : 1.2 Vendor : obs://build_opensuse_org/devel:languages:perl
Release : 7.71 Date : 2024-08-05 18:49:28
Group : Development/Libraries/Perl Source RPM : perl-Sys-AlarmCall-1.2-7.71.src.rpm
Size : 0.01 MB
Packager : (none)
Summary : Sys::AlarmCall Perl module
Description :
Sys::AlarmCall provides a straightforward function call to use the alarm
handler. It also handles the logic which allows nested time out calls if
timeout calls are run thorugh the alarm_call() functions.

The main advantages of Sys::AlarmCall are that:

1. simple calls, e.g.

AATTresult = &func(AATTargs); #Normal function call with \'&\'
$result = func(AATTargs);; #Normal function call
AATTresult = &$code_reference(AATTargs);
AATTresult = $obj->func(AATTargs); #Object method call

become simple calls:

AATTresult = alarm_call($timeout,\'&func\',AATTargs);
$result = alarm_call($timeout,\'func\',AATTargs);
AATTresult = alarm_call($timeout,$code_reference,AATTargs);
AATTresult = alarm_call($timeout,\'->func\',$obj,AATTargs);

no need to futz around with alarms and handlers and worrying about where to
intercept the timer or set globals or whatever; and

2. No need to worry if some subroutines within the call also set a timeout
- all that is handled logically by the Sys::AlarmCall package (as long as
the subroutines also use the alarm_call function of course. But if they
don\'t you\'re up the same creek anyway).

Sys::AlarmCall exports one function,

* alarm_call TIMEOUT,FUNCTION,ARGS

Where TIMEOUT is a positive number (a fatal error occurs if TIMEOUT is
not at least one);

FUNCTION is a string giving the function name (and the \'&\' if wanted, or
preceded by \'->\', e.g. \'->func\', if using that, in which case the calling
object should be the first argument in ARGS); and ARGS is the list of
arguments to that function.

NOTE: As a side effect, normally fatal errors in the FUNCTION call are
caught and reported in the return.

In a scalar context, returns as follows:

If the FUNCTION produces any sort of error (including fatal \'die\'s which
are trapped), returns the error as a string, prepended by the value given
by the variable $Sys::AlarmCall::SCALAR_ERROR (default is \'ERROR \').

If the FUNCTION times out (i.e. doesn\'t return before TIMEOUT - 1),
returns the value given by the variable $Sys::AlarmCall::TIMEOUT (default
is \'TIMEOUT\').

Otherwise, returns the scalar that the FUNCTION returns.

In an array context, returns as follows:

If the FUNCTION produces any sort of error (including fatal \'die\'s which
are trapped), returns a two element array, the first element being the
value given by the variable $Sys::AlarmCall::ARRAY_ERROR (default is
\'ERROR\'), and the second element the error string produced.

If the FUNCTION times out (i.e. doesn\'t return before TIMEOUT - 1),
returns a one element array consisting of the value given by the variable
$Sys::AlarmCall::TIMEOUT (default is \'TIMEOUT\').

Otherwise, returns the array that the FUNCTION returns.

Specific support for the -> construct has been added to alarm_call, so
that calling

alarm_call($timeout,\'->func\',$obj,AATTargs);

means that alarm_call will translate this to

$obj->func(AATTargs);

Specific support for code references (e.g. $ref = sub {warn \"this\
\"})
has been added to alarm_call, so that calling

alarm_call($timeout,$ref,AATTargs);

means that alarm_call will translate this to

&{$ref}(AATTargs);

Timers have resolutions of one second, but remember that a timeout value of
15 will cause a timeout to occur at some point more than 14 seconds in the
future. (see alarm() function in perl man page). Also, nested calls
decrease the resolution (make the uncertain interval larger) by one second
per nesting depth. This is because an alarm call returns the time left
rounded up to the next second.

RPM found in directory: /packages/linux-pbone/ftp5.gwdg.de/pub/opensuse/repositories/devel:/languages:/perl:/CPAN-S/openSUSE_Tumbleweed/noarch

Content of RPM  Provides Requires

Download
ftp.icm.edu.pl  perl-Sys-AlarmCall-1.2-7.71.noarch.rpm
     

Provides :
perl(Sys::AlarmCall)
perl-Sys-AlarmCall

Requires :
perl(:MODULE_COMPAT_5.40.0)
rpmlib(CompressedFileNames) <= 3.0.4-1
rpmlib(FileDigests) <= 4.6.0-1
rpmlib(PayloadFilesHavePrefix) <= 4.0-1
rpmlib(PayloadIsZstd) <= 5.4.18-1


Content of RPM :
/usr/lib/perl5/vendor_perl/5.40.0/Sys
/usr/lib/perl5/vendor_perl/5.40.0/Sys/AlarmCall.pm
/usr/share/doc/packages/perl-Sys-AlarmCall
/usr/share/doc/packages/perl-Sys-AlarmCall/Changes
/usr/share/doc/packages/perl-Sys-AlarmCall/TODO
/usr/share/man/man3/Sys::AlarmCall.3pm.gz

 
ICM