NAME

Data::Object - Data Type Objects for Perl 5

VERSION

version 0.09

SYNOPSIS

use Data::Object 'deduce';

my $object = deduce [1..9];

$object->isa('Data::Object::Array'); # 1
$object->count; # 9

DESCRIPTION

Data::Object provides functions for promoting Perl 5 native data types to objects which provide common methods for operating on the data. Note: This is an early release available for testing and feedback and as such is subject to change.

FUNCTIONS

load

# given 'List::Util';

$package = load 'List::Util'; # List::Util if loaded

The load function attempts to dynamically load a module and either dies or returns the package name of the loaded module.

deduce

# given qr/\w+/;

$object = deduce qr/\w+/;
$object->isa('Data::Object::Scalar');

The deduce function returns a data type object instance based upon the deduced type of data provided.

deduce_deep

# given {1,2,3,{4,5,6,[-1]}}

$deep = deduce_deep {1,2,3,{4,5,6,[-1]}}; # produces ...

# Data::Object::Hash {
#     1 => Data::Object::Number ( 2 ),
#     3 => Data::Object::Hash {
#          4 => Data::Object::Number ( 5 ),
#          6 => Data::Object::Array [ Data::Object::Integer ( -1 ) ],
#     },
# }

The deduce_deep function returns a data type object. If the data provided is complex, this function traverses the data converting all nested data to objects. Note: Blessed objects are not traversed.

deduce_type

# given qr/\w+/;

$type = deduce_type qr/\w+/; # SCALAR

The deduce_type function returns a data type description for the type of data provided, represented as a string in capital letters.

detract

# given bless({1..4}, 'Data::Object::Hash');

$object = detract $object; # {1..4}

The detract function returns a value of native type, based upon the underlying reference of the data type object provided.

detract_deep

# given {1,2,3,{4,5,6,[-1, 99, bless({}), sub { 123 }]}};

my $object = deduce_deep $object;
my $revert = detract_deep $object; # produces ...

# {
#     '1' => 2,
#     '3' => {
#         '4' => 5,
#         '6' => [ -1, 99, bless({}, 'main'), sub { ... } ]
#       }
# }

The detract_deep function returns a value of native type. If the data provided is complex, this function traverses the data converting all nested data type objects into native values using the objects underlying reference. Note: Blessed objects are not traversed.

type_array

# given [2..5];

$object = type_array [2..5];
$object->isa('Data::Object::Array');

The type_array function returns a Data::Object::Array instance which wraps the provided data type and can be used to perform operations on the data.

type_code

# given sub { 1 };

$object = type_code sub { 1 };
$object->isa('Data::Object::Code');

The type_code function returns a Data::Object::Code instance which wraps the provided data type and can be used to perform operations on the data.

type_float

# given 5.25;

$object = type_float 5.25;
$object->isa('Data::Object::Float');

The type_float function returns a Data::Object::Float instance which wraps the provided data type and can be used to perform operations on the data.

type_hash

# given {1..4};

$object = type_hash {1..4};
$object->isa('Data::Object::Hash');

The type_hash function returns a Data::Object::Hash instance which wraps the provided data type and can be used to perform operations on the data.

type_integer

# given -100;

$object = type_integer -100;
$object->isa('Data::Object::Integer');

The type_integer function returns a Data::Object::Object instance which wraps the provided data type and can be used to perform operations on the data.

type_number

# given 100;

$object = type_number 100;
$object->isa('Data::Object::Number');

The type_number function returns a Data::Object::Number instance which wraps the provided data type and can be used to perform operations on the data.

type_scalar

# given qr/\w+/;

$object = type_scalar qr/\w+/;
$object->isa('Data::Object::Scalar');

The type_scalar function returns a Data::Object::Scalar instance which wraps the provided data type and can be used to perform operations on the data.

type_string

# given 'abcdefghi';

$object = type_string 'abcdefghi';
$object->isa('Data::Object::String');

