X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=lib%2FClass%2FMOP%2FModule.pm;h=c516259def2d8dedfab36f5987fe454e611a35ec;hb=67f694add1dd6c3c8d78a7aa991e65ff71dd1395;hp=1ca2e400e8ffba48d4f3676e61e5d6eadcf6bcf1;hpb=1f44239e48160cadad8b8847875ce520d52bbf41;p=gitmo%2FClass-MOP.git diff --git a/lib/Class/MOP/Module.pm b/lib/Class/MOP/Module.pm index 1ca2e40..c516259 100644 --- a/lib/Class/MOP/Module.pm +++ b/lib/Class/MOP/Module.pm @@ -7,12 +7,30 @@ use warnings; use Carp 'confess'; use Scalar::Util 'blessed'; -our $VERSION = '0.78'; +our $VERSION = '1.04'; $VERSION = eval $VERSION; our $AUTHORITY = 'cpan:STEVAN'; use base 'Class::MOP::Package'; +sub _new { + my $class = shift; + return Class::MOP::Class->initialize($class)->new_object(@_) + if $class ne __PACKAGE__; + + my $params = @_ == 1 ? $_[0] : {@_}; + return bless { + + # from Class::MOP::Package + package => $params->{package}, + namespace => \undef, + + # attributes + version => \undef, + authority => \undef + } => $class; +} + sub version { my $self = shift; ${$self->get_package_symbol({ sigil => '$', type => 'SCALAR', name => 'VERSION' })}; @@ -33,23 +51,22 @@ sub identifier { } sub create { - my ( $class, %options ) = @_; - - my $package_name = $options{package}; + confess "The Class::MOP::Module->create method has been made a private object method.\n"; +} - (defined $package_name && $package_name) - || confess "You must pass a package name"; +sub _instantiate_module { + my($self, $version, $authority) = @_; + 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}; + Class::MOP::_is_valid_class_name($package_name) + || confess "creation of $package_name failed: invalid package name"; - eval $code; - confess "creation of $package_name failed : $@" if $@; + no strict 'refs'; + scalar %{ $package_name . '::' }; # touch the stash + ${ $package_name . '::VERSION' } = $version if defined $version; + ${ $package_name . '::AUTHORITY' } = $authority if defined $authority; - return; # XXX: should this return some kind of meta object? ~sartak + return; } 1; @@ -90,7 +107,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. @@ -102,7 +119,7 @@ Stevan Little Estevan@iinteractive.comE =head1 COPYRIGHT AND LICENSE -Copyright 2006-2009 by Infinity Interactive, Inc. +Copyright 2006-2010 by Infinity Interactive, Inc. L