NAME
    MooseX::Singleton - turn your Moose class into a singleton

VERSION
    Version 0.16

SYNOPSIS
        package MyApp;
        use MooseX::Singleton;

        has env => (
            is      => 'rw',
            isa     => 'HashRef[Str]',
            default => sub { \%ENV },
        );

        package main;

        delete MyApp->env->{PATH};
        my $instance = MyApp->instance;
        my $same = MyApp->instance;

DESCRIPTION
    A singleton is a class that has only one instance in an application.
    "MooseX::Singleton" lets you easily upgrade (or downgrade, as it were)
    your Moose class to a singleton.

    All you should need to do to transform your class is to change "use
    Moose" to "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.

    "MooseX::Singleton" gives your class an "instance" method that can be
    used to get a handle on the singleton. It's actually just an alias for
    "new".

    Alternatively, "YourPackage->method" should just work. This includes
    accessors.

TODO
    Always more tests and doc
    Fix speed boost
        "instance" invokes "new" every time "Package->method" is called,
        which incurs a nontrivial runtime cost. I've implemented a
        short-circuit for this case, which does eliminate nearly all of the
        runtime cost. However, it's ugly and should be fixed in a more
        elegant way.

BUGS
    All complex software has bugs lurking in it, and this module is no
    exception. If you find a bug please either email me, or add the bug to
    cpan-RT.

AUTHOR
    Shawn M Moore <sartak@gmail.com>

SOME CODE STOLEN FROM
    Anders Nor Berle <debolaz@gmail.com>

AND PATCHES FROM
    Ricardo SIGNES <rjbs@cpan.org>

    Dave Rolsky <autarch@urth.org>

COPYRIGHT AND LICENSE
    Copyright 2007, 2008 Shawn M Moore.

    This program is free software; you can redistribute it and/or modify it
    under the same terms as Perl itself.