NAME Module::Install::RTx - RT extension installer SYNOPSIS In the Makefile.PL of the "RT-Extension-Foo" module: use inc::Module::Install; RTx 'RT-Extension-Foo'; WriteAll(); optionally add a requires_rt('3.8.9'); to die if your RT version is too old during install DESCRIPTION This Module::Install extension implements a function, "RTx", that takes the extension name as the only argument. It arranges for certain subdirectories to install into the installed RT location, but does not affect the usual "lib" and "t" directories. The directory mapping table is as below: ./bin => $RT::LocalPath/bin ./etc => $RT::LocalPath/etc/$NAME ./html => $RT::MasonComponentRoot ./po => $RT::LocalLexiconPath/$NAME ./sbin => $RT::LocalPath/sbin ./var => $RT::VarPath/$NAME Under the default RT3 layout in /opt and with the extension name "Foo", it becomes: ./bin => /opt/rt3/local/bin ./etc => /opt/rt3/local/etc/Foo ./html => /opt/rt3/share/html ./po => /opt/rt3/local/po/Foo ./sbin => /opt/rt3/local/sbin ./var => /opt/rt3/var/Foo By default, all these subdirectories will be installed with "make install". you can override this by setting the "WITH_SUBDIRS" environment variable to a comma-delimited subdirectory list, such as "html,sbin". Alternatively, you can also specify the list as a command-line option to "Makefile.PL", like this: perl Makefile.PL WITH_SUBDIRS=sbin This module also provides the following helper functions requires_rt Takes one argument, a valid RT version. If an attempt is made to install on an older RT, it will die before Makefile creation. rt_too_new Takes an RT version and prevents this module from being installed on any version of RT equal to or newer than that. Useful if a particular release of an extension only works on 4.0.x but not 4.2.x. Takes an optional second argument which allows you to specify a custom error message. This message is passed to sprintf with two string arguments, the current RT version and the version you specify. CAVEATS * Use full name when call RTx method in Makefile.PL, some magic has been implemented in this installer to support RTx('Foo') for 'RTx-Foo' extension, but life proved that it's bad idea. Code still there for backwards compatibility. It will be deleted eventually. * installer won't work with RT 3.8.0, as it has some bugs new plugins sub-system. * layout of files has been changed between RT 3.6 and RT 3.8, old files may influence behaviour of your extension. Recommend people use clean dir on upgrade or guide how to remove old versions of your extension. ENVIRONMENT RTHOME Path to the RT installation that contains a valid lib/RT.pm. SEE ALSO Module::Install <http://www.bestpractical.com/rt/> AUTHORS Best Practical Solutions (Originally) Audrey Tang <cpan@audreyt.org> COPYRIGHT Copyright 2003, 2004, 2007 by Audrey Tang <cpan@audreyt.org>. Copyright 2008-2014 Best Practical Solutions This software is released under the MIT license cited below. The "MIT" License Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions: The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.