Revision history for subs-parallel
0.08 Sat Jan 6 02:01:34 2007
* bugfix: overriden CORE::GLOBAL::ref came without a prototype and thus
resulted in breakage
* added caveat regarding the interaction between this module and
Catalyst (and possibly other modules)
* fixed some typos, reformatted this Changes file
0.07 Sun Jun 19 12:30:10 2005
* s/parallelyze/parallelize/g
Thanks to Christian Renz (crenz AT web42.com) for promptly reporting
me the right way to spell the word. As a non-native English speaker
I'm prone to this kind of errors, since it was a word I've never
heard before. Fortunately, the module is very new and it wasn't too
late for a big interface change like this one. I confess I'm really
glad to have this kind of feedback.
0.06 Sun Jun 19 01:33:00 2005
* Fixed the Makefile.pl. It seems that Module::Starter generated a
wrong output file which only works on Windows (paths with '\' instead
of '/'). This has been fixed. Thanks to Sébastien Aperghis-Tramoni
(SAPER at cpan.org) for pointing it out.
0.05 Sat Jun 18 09:45:59 2005
* Fix problems with Pod::Coverage failing on some subs which were the
last ones added and should be private. Now it should be successfully
installed without "force".
0.04 Tue Jun 17 23:26:44 2005
This is more of a fine-tuning version, just to guarantee that some
specific situations will work as expected.
* First CPAN upload after giving up waiting an answer from the folks at
the official module-list.
* Some simple test cases added.
* Now, parallelyzed subs keep their prototypes. This didn't happen
before, so you couldn't parallelyze LWP::Simple's get() without a
warning. It would DWYM, though, but it seemed wrong. So this is fixed
but introduced the dependency of Scalar::Util (which would end up
being included anyway, as there's a lot of magic going on here).
* CORE::GLOBAL::ref() is now overriden in order to make it DWIM with
returned objects (previously, it would returns 'subs::parallel').
0.03 Mon Jun 13 20:50:25 2005
* Refactored the functional interface, so it makes more sense.
* Now there's documentation! Including a big "CAVEATS" section.
* Previously if you never used the return value of a parallelyzed sub
(i.e. it was called in void context) some memory would be leaked due
to non-detached threads waiting to be joined. Now, when the return
value goes out of scope (or never even enters, as in void context)
the threads are detached.
* The previous fix resulted in another bug which caused threads to be
incorrectly detached. This has been worked around.
* parallelyze() was causing "Scalars leaked: 1" warnings. Although
I don't really, understand why, it has been fixed. All I needed to
do was to change its definition from
sub parallelyze (&) { parallelyze_coderef(@_)->() }
to
sub parallelyze (&) { parallelyze_coderef(shift)->() }
As I read somewhere, I suspect there's just too much magic associated
with @_.
* The "parallel" attribute is now known as "Parallel" due to perl
interpreter whining.
* 0.03 is a much more respectable version number (hence the number of
issues fixed / worked-around).
0.02 June 10, 2005
This was supposed to be the first public version. But I decided to bump
up the version number because it seemed like the way to go. Besides,
who would use a module that is only version 0.02 and doesn't have that
many features? ;)
* "parallel" attribute handling implemented
0.01 June, 2005
* Gathering ideas.
* Making it just work.