X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?p=gitmo%2FMooseX-Singleton.git;a=blobdiff_plain;f=lib%2FMooseX%2FSingleton.pm;h=6b8a84bd4d0ce1e7904ac87610cdfc48a9cafe22;hp=c81d4803ef81637409d502657e36950fadadbc90;hb=c77ec30d3f650b696438bc3dff1544f193efb54c;hpb=060d6e6b284deb1c3e800877409f41aed8c56ec7 diff --git a/lib/MooseX/Singleton.pm b/lib/MooseX/Singleton.pm index c81d480..6b8a84b 100644 --- a/lib/MooseX/Singleton.pm +++ b/lib/MooseX/Singleton.pm @@ -1,24 +1,43 @@ package MooseX::Singleton; -use Moose (); +use Moose 0.82 (); use Moose::Exporter; -use MooseX::Singleton::Object; -use MooseX::Singleton::Meta::Class; +use MooseX::Singleton::Role::Object; +use MooseX::Singleton::Role::Meta::Class; +use MooseX::Singleton::Role::Meta::Instance; -our $VERSION = '0.13'; +our $VERSION = '0.21'; $VERSION = eval $VERSION; Moose::Exporter->setup_import_methods( also => 'Moose' ); sub init_meta { shift; - Moose->init_meta( - @_, - base_class => 'MooseX::Singleton::Object', - metaclass => 'MooseX::Singleton::Meta::Class', + my %p = @_; + + Moose->init_meta(%p); + + my $caller = $p{for_class}; + + Moose::Util::MetaRole::apply_metaclass_roles( + for_class => $caller, + metaclass_roles => ['MooseX::Singleton::Role::Meta::Class'], + instance_metaclass_roles => + ['MooseX::Singleton::Role::Meta::Instance'], + constructor_class_roles => + ['MooseX::Singleton::Role::Meta::Method::Constructor'], + ); + + Moose::Util::MetaRole::apply_base_class_roles( + for_class => $caller, + roles => + ['MooseX::Singleton::Role::Object'], ); + + return $caller->meta(); } + 1; __END__ @@ -29,10 +48,6 @@ __END__ MooseX::Singleton - turn your Moose class into a singleton -=head1 VERSION - -Version 0.08, released 24 May 08 - =head1 SYNOPSIS package MyApp; @@ -60,11 +75,15 @@ All you should need to do to transform your class is to change C to C. This module uses a new class metaclass and instance metaclass, so if you're doing metamagic you may not be able to use this. -C gives your class an C method that can be used to get a handle on the singleton. It's actually just an alias for C. +C gives your class an C method that can be used to +get a handle on the singleton. It's actually just an alias for C. Alternatively, C<< YourPackage->method >> should just work. This includes accessors. +If you need to reset your class's singleton object for some reason (e.g. +tests), you can call C<< YourPackage->_clear_instance >>. + =head1 TODO =over @@ -102,7 +121,7 @@ Ricardo SIGNES Erjbs@cpan.orgE =head1 COPYRIGHT AND LICENSE -Copyright 2007, 2008 Shawn M Moore. +Copyright 2007, 2008 Infinity Interactive This program is free software; you can redistribute it and/or modify it under the same terms as Perl itself.