NAME Class::InsideOut - a safe, simple inside-out object construction kit SYNOPSIS package My::Class; use Class::InsideOut qw( property register id ); use Scalar::Util qw( refaddr ); # declare a lexical property hash with 'my' property my %name; sub new { my $class = shift; my $self = \do {my $scalar}; bless $self, $class; # register the object for thread-safety register( $self ); } sub name { my $self = shift; if ( @_ ) { # use 'refaddr' to access properties for an object $name{ refaddr $self } = shift; return $self; } return $name{ refaddr $self }; } sub greeting { my $self = shift; # use 'id' as a mnemonic alias for 'refaddr' return "Hello, my name is " . $name { id $self }; } DESCRIPTION This is an alpha release for a work in progress. It is a functional but incomplete implementation of a simple, safe and streamlined toolkit for building inside-out objects. Unlike most other inside-out object building modules already on CPAN, this module aims for minimalism and robustness. It uses no source filters, no attributes or CHECK blocks, supports any underlying object type including foreign inheritance, does not leak memory, is overloading-safe, is thread-safe for Perl 5.8 or better and should be mod_perl compatible. In its current state, it provides the minimal support necessary for safe inside-out objects. All other implementation details, including writing a constructor and accessors, are left to the user. Future versions will add basic accessor support and serialization support. Inside-out object basics To be written. USAGE Importing `Class::InsideOut' To be written. Declaring and accessing object properties To be written. Object destruction To be written. Foreign inheritance To be written. Serialization To be written. Thread-safety To be written. FUNCTIONS `property' property my %name; Declares an inside-out property. The argument must be a lexical hash, though the `my' keyword can be included as part of the argument rather than as a separate statement. No accessor is created, but the property will be tracked for memory cleanup during object destruction and for proper thread-safety. `register' register $object; Registers an object for thread-safety. This should be called as part of a constructor on a object blessed into the current package. Returns the object (without modification). `id' $name{ id $object } = "Larry"; This is a shorter, mnemonic alias for `Scalar::Util::refaddr'. It returns the memory address of an object (just like `refaddr') as the index to access the properties of an inside-out object. `CLONE' `CLONE' is automatically exported to provide thread-safety to modules using `Class::InsideOut'. See perlmod for details. It will be called automatically by Perl if threads are in use and a new interpreter thread is created. It should never be called directly. `DESTROY' This destructor is automatically exported to modules using `Class::InsideOut' to clean up object property memory usage during object destruction. It should never be called directly. `DESTROY' will call a user-supplied `DEMOLISH' method if one exists to allow for additional, custom destruction actions such as closing sockets or database handles. `DEMOLISH' is called prior to deleting object properties. SEE ALSO * Object::InsideOut -- Currently the most full-featured, robust implementation of inside-out objects, but foreign inheritance is handled via delegation. Highly recommended if a more full-featured inside-out object builder is needed. Array-based mode is faster than hash-based implementations. * Class::Std -- Despite the name, does not reflect best practices for inside-out objects. Does not provide thread-safety with CLONE, is not mod_perl safe and doesn't support foreign inheritance. * Class::BuildMethods -- Generates accessors with encapsulated storage using a flyweight inside-out variant. Lexicals properties are hidden; accessors must be used everywhere. Not thread-safe. * Lexical::Attributes -- The original inside-out implementation, but missing some key features like thread-safety. Also, uses source filters to provide Perl-6-like object syntax. * Class::MakeMethods::Templates::InsideOut -- Not a very robust implementation. Not thread-safe. Not overloading-safe. Has a steep learning curve for the Class::MakeMethods system. * Object::LocalVars -- My own original thought experiment with 'outside-in' objects and local variable aliasing. Not production-safe and offers very weak encapsulation. BUGS Please report bugs using the CPAN Request Tracker at http://rt.cpan.org/NoAuth/Bugs.html?Dist=Class-InsideOut When submitting a bug or request, please include a test-file or a patch to an existing test-file that illustrates the bug or desired feature. AUTHOR David A. Golden (DAGOLDEN) dagolden@cpan.org http://dagolden.com/ COPYRIGHT Copyright (c) 2006 by David A. Golden This program is free software; you can redistribute it and/or modify it under the same terms as Perl itself. The full text of the license can be found in the LICENSE file included with this module.