—## no critic: TestingAndDebugging::RequireStrict
our
$DATE
=
'2022-07-23'
;
# DATE
our
$VERSION
=
'0.043'
;
# VERSION
our
$rschema
=
do
{
my
$var
={
base
=>
"perl::modname"
,
clsets_after_base
=>[{
description
=>
"\nThis schema is based on the `perl::modname` schema with an additional check that\nthe perl module is installed locally. Checking is done using\n<pm:Module::Installed::Tiny>. This check fetches the source code of the module\nfrom filesystem or %INC hooks, but does not actually load/execute the code.\n\n"
,
examples
=>[],
prefilters
=>[
"Perl::check_module_installed"
],
summary
=>
"Name of a Perl module that is installed locally"
}],
clsets_after_type
=>[{
description
=>
"\nThis is a schema you can use when you want to accept a Perl module name. It\noffers basic checking of syntax as well as a couple of conveniences. First, it\noffers completion from list of locally installed Perl modules. Second, it\ncontains coercion rule so you can also input `Foo-Bar`, `Foo/Bar`, `Foo/Bar.pm`\nor even 'Foo.Bar' and it will be normalized into `Foo::Bar`.\n\nTo see this schema in action on the CLI, you can try e.g. the `pmless` script\nfrom <pm:App::PMUtils> and activate its tab completion (see its manpage for more\ndetails). Then on the CLI try typing:\n\n % pmless M/<tab>\n % pmless dzp/<tab>\n % pmless Module/List/Wildcard\n % pmless Module::List::Wildcard\n\nNote that this schema does not check that the Perl module exists or is installed\nlocally. To check that, use the `perl::modname::installed` schema. And there's\nalso a `perl::modname::not_installed` schema.\n\n"
,
examples
=>[{
valid
=>0,
value
=>
""
},{
valid
=>1,
value
=>
"Foo::Bar"
},{
valid
=>1,
validated_value
=>
"Foo::Bar"
,
value
=>
"Foo-Bar"
},{
valid
=>1,
validated_value
=>
"Foo::Bar"
,
value
=>
"Foo/Bar"
},{
valid
=>1,
validated_value
=>
"Foo::Bar"
,
value
=>
"Foo/Bar.pm"
},{
valid
=>1,
validated_value
=>
"Foo::Bar"
,
value
=>
"Foo.Bar"
},{
valid
=>0,
value
=>
"Foo|Bar"
}],
match
=>
"\\A(?:[A-Za-z_][A-Za-z_0-9]*(::[A-Za-z_0-9]+)*)\\z"
,
prefilters
=>[
"Perl::normalize_perl_modname"
],
summary
=>
"Perl module name, e.g. Foo::Bar"
,
"x.completion"
=>
"perl_modname"
},'
$var
->{clsets_after_base}[0]
'],"clsets_after_type.alt.merge.merged"=>['
$var
->{clsets_after_type}[0]
','
$var
->{clsets_after_base}[0]'],
resolve_path
=>[
"str"
,
"perl::modname"
],
type
=>
"str"
,
v
=>2};
$var
->{clsets_after_type}[1]=
$var
->{clsets_after_base}[0];
$var
->{
"clsets_after_type.alt.merge.merged"
}[0]=
$var
->{clsets_after_type}[0];
$var
->{
"clsets_after_type.alt.merge.merged"
}[1]=
$var
->{clsets_after_base}[0];
$var
};
1;
# ABSTRACT: Name of a Perl module that is installed locally
__END__
=pod
=encoding UTF-8
=head1 NAME
Sah::SchemaR::perl::modname::installed - Name of a Perl module that is installed locally
=head1 VERSION
This document describes version 0.043 of Sah::SchemaR::perl::modname::installed (from Perl distribution Sah-Schemas-Perl), released on 2022-07-23.
=head1 DESCRIPTION
This module is automatically generated by Dist::Zilla::Plugin::Sah::Schemas during distribution build.
A Sah::SchemaR::* module is useful if a client wants to quickly lookup the base type of a schema without having to do any extra resolving. With Sah::Schema::*, one might need to do several lookups if a schema is based on another schema, and so on. Compare for example L<Sah::Schema::poseven> vs L<Sah::SchemaR::poseven>, where in Sah::SchemaR::poseven one can immediately get that the base type is C<int>. Currently L<Perinci::Sub::Complete> uses Sah::SchemaR::* instead of Sah::Schema::* for reduced startup overhead when doing tab completion.
=head1 HOMEPAGE
Please visit the project's homepage at L<https://metacpan.org/release/Sah-Schemas-Perl>.
=head1 SOURCE
Source repository is at L<https://github.com/perlancar/perl-Sah-Schemas-Perl>.
=head1 AUTHOR
perlancar <perlancar@cpan.org>
=head1 CONTRIBUTING
To contribute, you can send patches by email/via RT, or send pull requests on
GitHub.
Most of the time, you don't need to build the distribution yourself. You can
simply modify the code, then test via:
% prove -l
If you want to build the distribution (e.g. to try to install it locally on your
system), you can install L<Dist::Zilla>,
L<Dist::Zilla::PluginBundle::Author::PERLANCAR>, and sometimes one or two other
Dist::Zilla plugin and/or Pod::Weaver::Plugin. Any additional steps required
beyond that are considered a bug and can be reported to me.
=head1 COPYRIGHT AND LICENSE
This software is copyright (c) 2022, 2021, 2020, 2019, 2018, 2017, 2016 by perlancar <perlancar@cpan.org>.
This is free software; you can redistribute it and/or modify it under
the same terms as the Perl 5 programming language system itself.
=head1 BUGS
Please report any bugs or feature requests on the bugtracker website L<https://rt.cpan.org/Public/Dist/Display.html?Name=Sah-Schemas-Perl>
When submitting a bug or request, please include a test-file or a
patch to an existing test-file that illustrates the bug or desired
feature.
=cut