Perinci - Collection of Perl modules for Rinci and Riap
Perinci::Sub::Wrapper is the subroutine wrapper which implements/enforces many of the metadata properties, like argument validation (using information in
args) as well as offers features like convert argument passing style, automatically envelope function result, etc.
It is extensible so you can implement wrapper for your properties too.
Riap clients and servers (Perinci::Access::*)
Perinci::Access::InProcess is a client/server (well, neither really, since everything is in-process) to access Perl modules/functions using the Riap protocol. It is basically a way to call your modules/functions using URI syntax; it also dictates a bit on how you should write your functions and where to put the metadata, though it provides a lot of flexibility.
Perinci::Access is a simple wrapper for all Riap clients, you give it a URL/module name/whatever and it will try to select the appropriate Riap client for you.
Perinci::CmdLine is an extensible and featureful command-line library to create command-line programs and API clients. Features include: transparent remote access (thanks to Riap::HTTP), command-line options parsing, --help message, shell tab completion, etc.
These are convenient tools to generate common/generic function and/or metadata. For example, Perinci::Sub::Gen::AccessTable can generate accessor function + metadata for table data.
See CPAN for more Perinci::Sub::Gen::* modules.
See CPAN for more Perinci::* modules.
To get started, read Perinci::Access::InProcess which will tell you on how to write your functions and where to put the metadata. Or, if you only want to access existing code/metadata, head over to Perinci::Access or Perinci::CmdLine.
To declare and implement a new function metadata property, see example in one of the
Perinci-Sub-property-* modules, like Perinci::Sub::property::timeout.
To declare and implement a new function feature, see example in one of the
Perinci-Sub-feature-* modules, like Perinci::Sub::feature::foo.
To declare and implement a new function dependency type, see example in one of the
Perinci-Sub-dep-* modules, like Perinci::Sub::dep::pm.
Some modules have been implemented, some (including important ones) have not. See details on CPAN.
Perinci is taken from Indonesian word, meaning: to specify, to explain in more detail. It can also be an abbreviation for "Perl implementation of Rinci".
Steven Haryanto <email@example.com>
This software is copyright (c) 2012 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.