Since I keep on finding here and there tests like this:
if (defined ref $thingy ...let me point out that
ref never returns undef. If its argument is not a reference, ref simply returns the empty string (even if called on undef!)
To have an idea on what I'm talking about (and on how common this redundant - and sometimes completely wrong - test is), have a look at here.defined\s*\(?\s*ref - which gives more results (though some of them are not pertinent to be honest).
Anyway thank everyone for the clarification about the origin of this meme (though now I have the same n1vux's curiosity ;-)
Ciao, Emanuele.
I think it used to return undef on older Perls, which is where that meme came from.
Re:Legacy
link on 2006-10-27T09:13:49
It used to be documented as
Returns a TRUE value if EXPR is a reference, FALSE otherwise.
which could mean it returns "" or undef or alternates between them.Re:Legacy
n1vux on 2006-10-27T18:27:20
which means removing the defined() without putting in a require 5.8.0; would potentially create a compatibility regression, on any implementation/releases that actually returned undef when FALSE was documented?
Do we know if it actually returned 'undef' or if it always returned q{} as it's FALSE (but defined) value?Re:Legacy
DAxelrod on 2006-10-28T03:56:26
Since undef is false, wouldn'tif (ref $thingywork in all cases?Re:Legacy
bart on 2006-10-28T08:30:25
Sure it would. At least on the first page of results emazep's Code Search query, all code snippets take the form ofThis can be reduced toif(defined ref $x && ref $foo eq 'X')... even ifif(ref $x && ref $foo eq 'X')... refever returnedundef(which, last I heard, has always been considered false). Which it doesn't, evenreturns a true boolean, a value likeref undef!1. And then,suffices. No warnings, now, ever. But maybe it did warn, in the past.if(ref $foo eq 'X')... Re:Legacy
emazep on 2006-10-28T12:01:36
Well, not always.Under the false assumption that if the argument is not a reference
refreturnsundef, a test like thisto check ifif (defined ref $thingy) {... } $thingyis a reference or not, would clearly be wrong, non just redundant (you can find an example of this here).Anyway my main complaint was about the fact that, even if the code is formally correct (whereas the test is used to supposedly avoid the possible warning from a subsequent test), such
defined-ness test is redundant, or unnecessary, or superfluous (pick your favorite), sincerefnever returnsundef.In other words I mean that there is no reason to say
sinceif (defined ref $thingy && ref $thingy eq 'HASH') {... } gives no warnings as well (at least today), and it is less cluttered and more readable (and a little bit faster tooif (ref $thingy eq 'HASH') {... } ;-) Ciao, Emanuele.
Re:Legacy
emazep on 2006-10-28T12:23:21
UpdatePlease forget my previous pointless post: I wrongly assumed that DAxelrod was talking about
while he clearly saidif (defined ref $thingy) {... } Ciao, Emanuele.if (ref $thingy) {... }