NAME Data::Object ABSTRACT Object-Orientation for Perl 5 SYNOPSIS package main; use Data::Object; my $array = Array [1..4]; # my $iterator = $array->iterator; # $iterator->next; # 1 DESCRIPTION This package automatically exports and provides constructor functions for creating chainable data type objects from raw Perl data types. LIBRARIES This package uses type constraints from: Data::Object::Types FUNCTIONS This package implements the following functions: args Args(HashRef $data) : InstanceOf["Data::Object::Args"] The Args function returns a Data::Object::Args object. Args example #1 package main; use Data::Object 'Args'; my $args = Args; # [...] Args example #2 package main; my $args = Args { subcommand => 0 }; # $args->subcommand; array Array(ArrayRef $data) : InstanceOf["Data::Object::Box"] The Array function returns a Data::Object::Box which wraps a Data::Object::Array object. Array example #1 package main; my $array = Array; # [] Array example #2 package main; my $array = Array [1..4]; boolean Boolean(Bool $data) : BooleanObject The Boolean function returns a Data::Object::Boolean object representing a true or false value. Boolean example #1 package main; my $boolean = Boolean; Boolean example #2 package main; my $boolean = Boolean 0; box Box(Any $data) : InstanceOf["Data::Object::Box"] The Box function returns a Data::Object::Box object representing a data type object which is automatically deduced. Box example #1 package main; my $box = Box; Box example #2 package main; my $box = Box 123; Box example #3 package main; my $box = Box [1..4]; Box example #4 package main; my $box = Box {1..4}; code Code(CodeRef $data) : InstanceOf["Data::Object::Box"] The Code function returns a Data::Object::Box which wraps a Data::Object::Code object. Code example #1 package main; my $code = Code; Code example #2 package main; my $code = Code sub { shift }; data Data(Str $file) : InstanceOf["Data::Object::Data"] The Data function returns a Data::Object::Data object. Data example #1 package main; use Data::Object 'Data'; my $data = Data; Data example #2 package main; my $data = Data 't/Data_Object.t'; # $data->contents(...); error Error(Str | HashRef) : InstanceOf["Data::Object::Exception"] The Error function returns a Data::Object::Exception object. Error example #1 package main; use Data::Object 'Error'; my $error = Error; # die $error; Error example #2 package main; my $error = Error 'Oops!'; # die $error; Error example #3 package main; my $error = Error { message => 'Oops!', context => { time => time } }; # die $error; false False() : BooleanObject The False function returns a Data::Object::Boolean object representing a false value. False example #1 package main; my $false = False; float Float(Num $data) : InstanceOf["Data::Object::Box"] The Float function returns a Data::Object::Box which wraps a Data::Object::Float object. Float example #1 package main; my $float = Float; Float example #2 package main; my $float = Float '0.0'; hash Hash(HashRef $data) : InstanceOf["Data::Object::Box"] The Hash function returns a Data::Object::Box which wraps a Data::Object::Hash object. Hash example #1 package main; my $hash = Hash; Hash example #2 package main; my $hash = Hash {1..4}; name Name(Str $data) : InstanceOf["Data::Object::Name"] The Name function returns a Name::Object::Name object. Name example #1 package main; use Data::Object 'Name'; my $name = Name 'Example Title'; # $name->package; number Number(Num $data) : InstanceOf["Data::Object::Box"] The Number function returns a Data::Object::Box which wraps a Data::Object::Number object. Number example #1 package main; my $number = Number; Number example #2 package main; my $number = Number 123; opts Opts(HashRef $data) : InstanceOf["Data::Object::Opts"] The Opts function returns a Data::Object::Opts object. Opts example #1 package main; use Data::Object 'Opts'; my $opts = Opts; Opts example #2 package main; my $opts = Opts { spec => ['files|f=s'] }; # $opts->files; [...] regexp Regexp(RegexpRef $data) : InstanceOf["Data::Object::Box"] The Regexp function returns a Data::Object::Box which wraps a Data::Object::Regexp object. Regexp example #1 package main; my $regexp = Regexp; Regexp example #2 package main; my $regexp = Regexp qr/.*/; scalar Scalar(Ref $data) : InstanceOf["Data::Object::Box"] The Scalar function returns a Data::Object::Box which wraps a Data::Object::Scalar object. Scalar example #1 package main; my $scalar = Scalar; Scalar example #2 package main; my $scalar = Scalar \*main; space Space(Str $data) : InstanceOf["Data::Object::Space"] The Space function returns a Data::Object::Space object. Space example #1 package main; use Data::Object 'Space'; my $space = Space 'Example Namespace'; string String(Str $data) : InstanceOf["Data::Object::Box"] The String function returns a Data::Object::Box which wraps a Data::Object::String object. String example #1 package main; my $string = String; String example #2 package main; my $string = String 'abc'; struct Struct(HashRef $data) : InstanceOf["Data::Object::Struct"] The Struct function returns a Data::Object::Struct object. Struct example #1 package main; use Data::Object 'Struct'; my $struct = Struct; Struct example #2 package main; my $struct = Struct { name => 'example', time => time }; true True() : BooleanObject The True function returns a Data::Object::Boolean object representing a true value. True example #1 package main; my $true = True; undef Undef() : InstanceOf["Data::Object::Box"] The Undef function returns a Data::Object::Undef object representing the undefined value. Undef example #1 package main; my $undef = Undef; vars Vars() : InstanceOf["Data::Object::Vars"] The Vars function returns a Data::Object::Vars object representing the available environment variables. Vars example #1 package main; use Data::Object 'Vars'; my $vars = Vars; Vars example #2 package main; my $vars = Vars { user => 'USER' }; # $vars->user; # $USER 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/data-object/blob/master/LICENSE>. PROJECT Wiki <https://github.com/iamalnewkirk/data-object/wiki> Project <https://github.com/iamalnewkirk/data-object> Initiatives <https://github.com/iamalnewkirk/data-object/projects> Milestones <https://github.com/iamalnewkirk/data-object/milestones> Contributing <https://github.com/iamalnewkirk/data-object/blob/master/CONTRIBUTE.md> Issues <https://github.com/iamalnewkirk/data-object/issues>