From e3c18d9344aa46830c556076b4586025174f5a8b Mon Sep 17 00:00:00 2001 From: Lukas Mai Date: Tue, 16 Apr 2024 08:45:01 +0200 Subject: [PATCH] perldiag: update "You need to quote X" %SIG diagnostic The old description was clearly written for perl 4 programmers. - change "Perl 5" to just "Perl" - recommend foo() to call subroutines (instead of &foo) - mention the option of putting a subroutine reference in %SIG --- pod/perldiag.pod | 18 +++++++++++++----- 1 file changed, 13 insertions(+), 5 deletions(-) diff --git a/pod/perldiag.pod b/pod/perldiag.pod index 2ce34e2fa8cd..fc8e8d1032ef 100644 --- a/pod/perldiag.pod +++ b/pod/perldiag.pod @@ -8255,11 +8255,19 @@ set-id, your best bet is to put a set-id C wrapper around your script. =item You need to quote "%s" -(W syntax) You assigned a bareword as a signal handler name. -Unfortunately, you already have a subroutine of that name declared, -which means that Perl 5 will try to call the subroutine when the -assignment is executed, which is probably not what you want. (If it IS -what you want, put an & in front.) +(W syntax) You assigned a bareword as a signal handler name: + + $SIG{...} = foo; + +However, this will not make C the signal handler. Instead, Perl +will call the subroutine when the assignment is executed and use the +returned value as the signal handler, which is probably not what you want. +(If it I what you want, put C<()> after the subroutine name to avoid +the warning.) + +To register the subroutine as the signal handler, take a reference to it: + + $SIG{...} = \&foo; =item Your random numbers are not that random