The type_string function returns a Data::Object::String instance which wraps the provided data type and can be used to perform operations on the data.

type_undef

# given undef;

$object = type_undef undef;
$object->isa('Data::Object::Undef');

The type_undef function returns a Data::Object::Undef instance which wraps the provided data type and can be used to perform operations on the data.

type_universal

# given 0;

$object = type_universal 0;
$object->isa('Data::Object::Universal');

The type_universal function returns a Data::Object::Universal instance which wraps the provided data type and can be used to perform operations on the data.

ASSERTIONS

The type assertions functions exported can be used on to help ensure data integrity and prevent invalid usage patterns. The following is a list of standard type assertion functions whose routines map to those corresponding in the Types::Standard library.

asa_aref

my $thing = undef;
asa_aref $thing;

The aref function asserts that the argument is an array reference. If the argument is not an array reference, the program will die.

asa_arrayref

my $thing = undef;
asa_arrayref $thing;

The arrayref function asserts that the argument is an array reference. If the argument is not an array reference, the program will die.

asa_bool

my $thing = undef;
asa_bool $thing;

The bool function asserts that the argument is a boolean value. If the argument is not a boolean value, the program will die.

asa_boolean

my $thing = undef;
asa_boolean $thing;

The boolean function asserts that the argument is a boolean value. If the argument is not a boolean value, the program will die.

asa_class

my $thing = undef;
asa_class $thing;

The class function asserts that the argument is a class name. If the argument is not a class name, the program will die.

asa_classname

my $thing = undef;
asa_classname $thing;

The classname function asserts that the argument is a class name. If the argument is not a class name, the program will die.

asa_coderef

my $thing = undef;
asa_coderef $thing;

The coderef function asserts that the argument is a code reference. If the argument is not a code reference, the program will die.

asa_cref

my $thing = undef;
asa_cref $thing;

The cref function asserts that the argument is a code reference. If the argument is not a code reference, the program will die.

asa_def

my $thing = undef;
asa_def $thing;

The def function asserts that the argument is a defined value. If the argument is not a defined value, the program will die.

asa_defined

my $thing = undef;
asa_defined $thing;

The defined function asserts that the argument is a defined value. If the argument is not a defined value, the program will die.

asa_fh

my $thing = undef;
asa_fh $thing;

The fh function asserts that the argument is a file handle. If the argument is not a file handle, the program will die.

asa_filehandle

my $thing = undef;
asa_filehandle $thing;

The filehandle function asserts that the argument is a file handle. If the argument is not a file handle, the program will die.

asa_glob

my $thing = undef;
asa_glob $thing;

The glob function asserts that the argument is a glob reference. If the argument is not a glob reference, the program will die.

asa_globref

my $thing = undef;
asa_globref $thing;

The globref function asserts that the argument is a glob reference. If the argument is not a glob reference, the program will die.

asa_hashref

my $thing = undef;
asa_hashref $thing;

The hashref function asserts that the argument is a hash reference. If the argument is not a hash reference, the program will die.

asa_href

my $thing = undef;
asa_href $thing;

The href function asserts that the argument is a hash reference. If the argument is not a hash reference, the program will die.

asa_int

my $thing = undef;
asa_int $thing;

The int function asserts that the argument is an integer. If the argument is not an integer, the program will die.

asa_integer

my $thing = undef;
asa_integer $thing;

The integer function asserts that the argument is an integer. If the argument is not an integer, the program will die.

asa_num

my $thing = undef;
asa_num $thing;

The num function asserts that the argument is a number. If the argument is not a number, the program will die.

asa_number

my $thing = undef;
asa_number $thing;

The number function asserts that the argument is a number. If the argument is not a number, the program will die.

asa_obj

my $thing = undef;
asa_obj $thing;

The obj function asserts that the argument is an object. If the argument is not an object, the program will die.

asa_object

my $thing = undef;
asa_object $thing;

The object function asserts that the argument is an object. If the argument is not an object, the program will die.

