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.14';
+our $VERSION = '0.20';
$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__
MooseX::Singleton - turn your Moose class into a singleton
-=head1 VERSION
-
-Version 0.08, released 24 May 08
-
=head1 SYNOPSIS
package MyApp;
C<use MooseX::Singleton>. 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<MooseX::Singleton> gives your class an C<instance> method that can be used to get a handle on the singleton. It's actually just an alias for C<new>.
+C<MooseX::Singleton> gives your class an C<instance> method that can be used to
+get a handle on the singleton. It's actually just an alias for C<new>.
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