Ah, you gave me enough clues...
use strict is turned into require strict; which loads the module, followed by strict->import;. But Perl now knows strict as a filehandle, so this syntax is treated as an object method call to the filehandle object associated with the filehandle with the name " strict".
Since either there is a method for the package IO::Handle (or else, import has a special status so perl won't complain if it can't find it), it works but actually doesn't do much. What it definitely doesn't do is call import for the package strict. That's why strict checks are still off.
So it's all caused by the ambiguous syntax of word->method, which may represent either a class method call, or an object method call.
| [reply] [d/l] [select] |
| [reply] |
It certainly seems so, we can even verify this like this.
perl -we 'use IO::Handle; { package IO::Handle; sub import { warn "imp
+ort called on handle $_[0]"; } } if (0) { open strict; } BEGIN { warn
+ "about to use strict"; } use strict; BEGIN { warn "after use strict"
+; } use warnings;'
However, I don't understand why this happens even before the open is called at all. I originally wrote the snippet with open in a BEGIN, because I thought that was the only way to trigger this. In fact, as open $foo, ... should autovivify a new glob with filehandle each time it's executed, I don't really know why open strict should do anything in compile time.
Indeed, notice how my $h = *strict; open $h; triggers the feature if it's ran in a BEGIN block before use strict;, but not if it's just compiled before it.
| [reply] [d/l] [select] |