X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=lib%2FClass%2FMOP%2FModule.pm;h=33eb10a5bdd6a0affb53078a8a8ce0d73fbd3752;hb=b4bd10ecd2eabe1a2c1bc3addad22b207f6592ee;hp=8bf93b0c10a2bc09e5a18a77b2b59c49ace48193;hpb=7f436b8c244d791e254b49668ac2b6d5218314e4;p=gitmo%2FClass-MOP.git diff --git a/lib/Class/MOP/Module.pm b/lib/Class/MOP/Module.pm index 8bf93b0..33eb10a 100644 --- a/lib/Class/MOP/Module.pm +++ b/lib/Class/MOP/Module.pm @@ -4,22 +4,52 @@ package Class::MOP::Module; use strict; use warnings; +use Carp 'confess'; use Scalar::Util 'blessed'; -our $VERSION = '0.01'; +our $VERSION = '0.77'; +$VERSION = eval $VERSION; +our $AUTHORITY = 'cpan:STEVAN'; use base 'Class::MOP::Package'; -# introspection +sub version { + my $self = shift; + ${$self->get_package_symbol({ sigil => '$', type => 'SCALAR', name => 'VERSION' })}; +} -sub meta { - require Class::MOP::Class; - Class::MOP::Class->initialize(blessed($_[0]) || $_[0]); +sub authority { + my $self = shift; + ${$self->get_package_symbol({ sigil => '$', type => 'SCALAR', name => 'AUTHORITY' })}; } -sub version { +sub identifier { my $self = shift; - ${$self->get_package_variable('$VERSION')}; + join '-' => ( + $self->name, + ($self->version || ()), + ($self->authority || ()), + ); +} + +sub create { + my ( $class, %options ) = @_; + + my $package_name = $options{package}; + + (defined $package_name && $package_name) + || confess "You must pass a package 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}; + + eval $code; + confess "creation of $package_name failed : $@" if $@; + + return; # XXX: should this return some kind of meta object? ~sartak } 1; @@ -32,31 +62,60 @@ __END__ Class::MOP::Module - Module Meta Object -=head1 SYNOPSIS - =head1 DESCRIPTION +This is an abstraction of a Perl 5 module, it is a superclass of +L. A module essentially a package with metadata, +in our case the version and authority. + +=head1 INHERITANCE + +B is a subclass of L + =head1 METHODS =over 4 =item B +Returns a metaclass for this package. + +=item B + +This will initialize a Class::MOP::Module instance which represents +the module of C<$package_name>. + =item B +This is a read-only attribute which returns the C<$VERSION> of the +package for the given instance. + +=item B + +This is a read-only attribute which returns the C<$AUTHORITY> of the +package for the given instance. + +=item B + +This constructs a string of the name, version and authority. + +=item B + +This creates the module; it does not return a useful result. + =back -=head1 AUTHOR +=head1 AUTHORS Stevan Little Estevan@iinteractive.comE =head1 COPYRIGHT AND LICENSE -Copyright 2006 by Infinity Interactive, Inc. +Copyright 2006-2008 by Infinity Interactive, Inc. L This library is free software; you can redistribute it and/or modify it under the same terms as Perl itself. -=cut \ No newline at end of file +=cut