# NAME Dist::Zilla::Plugin::Conflicts - Declare conflicts for your distro # VERSION version 0.20 # SYNOPSIS In your `dist.ini`: [Conflicts] Foo::Bar = 0.05 Thing = 2 # DESCRIPTION This module lets you declare conflicts on other modules (usually dependencies of your module) in your `dist.ini`. Declaring conflicts does several thing to your distro. First, it generates a module named something like `Your::Distro::Conflicts`. This module will use [Dist::CheckConflicts](https://metacpan.org/pod/Dist%3A%3ACheckConflicts) to declare and check conflicts. The package name will be obscured from PAUSE by putting a newline after the `package` keyword. All of your runtime prereqs will be passed in the `-also` parameter to [Dist::CheckConflicts](https://metacpan.org/pod/Dist%3A%3ACheckConflicts). Second, it adds code to your `Makefile.PL` or `Build.PL` to load the generated module and print warnings if conflicts are detected. Finally, it adds the conflicts to the `META.json` and/or `META.yml` files under the "x\_breaks" key. # USAGE Using this module is simple, add a "\[Conflicts\]" section and list each module you conflict with: [Conflicts] Module::X = 0.02 The version listed is the last version that _doesn't_ work. In other words, any version of `Module::X` greater than 0.02 should work with this release. The special key `-script` can also be set, and given the name of a script to generate, as in: [Conflicts] -script = bin/foo-conflicts Module::X = 0.02 This script will be installed with your module, and can be run to check for currently installed modules which conflict with your module. This allows users an easy way to fix their conflicts - simply run a command such as `foo-conflicts | cpanm` to bring all of your conflicting modules up to date. **Note:** Currently, this plugin only works properly if it is listed in your `dist.ini` _after_ the plugin which generates your `Makefile.PL` or `Build.PL`. This is a limitation of [Dist::Zilla](https://metacpan.org/pod/Dist%3A%3AZilla) that will hopefully be addressed in a future release. # SEE ALSO - [Dist::CheckConflicts](https://metacpan.org/pod/Dist%3A%3ACheckConflicts) - [Dist::Zilla::Plugin::Breaks](https://metacpan.org/pod/Dist%3A%3AZilla%3A%3APlugin%3A%3ABreaks) - [Dist::Zilla::Plugin::Test::CheckBreaks](https://metacpan.org/pod/Dist%3A%3AZilla%3A%3APlugin%3A%3ATest%3A%3ACheckBreaks) # SUPPORT Please report any bugs or feature requests to `bug-dist-zilla-plugin-conflicts@rt.cpan.org`, or through the web interface at [http://rt.cpan.org](http://rt.cpan.org). I will be notified, and then you'll automatically be notified of progress on your bug as I make changes. Bugs may be submitted at [https://github.com/moose/Dist-Zilla-Plugin-Conflicts/issues](https://github.com/moose/Dist-Zilla-Plugin-Conflicts/issues). # SOURCE The source code repository for Dist-Zilla-Plugin-Conflicts can be found at [https://github.com/moose/Dist-Zilla-Plugin-Conflicts](https://github.com/moose/Dist-Zilla-Plugin-Conflicts). # DONATIONS If you'd like to thank me for the work I've done on this module, please consider making a "donation" to me via PayPal. I spend a lot of free time creating free software, and would appreciate any support you'd care to offer. Please note that **I am not suggesting that you must do this** in order for me to continue working on this particular software. I will continue to do so, inasmuch as I have in the past, for as long as it interests me. Similarly, a donation made in this way will probably not make me work on this software much more, unless I get so many donations that I can consider working on free software full time (let's all have a chuckle at that together). To donate, log into PayPal and send money to autarch@urth.org, or use the button at [https://houseabsolute.com/foss-donations/](https://houseabsolute.com/foss-donations/). # AUTHOR Dave Rolsky <autarch@urth.org> # CONTRIBUTORS - Karen Etheridge <ether@cpan.org> - Philippe Bruhat (BooK) <book@cpan.org> # COPYRIGHT AND LICENSE This software is Copyright (c) 2023 by Dave Rolsky. This is free software, licensed under: The Artistic License 2.0 (GPL Compatible) The full text of the license can be found in the `LICENSE` file included with this distribution.