#!/usr/bin/perl -w
use strict;
use warnings;
use diagnostics;
eval { require Image::Magick };
my $is_Magick = $@ ? 0 : 1;
print "Content-type: text/html; charset=ISO-8859-1\n\n";
print "<h1>$is_Magick</h1>";
which finally works on my XP box, now gives me
Deep recursion on subroutine "Image::Magick::Autoload"
and an out of memory ! on a debian server
has anyone a real working example ? an idea ? anything ? I cannot believe this can't be done !
thanks
Have a nice day !
"There is only one good, namely knowledge, and only one evil, namely ignorance." Socrates
| [reply] [Watch: Dir/Any] [d/l] [select] |
AUTOLOAD is going into an infinite loop trying to reflect a constant, eating up the entire "C" stack. That's the memory you're running out of.
I'm curious as to what is being autloaded. I'd add a print statement to Image/Magick.pm to print out $constname.
The immediate cause of the problem is probably $! =~ /Invalid/ returning false when it is intended to return true. I'd add a print statement to Image/Magick.pm to print out (0+$!).":$!".
Of course, that's assuming your version of Image::Magick is anything like the latest one. You haven't provided any version info.
By the way,
eval { require Image::Magick };
my $is_Magick = $@ ? 0 : 1;
is simpler and safer when written as
my $is_Magick = eval { require Image::Magick; 1 };
| [reply] [Watch: Dir/Any] [d/l] [select] |
It seems like he didn't install imagemagick correctly (both perl bindings, and library)
| [reply] [Watch: Dir/Any] |
Endless recursion would occur, if constant() is not being
found - for whatever reason... Normally, the routine is provided by the
XS code, but in case the wrong shared library is being loaded, or the symbol
isn't exported properly, or something like that, the call
to constant() would be routed to AUTOLOAD itself, leading to the
next level of recursion...
Quick proof of concept code:
#!/usr/bin/perl
package Image::Magick;
sub AUTOLOAD {
# This AUTOLOAD is used to 'autoload' constants from the constant(
+)
# XS function. If a constant is not found then control is passed
# to the AUTOLOAD in AutoLoader.
my $constname;
($constname = $AUTOLOAD) =~ s/.*:://;
print STDERR "$constname "; # DEBUG
my $val = constant($constname, @_ ? $_[0] : 0);
# the following code from the original sub is irrelevant (never re
+ached)
#if ($! != 0) {
# if ($! =~ /Invalid/) {
# $AutoLoader::AUTOLOAD = $AUTOLOAD;
# goto &AutoLoader::AUTOLOAD;
# }
# else {
# my($pack,$file,$line) = caller;
# die "Your vendor has not defined PerlMagick macro $pack\:
+\:$constname, used at $file line $line.\n";
# }
#}
#eval "sub $AUTOLOAD { $val }";
#goto &$AUTOLOAD;
}
package main;
Image::Magick::not_there(); # starts endless recursion
I'm not sure why lepetitalbert's respective print statement doesn't print
anything, but maybe it's just that STDOUT isn't connected to the
terminal here, or some such...
| [reply] [Watch: Dir/Any] [d/l] [select] |