asa_ref

my $thing = undef;
asa_ref $thing;

The ref function asserts that the argument is a reference. If the argument is not a reference, the program will die.

asa_reference

my $thing = undef;
asa_reference $thing;

The reference function asserts that the argument is a reference. If the argument is not a reference, the program will die.

asa_regexpref

my $thing = undef;
asa_regexpref $thing;

The regexpref function asserts that the argument is a regular expression reference. If the argument is not a regular expression reference, the program will die.

asa_rref

my $thing = undef;
asa_rref $thing;

The rref function asserts that the argument is a regular expression reference. If the argument is not a regular expression reference, the program will die.

asa_scalarref

my $thing = undef;
asa_scalarref $thing;

The scalarref function asserts that the argument is a scalar reference. If the argument is not a scalar reference, the program will die.

asa_sref

my $thing = undef;
asa_sref $thing;

The sref function asserts that the argument is a scalar reference. If the argument is not a scalar reference, the program will die.

asa_str

my $thing = undef;
asa_str $thing;

The str function asserts that the argument is a string. If the argument is not a string, the program will die.

asa_string

my $thing = undef;
asa_string $thing;

The string function asserts that the argument is a string. If the argument is not a string, the program will die.

asa_nil

my $thing = undef;
asa_nil $thing;

The nil function asserts that the argument is an undefined value. If the argument is not an undefined value, the program will die.

asa_null

my $thing = undef;
asa_null $thing;

The null function asserts that the argument is an undefined value. If the argument is not an undefined value, the program will die.

asa_undef

my $thing = undef;
asa_undef $thing;

The undef function asserts that the argument is an undefined value. If the argument is not an undefined value, the program will die.

asa_undefined

my $thing = undef;
asa_undefined $thing;

The undefined function asserts that the argument is an undefined value. If the argument is not an undefined value, the program will die.

asa_val

my $thing = undef;
asa_val $thing;

The val function asserts that the argument is a value. If the argument is not a value, the program will die.

asa_value

my $thing = undef;
asa_value $thing;

The value method asserts that the argument is a value. If the argument is not a value, the program will die.

VALIDATIONS

The type validation functions can be used to help control the flow of operations. The following is a list of standard type checking functions whose routines map to those corresponding in the Types::Standard library.

isa_aref

my $thing = undef;
isa_aref $thing;

The aref function checks that the argument is an array reference. If the argument is not an array reference, the function will return false.

isa_arrayref

my $thing = undef;
isa_arrayref $thing;

The arrayref function checks that the argument is an array reference. If the argument is not an array reference, the function will return false.

isa_bool

my $thing = undef;
isa_bool $thing;

The bool function checks that the argument is a boolean value. If the argument is not a boolean value, the function will return false.

isa_boolean

my $thing = undef;
isa_boolean $thing;

The boolean function checks that the argument is a boolean value. If the argument is not a boolean value, the function will return false.

isa_class

my $thing = undef;
isa_class $thing;

The class function checks that the argument is a class name. If the argument is not a class name, the function will return false.

isa_classname

my $thing = undef;
isa_classname $thing;

The classname function checks that the argument is a class name. If the argument is not a class name, the function will return false.

isa_coderef

my $thing = undef;
isa_coderef $thing;

The coderef function checks that the argument is a code reference. If the argument is not a code reference, the function will return false.

isa_cref

my $thing = undef;
isa_cref $thing;

The cref function checks that the argument is a code reference. If the argument is not a code reference, the function will return false.

isa_def

my $thing = undef;
isa_def $thing;

The def function checks that the argument is a defined value. If the argument is not a defined value, the function will return false.

isa_defined

my $thing = undef;
isa_defined $thing;

The defined function checks that the argument is a defined value. If the argument is not a defined value, the function will return false.

isa_fh

my $thing = undef;
isa_fh $thing;

The fh function checks that the argument is a file handle. If the argument is not a file handle, the function will return false.

isa_filehandle

