Hi Tosh,

The function sigil ("&") is an archaic left over from before perl5. Calling a 
function as "&cfg" is the same as saying "&cfg(@_)" and that implicit "@_" was 
probably the source of your problem. A bit more information can be found here:

http://www.perlfoundation.org/perl5/index.cgi?subroutines_called_with_the_ampersand

Executive summary: don't use "&" on a sub unless you need a sub-ref:

        my $x = \&cfg;
        $x->();


On 2010-01-14, at 13:28 , Tosh Cooey wrote:

> Ok now I'm really boggled...
> 
> If I use:
> 
> my $vars = { config => &cfg() };
> instead of:
> my $vars = { config => &cfg };
> 
> Then it works!  So what's the difference between &cfg and &cfg() when it 
> comes to mod_perl, or at least ModPerl::Registry?
> 
> Thank-you all...
> 
> Tosh
> 
> 
> Tosh Cooey wrote:
>> True, good point.  I cleaned up my code and changed some things around and I 
>> still have the same problem:
>> index.pl
>> ########
>> use MyConfig;
>> use ClientConf;
>> use MyUser;
>> my $vars = { config => &cfg };
>> MyConfig.pm
>> ###########
>> package MyConfig;
>> use strict;
>> use Exporter;
>> use vars qw(@ISA @EXPORT);
>> @ISA = qw(Exporter);
>> @EXPORT = qw(&cfg &user);
>> my %CFG = { global vars... };
>> sub cfg {
>>   return ClientConf->new();
>> }
>> sub user {
>>   return MyUser->new();
>> }
>> 1;
>> The function "user" works just fine, it returns the object as expected.
>> #### BREAK ####
>> So, while I was testing to make sure everything works exactly as I described 
>> above I discovered unexpected behaviour.  &cfg is actually:
>> sub cfg {
>>  my ($cfg_var) = @_;
>>  if ($cfg_var) {
>>    ...do something...
>>  } else {
>>    return ClientConf->new();
>>  }
>> }
>> &user is exactly as noted above.  When I changed &user and added the same 
>> $cfg_var and conditional it also did not return what I expected.
>> So basically the problem I'm having is that even though I'm calling &cfg 
>> without arguments that $cfg_var is evaluating as "TRUE", but only under 
>> ModPerl::Registry and not under regular unadulterated PERL.
>> As a PERL user for 15 years am I just the biggest newbie ever, or is there 
>> something obscure going on that I should know about?
>> Thanks for anything!
>> Tosh
>> Ihnen, David wrote:
>>> Global?  There's no need to use a global here.   You only ever reference 
>>> %CFG *in* the package... so just make it package scoped - it'll act like a 
>>> static variable and persist.  (scope it with 'my' and remove it from the 
>>> export)
>>> 
>>> You can always get the value you want with a call to MyConfig::cfg
>>> 
>>> David
>>> 
>>> -----Original Message-----
>>> From: Tosh Cooey [mailto:t...@1200group.com] Sent: Thursday, January 14, 
>>> 2010 10:45 AM
>>> To: modperl@perl.apache.org
>>> Subject: A ghost in the machine?
>>> 
>>> Hi to everyone!
>>> 
>>> I'm trying to find out if I'm passing objects properly under mod_perl 
>>> because something is not working as I expect.
>>> 
>>> index.pl
>>> ########
>>> use MyConfig;
>>> my $vars = { config => &cfg };
>>> 
>>> 
>>> MyConfig.pm
>>> ###########
>>> package MyConfig;
>>> 
>>> use strict;
>>> use Exporter;
>>> use vars qw(@ISA @EXPORT %CFG );
>>> use ClientConf;
>>> @ISA = qw(Exporter);
>>> @EXPORT = qw(%CFG &cfg);
>>> 
>>> %CFG = { global vars... };
>>> 
>>> sub cfg {
>>>   my $CFG{$clientID} = new ClientConf;
>>>   return $CFG{$clientID};
>>> }
>>> 1;
>>> 
>>> 
>>> Under normal PERL $vars->{config} is a MyConfig object.  Under mod_perl 
>>> nothing is returned.  Debugging with "print" statements in &cfg shows me 
>>> that "ref $CFG{$clientID}" is ClientConf, the object is there, but upon 
>>> return it just disappears.
>>> 
>>> I have other functions which "return new MyUser()" and these work 
>>> perfectly, so I'm thinking that the problem lies with the global variable 
>>> "$CFG" and that something which I think should be happening is NOT 
>>> happening.
>>> 
>>> I'm flummoxed...
>>> 
>>> Thank-you for any insights!
>>> 
>>> Tosh
>>> 
> 
> -- 
> McIntosh Cooey - Twelve Hundred Group LLC - http://www.1200group.com/


Eric Howe
e...@pieinsky.ca

Reply via email to