Dist::Zilla::Plugin::Beam::Connector This module aims to allow "Dist::Zilla" to use plugins using "Beam::Event" and "Beam::Emitter", and perhaps reduce the need for massive amounts of composition and role application proliferating "CPAN". This is in lieu of a decent dependency injection system, and is presently relying on "Dist::Zilla" to load and construct the plugins itself, and then you just connect the plugins together informally, without necessitating each plugin be specifically tailored to the recipient. Hopefully, this may also give scope for non-"dzil" plugins being loadable into memory some day, and allowing message passing of events to those plugins. ( Hence, the "plugin:" prefix ) A Real World Example of what a future could look like? [GatherDir] [Test::Compile] [Beam::Connector] on = plugin:GatherDir#collect => plugin:Test::Compile#generate_test "GatherDir" in this example would build a mutable tree of files, attach them to an event "::GatherDir::Tree", and pass that event to "Test::Compile#generate_test", which would then add ( or remove, or mutate ) any files in that tree. Tree state mutation then happens in order of prescription, in the order given by the various "on" declarations. Thus, a single plugin can be in 2 places in the same logical stage. [Beam::Connector] on = plugin:GatherDir#collect => plugin:Test::Compile#generate_test ; lots more collectors here on = plugin:GatherDir#collect => plugin:Test::Compile#finalize_test Whereas presently, order of affect is either governed by: * phase - where you can add but not remove or mutate, mutate but not add or remove, remove, but not add or mutate * plugin order - where a single plugin cant be both early in a single phase and late If that example is not convincing enough for you, consider all the different ways there are presently for implementing "[MakeMaker]". If you're following the standard logic its fine, but as soon as you set out of the box, you have a few things you're going to have to do instead: * Subclass "MakeMaker" in some way * Re-implement "MakeMaker" in some way * Fuss a lot with phase ordering and then inject code in the "File" that "MakeMaker" generates. These approaches all work, but they're an open door to everyone re-implementing the same thing thousands of times over. [MakeMaker] [DynamicPrereqs] -phases = none [Beam::Connector] on = plugin:MakeMaker#collect_augments => plugin:DynamicPrereqs#inject_augments "MakeMaker" here can just create an "event", pass it to "DynamicPrereqs", "DynamicPrereqs" can inject its desired content into the "event", and then "MakeMaker" can integrate the injected events at "wherever" the right place for them is. This is much superior to scraping the generated text file and injecting events at a given place based on a "RegEx" match. INSTALLATION This is a Perl module distribution. It should be installed with whichever tool you use to manage your installation of Perl, e.g. any of cpanm . cpan . cpanp -i . Consult http://www.cpan.org/modules/INSTALL.html for further instruction. Should you wish to install this module manually, the procedure is perl Makefile.PL make make test make install COPYRIGHT AND LICENSE This software is copyright (c) 2017 by Kent Fredric . This is free software; you can redistribute it and/or modify it under the same terms as the Perl 5 programming language system itself.