bump version # for next release
[gitmo/Class-MOP.git] / lib / Class / MOP / Package.pm
index e5c270b..06b88d2 100644 (file)
@@ -7,7 +7,8 @@ use warnings;
 use Scalar::Util 'blessed';
 use Carp         'confess';
 
-our $VERSION   = '0.65';
+our $VERSION   = '0.64_02';
+$VERSION = eval $VERSION;
 our $AUTHORITY = 'cpan:STEVAN';
 
 use base 'Class::MOP::Object';
@@ -15,14 +16,20 @@ use base 'Class::MOP::Object';
 # creation ...
 
 sub initialize {
-    my $class        = shift;
-    my $package_name = shift;
+    my ( $class, @args ) = @_;
+
+    unshift @args, "package" if @args % 2;
+
+    my %options = @args;
+    my $package_name = $options{package};
+
+
     # we hand-construct the class 
     # until we can bootstrap it
     if ( my $meta = Class::MOP::get_metaclass_by_name($package_name) ) {
        return $meta;
     } else {
-       my $meta = $class->_new({
+       my $meta = ( ref $class || $class )->_new({
            'package'   => $package_name,
        });
 
@@ -33,12 +40,19 @@ sub initialize {
 }
 
 sub reinitialize {
-    my $class        = shift;
-    my $package_name = shift;
+    my ( $class, @args ) = @_;
+
+    unshift @args, "package" if @args % 2;
+
+    my %options = @args;
+    my $package_name = delete $options{package};
+
     (defined $package_name && $package_name && !blessed($package_name))
         || confess "You must pass a package name and it cannot be blessed";
+
     Class::MOP::remove_metaclass_by_name($package_name);
-    $class->initialize('package' => $package_name, @_);
+
+    $class->initialize($package_name, %options); # call with first arg form for compat
 }
 
 sub _new {