NAME Pluto - Functional Programming ABSTRACT Functional Scripting for Perl 5 SYNOPSIS package Cosmos; use Pluto; call(string('hello world'), 'titlecase'); # Hello World DESCRIPTION This package enables functional programming for Perl 5 via indirect routine dispatching and dependency injection, operating in a way that plays nicely with third-party libraries without having to switch over to object-oriented programming. WHY Perl is a multi-paradigm programming language that supports functional programming, but, Perl has an intentionally limited standard library with an emphasis on providing library support via the CPAN which is overwhelmingly object-oriented. This makes developing in a functional style difficult as you'll eventually need to rely on a CPAN library that requires you to switch over to object-oriented programming. LIBRARIES This package uses type constraints from: Types::Standard SCENARIOS This package supports the following scenarios: array # given: synopsis array; This package supports making the array function available in the calling package if it doesn't exist already. This function creates a Data::Object::Array object. bool # given: synopsis bool; This package supports making the bool function available in the calling package if it doesn't exist already. This function creates a Data::Object::Boolean object. call # given: synopsis call('Test', 'ok'); This package supports making the call function available in the calling package. This function dispatches function and method calls to a package. code # given: synopsis code; This package supports making the code function available in the calling package if it doesn't exist already. This function creates a Data::Object::Code object. false # given: synopsis false; This package supports making the false function available in the calling package if it doesn't exist already. This function creates a Data::Object::Boolean object. float # given: synopsis float; This package supports making the float function available in the calling package if it doesn't exist already. This function creates a Data::Object::Float object. hash # given: synopsis hash; This package supports making the hash function available in the calling package if it doesn't exist already. This function creates a Data::Object::Hash object. inc # given: synopsis inc 'Data::Dumper'; # creates a DataDumper function DataDumper('Dumper', {1..4}); This package supports making the inc function available in the calling package. When used, this function creates a function after the name provided which calls into the named package. Special characters are stripped from the function name. number # given: synopsis number; This package supports making the number function available in the calling package if it doesn't exist already. This function creates a Data::Object::Number object. regexp # given: synopsis regexp; This package supports making the regexp function available in the calling package if it doesn't exist already. This function creates a Data::Object::Regexp object. space # given: synopsis space; This package supports making the space function available in the calling package if it doesn't exist already. This function creates a Data::Object::Space object. string # given: synopsis string; This package supports making the string function available in the calling package if it doesn't exist already. This function creates a Data::Object::String object. true # given: synopsis true; This package supports making the true function available in the calling package if it doesn't exist already. This function creates a Data::Object::Boolean object. AUTHOR Al Newkirk, awncorp@cpan.org LICENSE Copyright (C) 2011-2019, Al Newkirk, et al. This is free software; you can redistribute it and/or modify it under the terms of the The Apache License, Version 2.0, as elucidated in the "license file" <https://github.com/iamalnewkirk/pluto/blob/master/LICENSE>. PROJECT Wiki <https://github.com/iamalnewkirk/pluto/wiki> Project <https://github.com/iamalnewkirk/pluto> Initiatives <https://github.com/iamalnewkirk/pluto/projects> Milestones <https://github.com/iamalnewkirk/pluto/milestones> Contributing <https://github.com/iamalnewkirk/pluto/blob/master/CONTRIBUTE.md> Issues <https://github.com/iamalnewkirk/pluto/issues>