in reply to Re^2: do [...], @INC subs, 3-args open to heredoc refs (oh my)
in thread do [...], @INC subs, 3-args open to heredoc refs (oh my)

I don't agree that it's simple. You haven't explained how the subroutine reference in @INC gets called. Yes, it could in principle do whatever it wants, but it specifically does

unshift @INC, sub { no warnings 'uninitialized'; ref $_[1] eq 'ARRAY' ? @{$_[1]} : $_[1]; };

which doesn't call the sub. The sub is somehow passed to the filter when the do reads in the heredoc in the 3-argument open that creates the $fh.

The docs I pointed to above in perldoc perlfunc say:

Subroutine references are the simplest case. When the inclusion system walks through @INC and encounters a subroutine, this subroutine gets called with two parameters, the first being a reference to itself, and the second the name of the file to be included (e.g. "Foo/Bar.pm"). The subroutine should return "undef" or a filehandle, from which the file to include will be read. If "undef" is returned, "require" will look at the remaining elements of @INC.

It says that one value, the filehandle, is returned, but the @INC hook above appears to me to return two values; because the "filename" passed to do is an array ref, and the @INC hook returns @{$_[1]}, those are the items inside the array ref ($fh, sub {...}) passed to do. As the docs say, the @INC hook should return a single $fh, but how is the second return value (sub {...}) called?