Revision history for subs-parallel-0.06

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 DWYM 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.