NAME AutoXS - Speed up your code after compile time SYNOPSIS package MyClass; sub blah {...} use AutoXS ':all'; # if blah matches one of the patterns, it's running # as XS code now! DESCRIPTION *Warning:* This module contains some scary code. I'm not even sure it abides by the official Perl API totally. Furthermore, it's my first *real* XS module. It abuses some features of the XS/XSUB syntax. If you break it, you get to keep both halves. That being said, the purpose of this module and its plugin modules is to speed up the execution of your program at the expense of a longer startup time. AutoXS::Accessor comes with the same distribution as an example plugin. AuotXS plugins use the B and B::Utils modules to scan all subroutines (or methods) in the calling package for certain patterns. If a subroutine complies with such a pattern, it is replaced with an XS subroutine that has the same function. The XS subroutines for replacement are *not* compiled at runtime like Inline::C would do. They have been compiled at module build time just like any other XSUBs. In a simple minded test, AuotXS::Accessor sped up typical read-only accessors by a factor of 1.6 to a factor of 2.5. Your mileage may vary, of course. Keep in mind mind that accessors can sometimes be part of very tight loops. To get an impression of the imposed pre-runtime penalty of using AutoXS, a file containing nine methods (code shown in AutoXS::Accessor) was compiled with and without AutoXS. The test is contrived because all nine methods will be replaced. In normal code, there is much more non-accessor code which will be quickly rejected. Naturally, rejection is faster than successful matching and replacement. The compilation with AutoXS took "74ms" longer than without. CAVEATS This is alpha code. Beware. The module abuses XS syntax constructs. The startup penalty may be big and is proportional to the number of subroutines in the calling package. The module works its magic at CHECK time. CHECK blocks are not executed in string "eval """ environments. That means this module potentially does not work in a PAR packaged executable. (It should do no harm there, either.) SEE ALSO AutoXS::Accessor AutoXS::Header B, B::Utils AUTHOR Steffen Mueller, <smueller@cpan.org> COPYRIGHT AND LICENSE Copyright (C) 2008 by Steffen Mueller This library is free software; you can redistribute it and/or modify it under the same terms as Perl itself, either Perl version 5.8 or, at your option, any later version of Perl 5 you may have available.