How can I resolve this case of \"Useless use of a variable in a void context\"?
For example:
my $err = $soap_response->code, \" \", $soap_response-&
I guess you wanted to concatenate the string pieces to form the entire error message, so you'll have to use the dot instead of comma:
my $err = $soap_response->code. " ". $soap_response->string. "\n";
my $err = join(' ', $soap_response->code, $soap_response->string) . "\n";
or, better IMO:
return sprintf "%s %s\n", $soap_response->code, $soap_response->string;
See perldoc -f join and perldoc -f sprintf perldoc perlop.
Regarding the warning, see perldoc perlop and this note on the comma operator.
In case you want to concatenate the arguments, use the "."
operator or join
:
my $err = $soap_response->code. " ". $soap_response->string. "\n";
my $err = join '', $soap_response->code, " ", $soap_response->string, "\n";
Next is why Perl gives you warnings.
You're assigning to a scalar variable $err
, and the right-hand side of the assignment is evaluated in scalar context.
Binary ",
" is the comma operator. In scalar context it evaluates its left argument in void context, throws that value away, then evaluates its right argument in scalar context and returns that value.
Evaluating a variable or a constant and throwing that value away is useless. And perl warns you about this.
FYI: Another possible issue with your code:
my $err = $soap_response->code, " ", $soap_response->string, "\n";
The assignment has higher precedence so that is:
(my $err = $soap_response->code), " ", $soap_response->string, "\n";
See Perl operators and precedence and the Comma operator for more information.