my $thing = undef;
isa_filehandle $thing;

The filehandle function checks that the argument is a file handle. If the argument is not a file handle, the function will return false.

isa_glob

my $thing = undef;
isa_glob $thing;

The glob function checks that the argument is a glob reference. If the argument is not a glob reference, the function will return false.

isa_globref

my $thing = undef;
isa_globref $thing;

The globref function checks that the argument is a glob reference. If the argument is not a glob reference, the function will return false.

isa_hashref

my $thing = undef;
isa_hashref $thing;

The hashref function checks that the argument is a hash reference. If the argument is not a hash reference, the function will return false.

isa_href

my $thing = undef;
isa_href $thing;

The href function checks that the argument is a hash reference. If the argument is not a hash reference, the function will return false.

isa_int

my $thing = undef;
isa_int $thing;

The int function checks that the argument is an integer. If the argument is not an integer, the function will return false.

isa_integer

my $thing = undef;
isa_integer $thing;

The integer function checks that the argument is an integer. If the argument is not an integer, the function will return false.

isa_num

my $thing = undef;
isa_num $thing;

The num function checks that the argument is a number. If the argument is not a number, the function will return false.

isa_number

my $thing = undef;
isa_number $thing;

The number function checks that the argument is a number. If the argument is not a number, the function will return false.

isa_obj

my $thing = undef;
isa_obj $thing;

The obj function checks that the argument is an object. If the argument is not an object, the function will return false.

isa_object

my $thing = undef;
isa_object $thing;

The object function checks that the argument is an object. If the argument is not an object, the function will return false.

isa_ref

my $thing = undef;
isa_ref $thing;

The ref function checks that the argument is a reference. If the argument is not a reference, the function will return false.

isa_reference

my $thing = undef;
isa_reference $thing;

The reference function checks that the argument is a reference. If the argument is not a reference, the function will return false.

isa_regexpref

my $thing = undef;
isa_regexpref $thing;

The regexpref function checks that the argument is a regular expression reference. If the argument is not a regular expression reference, the function will return false.

isa_rref

my $thing = undef;
isa_rref $thing;

The rref function checks that the argument is a regular expression reference. If the argument is not a regular expression reference, the function will return false.

isa_scalarref

my $thing = undef;
isa_scalarref $thing;

The scalarref function checks that the argument is a scalar reference. If the argument is not a scalar reference, the function will return false.

isa_sref

my $thing = undef;
isa_sref $thing;

The sref function checks that the argument is a scalar reference. If the argument is not a scalar reference, the function will return false.

isa_str

my $thing = undef;
isa_str $thing;

The str function checks that the argument is a string. If the argument is not a string, the function will return false.

isa_string

my $thing = undef;
isa_string $thing;

The string function checks that the argument is a string. If the argument is not a string, the function will return false.

isa_nil

my $thing = undef;
isa_nil $thing;

The nil function checks that the argument is an undefined value. If the argument is not an undefined value, the function will return false.

isa_null

my $thing = undef;
isa_null $thing;

The null function checks that the argument is an undefined value. If the argument is not an undefined value, the function will return false.

isa_undef

my $thing = undef;
isa_undef $thing;

The undef function checks that the argument is an undefined value. If the argument is not an undefined value, the function will return false.

isa_undefined

my $thing = undef;
isa_undefined $thing;

The undefined function checks that the argument is an undefined value. If the argument is not an undefined value, the function will return false.

isa_val

my $thing = undef;
isa_val $thing;

The val function checks that the argument is a value. If the argument is not a value, the function will return false.

isa_value

my $thing = undef;
isa_value $thing;

The value function checks that the argument is a value. If the argument is not a value, the function will return false.

SEE ALSO

AUTHOR

Al Newkirk <anewkirk@ana.io>

COPYRIGHT AND LICENSE

This software is copyright (c) 2014 by Al Newkirk.

This is free software; you can redistribute it and/or modify it under the same terms as the Perl 5 programming language system itself.