NAME

POE::Thing - A POE abstraction layer for conciseness and simplicity

DESCRIPTION

POE is a very powerful and flexible system for doing asynchronous programming.

But personally, I find it confusing and tricky to use at times.

It is flexible to the point of having too much choice, has a terminology that is sometimes confusing, a tendency towards very verbose programming, and POE components aren't as easy to reuse as I would like.

To be fair, a lot of these issues are done for the sake of speed, dependency minimisation and Perl version compatibility, but sometimes speed doesn't matter so much, you can be sure of a modern Perl version, and you are more interested in expressiveness and development time.

POE::Thing is an abstraction layer implemented on a number of principles.

Object Orientation is Worth It

Although POE emphasises speed, for general usage the additional development time and flexibility gained by using OO methods is worth it for most general uses.

The Use of Modern Techniques

Techniques such as subroutines attributes can be used to make POE development much more declarative and expressive.

These techniques, and other setup-time abstractions, can also allow us to check the configuration of the objects and catch user mistakes early, reducing the number of bugs, and reducing the total code size.

Early Checking

POE can be somewhat confusing about what it does or does not allow.

It is perfectly happy to let you spell an event name incorrectly, and yet will not allow you to load POE but not run a kernel (it throws a warning instead).

Where possible, POE::Thing adds additional checking at compile time, and at constructor time (before the POE kernel is started) to catch any mistakes you make.

Conciseness

Using POE can lead to duplication, particular for cases like having to specify all your event name to subroutine bindings seperately.

As part of the simplification, POE::Thing tries to reduce the amount of typing you need to do to interact with POE directly. Ideally, you should never have to touch POE directly, and most of the nitty gritty will be hidden away.

METHODS

_start

The default _start implementation is used to register the alias for the heap object with the kernel. As such, if you need to do your own tasks in _start you should always call it first.

sub _start {
    my $self = $_[HEAP];
    shift()->SUPER::_start(@_);

    # Additional tasks here
    ...
}

Please note though that the super call will break @_ in the current subroutine, and so you should not use $_[KERNEL] style expressions after the SUPER call.

_stop

The default _stop implementation is used to clean up our resources and aliases in the kernel. As such, if you need to do your own tasks in _stop you should always do them first and then call the SUPER last.

sub _stop {
    my $self = $_[HEAP];

    # Additional tasks here
    ...

    shift()->SUPER::_stop(@_);
}

ID

The ID is a wrapper for the equivalent POE::Session method, and returns the id number for the POE::Session.

Returns an integer, or undef if the heap object has not spawned.

postback

my $handler = $object->postback( 'event_name', $first_param, 'second_param' );
$handler->( $third_param, $first_param );

The postback method is a wrapper for the equivalent POE::Session method, and creates an anonymous subroutine that triggers a post for a named event of the heap object.

Returns a CODE reference, or dies if the heap object has not been spawned.

callback

my $handler = $object->callback( 'event_name', $first_param, 'second_param' );
$handler->( $third_param, $first_param );

The callback method is a wrapper for the equivalent POE::Session method, and creates an anonymous subroutine that triggers a post for a named event of the heap object.

Please don't confuse this for a method relating to "callback events" mentioned earlier, it is not related to them.

Returns a CODE reference, or dies if the heap object has not been spawned.

lookback

sub create_foo {
    my $self  = shift;
    my $thing = Other::Class->new(
         ConnectEvent => $self->lookback('it_connected'),
         ConnectError => $self->lookback('it_failed'),
         );

    ...
}

The lookback method is a safe alias for [ $self-Alias, 'event_name' ] >.

When creating the lookback, the name will be double checked to verify that the handler actually exists and is registered.

Returns a reference to an ARRAY containing the heap object's alias and the event name.

post

The post method runs a POE kernel post for a named event for the heap object's session.

Returns void.

call

The call method runs a POE kernel call for a named event for the heap object's session.

Returns as for the particular event handler, but generally returns void.

alarm_set

The alarm_set method is equivalent to the POE::Kernel method of the same name, setting an alarm for a named event of the heap object's session.

alarm_adjust

The alarm_adjust method is equivalent to the POE::Kernel method of the same name, adjusting an alarm for a named event of the heap object's session.

alarm_remove

The alarm_remove method is equivalent to the POE::Kernel method of the same name, removing an alarm for a named event of the heap object's session.

alarm_clear

The alarm_clear method is a convenience method. It takes the name of a hash key for the object, containing a timer id. If the ID is set, it is cleared. If not, the method shortcuts.

delay_set

The delay_set method is equivalent to the POE::Kernel method of the same name, setting a delayed alarm for a named event of the heap object's session.

delay_adjust

The delay_adjust method is equivalent to the POE::Kernel method of the same name, adjusting a delayed alarm for a named event of the heap object's session.

set_message

The set_message method is used to set or change a callback event registration after the initial creation of the object.

SUPPORT

Bugs should be always be reported via the CPAN bug tracker at

http://rt.cpan.org/NoAuth/ReportBug.html?Queue=POE-Declare

For other issues, or commercial enhancement or support, contact the author.

AUTHORS

Adam Kennedy <adamk@cpan.org<

SEE ALSO

POE, http://ali.as/

COPYRIGHT

Copyright 2006 Adam Kennedy.

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.