Man page - minil(1)
Packages contains this manual
Manual
Minilla
NAMESYNOPSIS
DESCRIPTION
CONVENTION
GETTING STARTED
WHY MINILLA?
Repository managed by Minilla is git install ready.
Minilla is built on small libraries.
And, what is Minilla?
Minillaās release process
CheckUntrackedFiles
CheckOrigin
CheckReleaseBranch
BumpVersion
CheckChanges
RegenerateFiles
RunHooks
DistTest
MakeDist
UploadToCPAN
RewriteChanges
Commit
Tag
CONFIGURATION
FAQ
bash/zsh completion
AUTHORS
THANKS TO
SEE ALSO
LICENSE
NAME
Minilla - CPAN module authoring tool
SYNOPSIS
minil new -
Create a new dist
minil test - Run test cases
minil dist - Make your dist tarball
minil install - Install your dist
minil release - Release your dist to CPAN
minil run - Run arbitrary commands against build dir
DESCRIPTION
Minilla is a CPAN module authoring tool. Minilla provides minil command for authorizing a CPAN distribution.
(M::I - inc) + shipit + (dzil - plugins)
CONVENTION
As stated above,
Minilla is opinionated. Minilla has a bold assumption and
convention like the followings, which are almost compatible
to the sister project Dist::Milla.
Your modules are written in Pure Perl and are located in
lib/
.
Your executable files are in
script/
directory, if
any
Your module is maintained with
Git
, "git
ls-files" matches with what
you will release and your remote is named
origin
Your module has a static list of prerequisites that can be
described in
cpanfile
Your module has a Changes file
Your module requires at least perl 5.6.
GETTING STARTED
# First time
only
% cpanm --with-recommends Minilla
# Minilla has only a few deps. It should be very quick
# Make a new distribution
% minil new Dist-Name
% cd Dist-Name/
# Git commit
% git commit -m "initial commit"
# Hack your code!
% $EDITOR lib/Dist/Name.pm t/dist-name.t cpanfile
# Done? Test and release it!
% minil release
Itās that easy.
You already have distributions with Module::Install, Module::Build, Dist::Zilla or ShipIt? Migrating is also trivial. See "MIGRATING" in Minilla::Tutorial for more details.
WHY MINILLA?
Repository managed by Minilla is git install ready.
The repository created and managed by Minilla is git install ready. You can install the library by "cpanm git://...".
Of course, you can install Minilla from "cpanm git://github.com/tokuhirom/Minilla.git".
Minilla is built on small libraries.
Minilla is built on only few small libraries. You can install Minilla without a huge list of dependencies to heavy modules.
And, what is Minilla?
Minilla is a
Kaiju (Japanese giant monster) from the Godzilla series of
films and is the first of several young Godzillas.
https://en.wikipedia.org/wiki/Minilla
Minillaās release process
Minillaās release process is the following.
CheckUntrackedFiles
Checking gitās untracked files. If thereās untracked files, minilla will abort.
CheckOrigin
This step will run the āgit remoteā. If thereās no remote, minilla will abort.
CheckReleaseBranch
Checking gitās current branch is ārelease.branchā key in minil.toml. If no match, minilla will abort.
BumpVersion
Minilla will show āNext Release?ā prompt. You can input next version number.
After that, minilla rewrites version numbers in **/*.pm, **/*.pl, and a script file contains perl-ish shebang.
CheckChanges
You need to write Changes file. Your moduleās users need to know the difference between versions.
Minillaās Changes file includes ā{{$NEXT}}ā next version indicator. You should put update informations after that.
RegenerateFiles
In this step, minilla will regenerate META.json, README.md and (Makefile.PL|Build.PL).
RunHooks
This step runs commands listed on ārelease.hooksā key in minil.toml.
DistTest
This script runs test cases in clean working directory with "$ENV{RELEASE_TESTING} = 1".
MakeDist
Make distribution tar ball.
UploadToCPAN
Upload your module to CPAN.
RewriteChanges
Rewrite Changes file. Minilla replaces "{{$NEXT}}" with released version number and current date & time. And put "{{$NEXT}}" on the first line.
Commit
Commit current directory with automatically generated commit message from Changes file. And push it to origin.
Tag
Create new git tag and push it to origin.
CONFIGURATION
Minilla uses Convention over Configuration .
But, you can
write configurations to
minil.toml
file in TOML
<https://github.com/toml-lang/toml> format. Minilla
reads the
minil.toml
file in the root directory of
your project.
name
You can write ānameā instead of automatically detecting project name out of the directory name.
module_maker
Minilla supports three module building mechanisms. Module::Build::Tiny is the default one and Module::Build or ExtUtils::MakeMaker are the alternatives. See also FAQ section in this document.
module_maker="ModuleBuild"
readme_from
readme_from="lib/My/Foo.pod"
You can specify the file to generate the README.md. This is a main module path by default.
tag_format
tag_format="perl/%v"
format of the tag to apply. Defaults to %v. %v will replace with the distribution version.
abstract_from
abstract_from="lib/My/Foo.pod"
Grab abstract information from the file contains pod.
authors_from
authors_from="lib/My/Foo.pod"
Grab authors information from the file contains pod.
authority
authority = "cpan:TOKUHIROM"
Set x_authority attribute to META. See <https://jawnsy.wordpress.com/2011/02/20/what-is-x_authority/> for more details. Note that now PAUSE itself copies the permissions from the "main module" to any new modules entering the index for the first time, so you donāt need to set this attribute anymore.
allow_pureperl
allow_pureperl=1
A boolean indicating the module is still functional without its XS parts. When an XS module is build with "--pureperl_only", it will otherwise fail.
It affects to Module::Build 0.4005+ only.
no_github_issues
no_github_issues=true
Minilla sets bugtracker to github/GitLabās issue tracker by default. But if you want to use RT, you can set this variable.
no_index
[no_index]
directory=['t', 'xt', 'tools']
Minilla sets META.jsonās no_index as "directory => ['t', 'xt', 'inc', 'share', 'eg', 'examples', 'author', 'builder']" by default. But if you want to change them, you can set this section variable. If this section is set, specified variables are only used, in fact default settings are not merged.
c_source
c_source = ['src']
A directory which contains C source files that the rest of the build may depend on. Any ".c" files in the directory will be compiled to object files. The directory will be added to the search path during the compilation and linking phases of any C or XS files.
script_files
script_files = ['bin/foo', 'script/*']
Minilla sets install script files as "['script/*', 'bin/*']" by default.
(Note. This option doesnāt affect anything if you are using ModuleBuildTiny or ExtUtilsMakeMaker, for now. If you are using ModuleBuildTiny, you MUST put scripts in script/ directory.)
tap_harness_args(EXPERIMENTAL)
[tap_harness_args]
jobs=19
This parameters pass to TAP::Harness when running tests. See the TAP::Harness documentation for details.
license
license="artistic_2"
You can specify your favorite license on minil.toml. The license key is same as CPAN Meta spec 2.0. See CPAN::Meta::Spec.
badges
badges = ['travis-ci.com', 'travis-ci.org', 'circleci', 'appveyor', 'coveralls', 'codecov', 'gitter', 'metacpan', 'kritika', 'github-actions/$workflow_file', 'gitlab-pipeline', 'gitlab-coverage']
Embed badges image (e.g. Travis-CI) to README.md. It ought to be array and each elements must be service name. Now, supported services are ātravis-ci.comā, ātravis-ci.orgā, ācircleciā, āappveyorā, ācoverallsā, ācodecovā, āgitterā, āmetacpanā, ākritikaā āgithub-actionsā, āgitlab-pipelineā and āgitlab-coverageā.
You can send additional parameters as required by your CI provider by including a query string along with your service name: e.g. "travis?token=[YOUR_TOKEN_GOES_HERE]&branch=dev"
PL_files
Specify the PL files.
[PL_files]
lib/Foo/Bar.pm.PL="lib/Foo/Bar.pm"
This option is not supported by Minilla::ModuleMaker::ModuleBuildTiny.
Note. MBTiny executes *.PL files by default.
build.build_class
Specify a custom Module::Build subclass.
[build]
build_class = "builder::MyBuilder"
XSUtil.needs_compiler_c99
[XSUtil]
needs_compiler_c99 = 1
You can specify "needs_compiler_c99" parameter of Module::Build::XSUtil.
XSUtil.needs_compiler_cpp
[XSUtil]
needs_compiler_cpp = 1
You can specify "needs_compiler_cpp" parameter of Module::Build::XSUtil.
XSUtil.generate_ppport_h
[XSUtil]
generate_ppport_h = 1
You can specify "generate_ppport_h" parameter of Module::Build::XSUtil.
XSUtil.generate_xshelper_h
[XSUtil]
generate_xshelper_h = 1
You can specify "generate_xshelper_h" parameter of Module::Build::XSUtil.
XSUtil.cc_warnings
[XSUtil]
cc_warnings = 1
You can specify "cc_warnings" parameter of Module::Build::XSUtil.
FileGatherer.exclude_match
[FileGatherer]
exclude_match = ['Ėauthor_tools/.*']
Nothing by default. To exclude certain files from being gathered into dist, use the "exclude_match" option. Files matching the patterns are not gathered.
FileGatherer.include_dotfiles
[FileGatherer]
include_dotfiles = false
By default, files will not be included in dist if they begin with a dot. This goes both for files and for directories.
In almost all cases, the default value (false) is correct.
release.pause_config
[release]
pause_config = "/path/to/some/.pause"
By setting this value to another PAUSE configuration file (see "CONFIGURATION" in cpan-upload for the details), it is possible to use another PAUSE server (or anything good enough to mimick its upload process) for the release step.
To do so, simply add a "upload_uri" entry in your file to the alternate PAUSE server, i.e :
upload_uri http://127.0.0.1:5000/pause/authenquery
If you instantly launch your origin upload server as DarkPAN, See OrePAN2::Server.
release.do_not_upload_to_cpan
[release]
do_not_upload_to_cpan=true
This variable disables CPAN upload feature.
release.hooks
[release]
hooks = [
"COMMAND1",
"COMMAND2"
]
Commands that are specified by this option will be executed when releasing. If result of commands is not successful, it will abort.
release.branch
[release]
branch = "main"
If this value does not match the current branch, it will abort.
unsupported.os
[unsupported]
os = [
"MSWin32",
"darwin"
]
By setting this value to add unsupported OS checks for (Build.PL|Makefile.PL).
ReleaseTest.MinimumVersion
[ReleaseTest]
MinimumVersion = false
If you set this key false, Minilla will not generate āxt/minilla/minimum_version.tā.
requires_external_bin
requires_external_bin=['tar']
The "requires_external_bin" command takes the name of a system command or program. Build fail if the command does not exist.
markdown_maker
markdown_maker = "Pod::Markdown::Github"
Use a different module to generate "README.md" from your pod. This module must subclass Pod::Markdown.
markdown_maker_opts
[markdown_maker_opts]
local_module_re = "ĖMyApp::"
local_module_url_prefix =
"https://example.org/perl/pod/"
Specify arguments to pass to "markdown_maker"ās new() constructor.
Metadata
[Metadata]
x_deprecated = 1
Add arbitrary keys to "META.json"/"META.yml".
static_install
static_install = "auto"
If "static_install = "auto"" (or nothing is specified at all), then minil tries to detect whether distributions are ready for static install or not, and set "x_static_install" in META files accordingly. You can also set "static_install = 0/1" explicitly; then minil will respect it.
For static install itself, please refer to <https://github.com/Perl-Toolchain-Gang/cpan-static>.
FAQ
How can I manage contributors section?
Minilla aggregates contributors list from "git log --format="%aN <%aE>" | sort | uniq".
You can merge accounts by .mailmap file. See <https://www.kernel.org/pub/software/scm/git/docs/git-shortlog.html>
Why donāt you provide plug-in support?
If you want a pluggable tool, it already exists: Itās called Dist::Zilla :P If you like Minillaās behavior but you really want something pluggable, you can use Dist::Milla, Minillaās sister project. Dist::Millaās behavior is almost identical to that of Minilla.
Why does minil only support git?
I think git is a best VC for CPAN modules, for now.
If you want to use another version control system, you can probably use Dist::Milla.
And why...
Yes. You can use Dist::Milla.
Should I add (META.json|Build.PL) to repository?
Yes. You need to add it to make your git repo installable via cpanm.
How do I manage ppport.h?
Is there a reason to remove ppport.h from repo?
How can I install script files?
Your executables must be in script/ directory.
How to switch from Module::Install/Module::Build/Dist::Zilla?
You can use experimental āminil migrateā sub-command. See Minilla::CLI::Migrate for more details.
How should I manage the files you do not want to upload to CPAN?
Please use FileGatherer.exclude_match for ignoring files to upload tar ball.
You can use MANIFEST.SKIP file for ignoring files. ref. ExtUtils::Manifest.
How do I use Module::Build::Tiny with Minilla?
Minilla supports Module::Build::Tiny and uses it as a default installer since v1.0.0.
If you want to migrate an existing project created before Minilla v1.0, you need to rewrite "minil.toml" file. You need to add the following line:
module_maker="ModuleBuildTiny"
How do I use Module::Build with Minilla?
If you want to create new project with Module::Build, run the command as following.
% minil new -p ModuleBuild My::Awesome::Module
How do I use ExtUtils::MakeMaker with Minilla?
Minilla v2.1.0+ supports EUMM(EXPERIMENTAL).
You need to rewrite minil.toml file and add the following line:
module_maker="ExtUtilsMakeMaker"
(There is no profile, yet. Patches welcome.)
I donāt suggest to use this module... But you can use this option for maintaining primitive modules like Test::TCP.
Ho do I support Perl 5.6?
EUMM can run on Perl 5.6. Write following statement in your minil.toml file.
module_maker="ExtUtilsMakeMaker"
bash/zsh completion
Minilla provides bash and zsh completion files under "contrib/" directory.
AUTHORS
Tokuhiro Matsuno < tokuhirom@gmail.com >
Tatsuhiko Miyagawa
THANKS TO
RJBS, the author of Dist::Zilla. Dist::Zilla points CPAN authorizing tool.
SEE ALSO
LICENSE
Copyright (C) Tokuhiro Matsuno
This library is free software; you can redistribute it and/or modify it under the same terms as Perl itself.