NAME Do ABSTRACT Modern Perl Development Framework SYNOPSIS package User; use Do 'Class'; has 'fname'; has 'lname'; method greet(Str $name) { my $fname = $self->fname; my $lname = $self->lname; "Hey $name, I'm $fname $lname"; } package main; my $user = User->new(fname => 'Al', lname => 'Newkirk'); say $user->greet('You'); 1; DESCRIPTION This package aims to provide a modern Perl development framework and foundational set of types, functions, classes, patterns, and interfaces for jump-starting application development. FRAMEWORK Do (aka Data-Object) is a robust modern Perl development framework, embracing Perl's multi-paradigm programming nature, flexibility and vast ecosystem that many engineers already know and love. FRAMEWORK CORE package main; use Do; fun main() { # ... } 1; The framework's core configuration enables strict, warnings, Perl's 5.14 features, and configures the core type library, method signatures, and autoboxing. FRAMEWORK LIBRARY package App::Library; use Do 'Library'; our $User = declare 'User', as InstanceOf["App::User"]; 1; The framework's library configuration established a Type::Library compliant type library, as well as configuring Type::Utils in the calling package. Read more at Data::Object::Library. FRAMEWORK CLASS package App::User; use Do 'Class'; has 'fname'; has 'lname'; 1; The framework's class configuration configures the calling package as a Moo class, having the "has", "with", and "extends" keywords available. Read more at Data::Object::Class. FRAMEWORK ROLE package App::Queuer; use Do 'Role'; has 'queue'; method dequeue() { # ... } method enqueue($job) { # ... } 1; The framework's role configuration configures the calling package as a Moo role, having the "has", "with", and "extends" keywords available. Read more at Data::Object::Role. FRAMEWORK RULE package App::Queueable; use Do 'Rule'; requires 'dequeue'; requires 'enqueue'; 1; The framework's rule configuration configures the calling package as a Moo role, intended to be used to classify interfaces. Read more at Data::Object::Rule. FRAMEWORK STATE package App::Env; use Do 'State'; has 'vars'; has 'args'; has 'opts'; 1; The framework's state configuration configures the calling package as a singleton class with global state. Read more at Data::Object::State. FRAMEWORK STRUCT package App::Data; use Do 'Struct'; has 'auth'; has 'user'; has 'args'; 1; The framework's struct configuration configures the calling package as a class whose state becomes immutable after instantiation. Read more at Data::Object::Struct. FRAMEWORK ARRAY package App::Args; use Do 'Array'; method command() { return $self->get(0); } 1; The framework's array configuration configures the calling package as a class which extends the Array class. Read more at Data::Object::Array. FRAMEWORK CODE package App::Func; use Do 'Code'; around BUILD($args) { $self->$orig($args); # ... } 1; The framework's code configuration configures the calling package as a class which extends the Code class. Read more at Data::Object::Code. FRAMEWORK FLOAT package App::Amount; use Do 'Float'; method currency(Str $code) { # ... } 1; The framework's float configuration configures the calling package as a class which extends the Float class. Read more at Data::Object::Float. FRAMEWORK HASH package App::Data; use Do 'Hash'; method logline() { # ... } 1; The framework's hash configuration configures the calling package as a class which extends the Hash class. Read more at Data::Object::Hash. FRAMEWORK INTEGER package App::Phone; use Do 'Integer'; method format(Str $code) { # ... } 1; The framework's integer configuration configures the calling package as a class which extends the Integer class. Read more at Data::Object::Integer. FRAMEWORK NUMBER package App::ID; use Do 'Number'; method find() { # ... } 1; The framework's number configuration configures the calling package as a class which extends the Number class. Read more at Data::Object::Number. FRAMEWORK REGEXP package App::Path; use Do 'Regexp'; method match() { # ... } 1; The framework's regexp configuration configures the calling package as a class which extends the Regexp class. Read more at Data::Object::Regexp. FRAMEWORK SCALAR package App::OID; use Do 'Scalar'; method find() { # ... } 1; The framework's scalar configuration configures the calling package as a class which extends the Scalar class. Read more at Data::Object::Scalar. FRAMEWORK STRING package App::Title; use Do 'String'; method generate() { # ... } 1; The framework's string configuration configures the calling package as a class which extends the String class. Read more at Data::Object::String. FRAMEWORK UNDEF package App::Fail; use Do 'Undef'; method explain() { # ... } 1; The framework's undef configuration configures the calling package as a class which extends the Undef class. Read more at Data::Object::Undef. INSTALLATION If you have cpanm, you only need one line: $ cpanm -qn Do If you don't have cpanm, get it! It takes less than a minute, otherwise: $ curl -L https://cpanmin.us | perl - -qn Do Add Do to the list of dependencies in cpanfile: requires "Do" => "1.05"; # 1.05 or newer If cpanm doesn't have permission to install modules in the current Perl installation, it will automatically set up and install to a local::lib in your home directory. See the local::lib documentation for details on enabling it in your environment. We recommend using a Perlbrew <https://github.com/gugod/app-perlbrew> or Plenv <https://github.com/tokuhirom/plenv> environment. These tools will help you manage multiple Perl installations in your $HOME directory. They are completely isolated Perl installations. 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 same terms as the Perl 5 programming language system itself. PROJECT On GitHub <https://github.com/iamalnewkirk/do> Initiatives <https://github.com/iamalnewkirk/do/projects> Contributing <https://github.com/iamalnewkirk/do/blob/master/CONTRIBUTE.mkdn> Reporting <https://github.com/iamalnewkirk/do/issues> SEE ALSO To get the most out of this distribution, consider reading the following: Data::Object::Class Data::Object::Role Data::Object::Rule Data::Object::Library Data::Object::Signatures