File Coverage

blib/lib/Data/Sah/Coerce/perl/To_str/From_str/convert_perl_pod_or_pm_to_path.pm
Criterion Covered Total %
statement 16 16 100.0
branch n/a
condition 1 2 50.0
subroutine 5 5 100.0
pod 0 2 0.0
total 22 25 88.0


line stmt bran cond sub pod time code
1             package Data::Sah::Coerce::perl::To_str::From_str::convert_perl_pod_or_pm_to_path;
2              
3 1     1   7715 use 5.010001;
  1         4  
4 1     1   6 use strict;
  1         2  
  1         20  
5 1     1   5 use warnings;
  1         3  
  1         252  
6              
7             our $AUTHORITY = 'cpan:PERLANCAR'; # AUTHORITY
8             our $DATE = '2022-12-16'; # DATE
9             our $DIST = 'Sah-Schemas-Perl'; # DIST
10             our $VERSION = '0.046'; # VERSION
11              
12             sub meta {
13             +{
14 1     1 0 13 v => 4,
15             summary => 'Convert POD/module name existing in @INC to its filesystem path',
16             prio => 50,
17             };
18             }
19              
20             sub coerce {
21 1     1 0 19 my %args = @_;
22              
23 1         3 my $dt = $args{data_term};
24              
25 1         2 my $res = {};
26              
27 1   50     10 $res->{modules}{'Module::Path::More'} //= {version=>0, core=>0, pp=>1};
28 1         2 $res->{expr_match} = "1";
29 1         5 $res->{expr_coerce} = join(
30             "",
31             "do { ",
32             "my \$_sahc_orig = $dt; ",
33             "if (\$_sahc_orig =~ m!\\A\\w+((?:/|::)\\w+)*(?:\\.pm|\\.pod)?\\z!) {",
34             " (my \$tmp = \$_sahc_orig) =~ s!/!::!g; my \$ext; \$tmp =~ s/\\.(pm|pod)\\z// and \$ext = \$1;",
35             " Module::Path::More::module_path(module=>\$tmp, find_pm=>!\$ext || \$ext eq 'pm' ? 2:0, find_pod=>!\$ext || \$ext eq 'pod' ? 1:0, find_prefix=>0, find_pmc=>0) || \$_sahc_orig ",
36             "} else {",
37             " \$_sahc_orig ",
38             "} ",
39             "}",
40             );
41              
42 1         5 $res;
43             }
44              
45             1;
46             # ABSTRACT:
47              
48             __END__
49              
50             =pod
51              
52             =encoding UTF-8
53              
54             =head1 NAME
55              
56             Data::Sah::Coerce::perl::To_str::From_str::convert_perl_pod_or_pm_to_path
57              
58             =head1 VERSION
59              
60             This document describes version 0.046 of Data::Sah::Coerce::perl::To_str::From_str::convert_perl_pod_or_pm_to_path (from Perl distribution Sah-Schemas-Perl), released on 2022-12-16.
61              
62             =head1 DESCRIPTION
63              
64             This rule can convert strings in the form of:
65              
66             Foo::Bar
67             Foo/Bar
68             Foo/Bar.pod
69             Foo/Bar.pm
70              
71             into the filesystem path (e.g.
72             C</home/ujang/perl5/perlbrew/perls/perl-5.24.0/lib/site_perl/5.24.0/Foo/Bar.pm>)
73             when the POD or module exists in C<@INC>. Otherwise, it leaves the string as-is.
74              
75             This rule is the same as
76             L<Data::Sah::Coerce::perl::To_str::From_str::convert_perl_pm_or_pod_to_path> except that
77             .pod is prioritized over .pm. If C<Foo.pm> and C<Foo.pod> are both found on the
78             filesystem, C<Foo.pod> will be returned.
79              
80             =for Pod::Coverage ^(meta|coerce)$
81              
82             =head1 HOMEPAGE
83              
84             Please visit the project's homepage at L<https://metacpan.org/release/Sah-Schemas-Perl>.
85              
86             =head1 SOURCE
87              
88             Source repository is at L<https://github.com/perlancar/perl-Sah-Schemas-Perl>.
89              
90             =head1 AUTHOR
91              
92             perlancar <perlancar@cpan.org>
93              
94             =head1 CONTRIBUTING
95              
96              
97             To contribute, you can send patches by email/via RT, or send pull requests on
98             GitHub.
99              
100             Most of the time, you don't need to build the distribution yourself. You can
101             simply modify the code, then test via:
102              
103             % prove -l
104              
105             If you want to build the distribution (e.g. to try to install it locally on your
106             system), you can install L<Dist::Zilla>,
107             L<Dist::Zilla::PluginBundle::Author::PERLANCAR>,
108             L<Pod::Weaver::PluginBundle::Author::PERLANCAR>, and sometimes one or two other
109             Dist::Zilla- and/or Pod::Weaver plugins. Any additional steps required beyond
110             that are considered a bug and can be reported to me.
111              
112             =head1 COPYRIGHT AND LICENSE
113              
114             This software is copyright (c) 2022, 2021, 2020, 2019, 2018, 2017, 2016 by perlancar <perlancar@cpan.org>.
115              
116             This is free software; you can redistribute it and/or modify it under
117             the same terms as the Perl 5 programming language system itself.
118              
119             =head1 BUGS
120              
121             Please report any bugs or feature requests on the bugtracker website L<https://rt.cpan.org/Public/Dist/Display.html?Name=Sah-Schemas-Perl>
122              
123             When submitting a bug or request, please include a test-file or a
124             patch to an existing test-file that illustrates the bug or desired
125             feature.
126              
127             =cut