#!perl

use 5.010;
use strict;
use warnings;

use App::PMUtils;
use Perinci::CmdLine::Any -prefer_lite=>1;
use SHARYANTO::Module::Path;

our $VERSION = '0.21'; # VERSION
our $DATE = '2014-08-17'; # DATE

our %SPEC;
$SPEC{podpath} = {
    v => 1.1,
    summary => 'Get path to locally installed POD',
    args => {
        pod => {
            schema => ['array*', of=>'str*', min_len=>1],
            req    => 1,
            pos    => 0,
            greedy => 1,
            element_completion => $App::PMUtils::_complete_pod,
        },
        all => {
            schema => 'bool',
            cmdline_aliases => {a=>{}},
        },
        abs => {
            schema => 'bool',
            cmdline_aliases => {P=>{}},
        },
    },
    "x.perinci.cmdline.default_format" => 'text-simple',
};
sub podpath {
    require SHARYANTO::Module::Path;
    my %args = @_;

    my $pods = $args{pod};
    my $res = [];
    my $found;

    for my $pod (@{$pods}) {
        my $mpath = SHARYANTO::Module::Path::module_path(
            module=>$pod, find_pmc=>0, find_pm=>0, find_pod=>1, find_prefix=>0,
            abs=>$args{abs}, all=>$args{all});
        $found++ if $mpath;
        push @$res, @$pods > 1 ? {pod=>$pod, path=>$mpath} : $mpath;
    }

    if ($found) {
        [200, "OK", $res];
    } else {
        [404, "No such POD"];
    }
}

Perinci::CmdLine::Any->new(
    url => '/main/podpath',
)->run;

# ABSTRACT: Get path to locally installed POD
# PODNAME: podpath

__END__

=pod

=encoding UTF-8

=head1 NAME

podpath - Get path to locally installed POD

=head1 VERSION

This document describes version 0.21 of podpath (from Perl distribution App-PMUtils), released on 2014-08-17.

=head1 SYNOPSIS

Basic usage:

 % podpath PSGI

To active bash completion:

 % complete -C podpath podpath; # can be put in bash startup file e.g. .bashrc
 % podpath PSG<tab>
 % pmcost moose/cookbook/st<tab> ; # resolve to Moose/Cookbook/Style, can resolve case
 % pmcost "Moose::Man<tab>       ; # use quote (' or ") if you want to use :: as separator

=head1 HOMEPAGE

Please visit the project's homepage at L<https://metacpan.org/release/App-PMUtils>.

=head1 SOURCE

Source repository is at L<https://github.com/sharyanto/perl-App-PMUtils>.

=head1 BUGS

Please report any bugs or feature requests on the bugtracker website L<https://rt.cpan.org/Public/Dist/Display.html?Name=App-PMUtils>

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.

=head1 AUTHOR

Steven Haryanto <stevenharyanto@gmail.com>

=head1 COPYRIGHT AND LICENSE

This software is copyright (c) 2014 by Steven Haryanto.

This is free software; you can redistribute it and/or modify it under
the same terms as the Perl 5 programming language system itself.

=cut
