NAME

Sub::Spec::Clause::args - Schema for subroutine parameters

VERSION

version 0.03

SYNOPSIS

NOT IMPLEMENTED YET.

In your spec:

args => {
  # ARG_NAME => SCHEMA
  num => ['int*' => {arg_order=>0, min=>0, divisible_by=>2}],
  ...
},
required_args => [qw/num/],

In your caller:

use Sub::Spec;
use MyModule qw(mysub);

my $res;
$res = mysub();        # error 400: missing argument num
$res = mysub(num=>-1); # error 400: number must be >= 0

DESCRIPTION

args defines schema for each known argument. Schema language is Data::Sah.

required_args lists which argument is available. In most cases you do not need this spec clause, except when you want to allow an argument value to be undef, but you want to require that it is specified:

func(arg => undef); # arg is specified, but value is undef, OK.
func();             # arg is not specified, ERROR

In that case, your spec will be something like this:

args          => { arg => 'any' }, # arg value is not required
required_args => [qw/arg/],

ARGUMENT CLAUSES

Since each argument is a Sah schema, all Sah type clauses are allowed. But there are several type clauses added specific to arguments:

arg_order => INT, 0+

Specify the order of argument when specified in a positional order. Utilized by Sub::Spec::Exporter and Sub::Spec::CmdLine to parse positional arguments. Example:

$SPEC{multiply2} = {
    summary => 'Multiple two numbers (a & b)',
    args    => {
        a      => ['num*' => {arg_order=>0}],
        b      => ['num*' => {arg_order=>1}],
        digits => 'int',
    },
}

In the caller package, if they export as positional:

use Sub::Spec;
use MyModule multiply2 => {-positional=>1};

then they can do:

multiply2(2, 3)

instead of the normally:

multiple(a=>2, b=>3)

And in the command-line, any of below is allowed:

% cmd --a 2 --b 3
% cmd 2 --b 3
% cmd 2 3

arg_complete => CODEREF

Specifies how to complete argument value. CODEREF will be given arguments: word=>..., args=>.... and should return an arrayref containing a list of possible candidates. Used for example by Sub::Spec::CmdLine to provide tab completion for argument value. Example:

$SPEC{delete_user} = {
   args => {
       username => ['str*' => {
           arg_complete => sub {
               my %args = @_;
               my $word = $args{word} // "";

               # find users beginning with $word
               local $CWD = "/home";
               return [grep {-d && $_ ~~ /^\Q$word/} <*>];
           },
       }],
   },
};

SEE ALSO

Sub::Spec

Data::Sah

Sub::Spec::Clause::returns

AUTHOR

Steven Haryanto <stevenharyanto@gmail.com>

COPYRIGHT AND LICENSE

This software is copyright (c) 2011 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.