NAME

Module::Notify - trigger a callback when a module is loaded

SYNOPSIS

use Module::Notify;

Module::Notify->new(Foo => sub { print "2\n" });

# Count to three...
print "1\n";
require Foo;
print "3\n";

DESCRIPTION

Module::Notify runs callback code when it detects that a particular module has been loaded.

Constructor

new($module_name, $callback)

Runs the callback when the module is loaded.

Unlike most OO modules, you can freely use this in void context, and it will work fine. However, if you keep the returned reference, you can call methods on it:

my $handle = Module::Notify->new($module, $callback);

If the module is already loaded, runs the callback immediately, and returns undef instead of an object.

Object Methods

cancel

Cancels the callback.

CAVEATS

Module::Notify works through an @INC hook. It ought to be the first item in @INC and does its best to insert itself as $INC[0] at every opportunity it gets.

If any other path or hook does end up before Module::Notify's @INC hook, then any modules loaded via that path or hook will escape Module::Notify's notice.

BUGS

Please report any bugs to http://rt.cpan.org/Dist/Display.html?Queue=Module-Notify.

SEE ALSO

Module::Runtime.

AUTHOR

Toby Inkster <tobyink@cpan.org>.

COPYRIGHT AND LICENCE

This software is copyright (c) 2013 by Toby Inkster.

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

DISCLAIMER OF WARRANTIES

THIS PACKAGE IS PROVIDED "AS IS" AND WITHOUT ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, WITHOUT LIMITATION, THE IMPLIED WARRANTIES OF MERCHANTIBILITY AND FITNESS FOR A PARTICULAR PURPOSE.