NAME
DBIx::VersionedSubs::Hash - store subroutines in a simple hash
SYNOPSIS
package My::App;
use strict;
use base 'DBIx::VersionedSubs::Hash';
__PACKAGE__->{code} = {
say_hello => sub {print "Hello World"},
};
package main;
use strict;
my $app = My::App->new({code => {},dsn => $dsn );
while (my $request = Some::Server->get_request) {
$app->update_code(); # update code from the DB
$app->handle_request->($request);
}
ABSTRACT
This module overrides some methods in DBIx::VersionedSubs and replaces the normal namespace based code storage with simple storage in a hash. This is useful if you want multiple code versions in a mod_perl environment for example.
Package->new({ %ARGS })
Creates a new object and initializes it from the class default values as inherited from DBIx::VersionedSubs.
If you pass in a hashref to the code
key, all subroutines will be stored in it. You can also use this feature to pass in a package hash (like %My::App::
), then this module will be almost identical in usage to DBIx::VersionedSubs itself. The difference between the two is that subroutine names with characters outside of \w
will not create subroutines in other namespaces with this module.
$app->dispatch( FUNCTION, ARGS )
This is a shorthand method for
return $self->{code}->{$function}->(@ARGS);
except with error checking
AUTHOR
Max Maischein, <corion@cpan.org>
LICENSE
This module is licensed under the same terms as Perl itself.