X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=lib%2FClass%2FMOP%2FModule.pm;h=2dba8557b90a87f6d4544bc0108ebe6309f8b2fe;hb=3bc310dd562250ad2bbce64058877d7d95d931a9;hp=8ff573c48047f2c4791987286058f8dcf8525317;hpb=d678919e9108f6768818dfd9eeca44c0c387b185;p=gitmo%2FClass-MOP.git diff --git a/lib/Class/MOP/Module.pm b/lib/Class/MOP/Module.pm index 8ff573c..2dba855 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.85'; $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;