Class::Std and run-time loading.
Pic
created: 2006-01-05 08:17:20
I've started to use the rather spiffy Class::Std module from CPAN to implement my classes for a mod_perl2 project I'm working on, but the classes I'm using are loaded at run-time according to how things are configured. This gives me the following warning in my error_log: Too late to run CHECK block at /usr/lib/perl5/site_perl/5.8.6/Class/Std.pm line 359.

Now, I've had a look at the Class::Std code, and line 359 is the end of a rather large check block that looks like it's making the various subroutine attributes work. From some experimentation on the CLI, it looks like CHECK blocks aren't executed when the module is loaded via eval EXPR.

Two question to this:
1) Will this break the Class::Std subroutine attributes? (I suspect that it will)
2) If this breaks things, is there a way to make them work that allows me to load my classes at run-time?
Re: Class::Std and run-time loading.
created: 2006-01-05 08:20:36

See bug #14782 – Class::Std does noet (sic) work with mod_perl.

Makeshifts last the longest.

Re^2: Class::Std and run-time loading.
Pic
created: 2006-01-05 08:29:38
Thanks a lot for the very quick reply. I guess it time to head over to CPAN and see what I can find there. The Object::InsideOut class linked from the bug report looks promising for one.
Re^2: Class::Std and run-time loading.
created: 2006-01-05 09:11:14

That sort of "bug" is trivial to work around. Move the contents of the CHECK block into a named subroutine and then have the CHECK block call it. This allows compile-time loading of the module to still work as planned and allows runtime loading to manually compensate. You'd just call the new named function after loading your module.

Before

package Bad::Module;
CHECK {
    ... # Lots of code
}

package Your::Code;
require Bad::Module;
# Error! Too late for CHECK.

After

package Bad::Module;
CHECK {
    STUFF_THAT_NEEDS_DOING();
}

sub STUFF_THAT_NEEDS_DOING {
    ... # Lots of code
}

package Your::Code;
require Bad::Module;
... # All your code
Bad::Module::STUFF_THAT_NEEDS_DOING();

⠤⠤ ⠙⠊⠕⠞⠁⠇⠑⠧⠊

Re^3: Class::Std and run-time loading.
created: 2006-01-05 09:47:34

I know that. But that doesn’t really help CPAN users… whereas knowing that it has been reported and that TheDamian has acknowledged it and plans to offer a workaround in the next version of Class::Std is useful. :-)

Makeshifts last the longest.

Re^4: Class::Std and run-time loading.
created: 2006-01-05 11:34:16

It's good to repeat that because it means it is trivial for a CPAN user to fix the module they're trying to use so it works even if the module's author can't be bothered to fix it themselves.

⠤⠤ ⠙⠊⠕⠞⠁⠇⠑⠧⠊

perlmonks.org content © perlmonks.org and Aristotle, diotalevi, Pic

prlmnks.org © 2006 edmund von der burg (eccles & toad)

v 0.03