Beefy Boxes and Bandwidth Generously Provided by pair Networks
Perl Monk, Perl Meditation

Re^3: Random Tips on Parse::RecDescent

by Aristotle (Chancellor)
on Jul 13, 2002 at 02:30 UTC ( #181435=note: print w/replies, xml ) Need Help??

in reply to Re: Re: Random Tips on Parse::RecDescent
in thread Random Tips on Parse::RecDescent

Because %PACKAGE:: is a special hashtable containing all global symbols from the given PACKAGE. Via that hash, a hard reference to the desired subroutine can be looked up. The call to UNIVERSAL::can produces the same result. And obviously calling a subroutine by dereferencing a hard reference is allowed under the stricture.

Try the following sometime:

$ perl -MData::Dumper -e'print Dumper(\%main::);'

It's rather interesting to poke around in there.

Basically, a lot of things in Perl (all of OO really, f.ex) are symbolic lookups, so they cannot be evil by nature. What is evil is accidentally using symbolic lookups where you meant a hard dereference. If your code has a bug so that it happens to put a string rather than the hard reference you intended into $var, without the stricture $$var will still work but suddenly becomes a soft reference. If that only happens sporadically, the resulting bugs can be incredibly hard to spot. That's what strict 'refs' catches, and that's why I strongly suggest you reenable it. You're depriving yourself of a very important safety net otherwise.

Conversly, when you really do need a symbolic lookup, you can still achieve it in ways strict won't complain about. It's just that you explicitly spell out that you do in fact want a symbolic lookup and are fully aware that it's happening.

Makeshifts last the longest.

Replies are listed 'Best First'.
Re: Re^3: Random Tips on Parse::RecDescent
by hsmyers (Canon) on Jul 13, 2002 at 16:10 UTC
    Excellent! Good explanation, better idea. The qualification using $main:: becomes Perl's "What I tell you three times is true."-- even better since you don't have to tell it the first two times! Conceptually not greatly different from a 'C' cast. Thanks, it will be in the revised version, I am holding off until Monday or so, hoping for additional useful suggestions...


    "Never try to teach a pig to sing…it wastes your time and it annoys the pig."

Log In?

What's my password?
Create A New User
Node Status?
node history
Node Type: note [id://181435]
and the web crawler heard nothing...

How do I use this? | Other CB clients
Other Users?
Others examining the Monastery: (3)
As of 2020-10-30 03:02 GMT
Find Nodes?
    Voting Booth?
    My favourite web site is:

    Results (277 votes). Check out past polls.