X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=lib%2FClass%2FMOP%2FModule.pm;h=cf12b2ac703de1fc4e7ee3cffd6eb099658a19dd;hb=47d35fbafc21dc6ede2024c81bbb6504e3cb27ae;hp=1ca2e400e8ffba48d4f3676e61e5d6eadcf6bcf1;hpb=3d964063816727a1eba05041b3f94d884d99011d;p=gitmo%2FClass-MOP.git diff --git a/lib/Class/MOP/Module.pm b/lib/Class/MOP/Module.pm index 1ca2e40..cf12b2a 100644 --- a/lib/Class/MOP/Module.pm +++ b/lib/Class/MOP/Module.pm @@ -7,7 +7,7 @@ use warnings; use Carp 'confess'; use Scalar::Util 'blessed'; -our $VERSION = '0.78'; +our $VERSION = '0.84'; $VERSION = eval $VERSION; our $AUTHORITY = 'cpan:STEVAN'; @@ -33,23 +33,25 @@ sub identifier { } sub create { - my ( $class, %options ) = @_; + confess "The Class::MOP::Module->create method has been made a private object method.\n"; +} - my $package_name = $options{package}; +sub _instantiate_module { + my $self = shift; + my $version = shift; + my $authority = shift; - (defined $package_name && $package_name) - || confess "You must pass a package name"; + my $package_name = $self->name; my $code = "package $package_name;"; - $code .= "\$$package_name\:\:VERSION = '" . $options{version} . "';" - if exists $options{version}; - $code .= "\$$package_name\:\:AUTHORITY = '" . $options{authority} . "';" - if exists $options{authority}; + + $code .= "\$$package_name\:\:VERSION = '" . $version . "';" + if defined $version; + $code .= "\$$package_name\:\:AUTHORITY = '" . $authority . "';" + if defined $authority; eval $code; confess "creation of $package_name failed : $@" if $@; - - return; # XXX: should this return some kind of meta object? ~sartak } 1; @@ -90,7 +92,7 @@ package, if one exists. This constructs a string which combines the name, version and authority. -=item B<< Class::MOP::Module->meta > +=item B<< Class::MOP::Module->meta >> This will return a L instance for this class.