NAME

Data::Object

ABSTRACT

Development Framework Entrypoint

SYNOPSIS

package User;

use Data::Object 'Class';

extends 'Identity';

has 'fname';
has 'lname';

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. This package inherits all behavior from Data::Object::Config.

RATIONALE

This package provides a framework for modern Perl development, embracing Perl's multi-paradigm programming nature, flexibility and vast ecosystem that many of engineers already know and love. The power of this framework comes from the extendable (yet fully optional) type library which is integrated into the object system and type-constrainable subroutine signatures (supporting functions, methods and method modifiers). We also provide classes which wrap Perl 5 native data types and provides methods for operating on the data.

CONVENTION

Contrary to the opinion of some, modern Perl programming can be extremely well-structured and beautiful, leveraging many advanced concepts found in other languages, and some which aren't. Abilities like method modification also referred to as augmentation, reflection, advanced object-orientation, type-constrainable object attributes, type-constrainable subroutine signatures (with named and positional arguments), as well roles (similar to mixins or interfaces in other languages). This framework aims to serve as an entrypoint to leveraging those abilities.

use Do;

The "Do" package is an alias and subclass of this package. It encapsulates all of the framework's features, is minimalist, and is meant to be the first import in a new class or module.

use Data::Object;

Both import statements are funcationally equivalent, enable the same functionality, and can be configured equally. This is what's enabled whenever you import the "Do" or "Data::Object" package into your namespace.

# basics
use strict;
use warnings;

# loads say, state, switch, etc
use feature ':5.14';

# loads type constraints
use Data::Object::Library;

# loads function/method signatures
use Data::Object::Signatures;

# imports keywords and super "do" function, etc
use Data::Object::Export;

# enables method calls on native data types
use Data::Object::Autobox;

To explain by way of example: The following established a user-defined type library where user-defined classes, roles, etc, will be automatically registered.

package App;

use Do 'Library';

1;

The following creates a class representing a user which has the ability to greet another person. This class is type-library aware and will register itself as a type constraint.

package App::User;

use Do 'Class', 'App';

has name => (
  is  => 'ro',
  isa => 'Str',
  req => 1
);

method hello(AppUser $user) {
  return 'Hello '. $user->name .'. How are you?';
}

1;

The following is a script which is type-library aware that creates a function that returns how one user greets another user.

package main;

use App::User;

use Do 'Core', 'App';

fun greetings(AppUser $u1, AppUser $u2) {
  return $u1->hello($u2);
}

my $u1 = User->new(name => 'Jane');
my $u2 = User->new(name => 'June');

say(greetings($u1, $u2)); # Hello June ...

This demonstrates much of the power of this framework in one simple example. If you're new to Perl, the code above creates a class with a single (read-only string) attribute called name and a single method called hello, then registers the class in a user-defined type-library called App where all user-defined type constraints will be stored and retrieved (and reified). The main program (namespace) initializes the framework and specifies the user-defined type library to use in the creation of a single function greetings which takes two arguments which must both be instances of the class we just created.

DISCRETIONARY

It's also important to note that while the example showcases much of what's possible with this framework, all of the sophistication is totally optional. For example, method and function signatures are optionally typed, so the declarations would work just as well without the types specified. In fact, you could then remove the App type library declarations and even resort rewriting the method and function as plain-old Perl subroutines. This flexibility to be able to enable more advanced capabilities is common in the Perl ecosystem and is one of the things we love most. The wiring-up of things! If you're familiar with Perl, this framework is in-part the wiring up of Moo (with Moose support), Type::Tiny, Function::Parameters, Try::Tiny and data objects in a cooperative and cohesive way that feels like it's native to the language.

METHODS

This package implements the following methods.

any

any(Any $arg) : AnyObject

The any constructor function returns a Data::Object::Any object for given argument.

any example
# given \*main

my $object = Data::Object->any(\*main);

array

array(ArrayRef $arg) : ArrayObject

The array constructor function returns a Data::Object::Array object for given argument.

array example
# given [1..4]

my $object = Data::Object->array([1..4]);

code

code(CodeRef $arg) : CodeObject

The code constructor function returns a Data::Object::Code object for given argument.

code example
# given sub { shift + 1 }

my $object = Data::Object->code(sub { $_[0] + 1 });

exception

exception(HashRef $arg) : ExceptionObject

The exception constructor function returns a Data::Object::Exception object for given argument.

exception example
# given { message => 'Oops' }

my $object = Data::Object->exception({ message => 'Oops' });

float

float(Num $arg) : FloatObject

The float constructor function returns a Data::Object::Float object for given argument.

float example
# given 1.23

my $object = Data::Object->float(1.23);

hash

hash(HashRef $arg) : HashObject

The hash constructor function returns a Data::Object::Hash object for given argument.

hash example
# given {1..4}

my $object = Data::Object->hash({1..4});

integer

integer(Int $arg) : IntegerObject

The integer constructor function returns a Data::Object::Integer object for given argument.

integer example
# given -123

my $object = Data::Object->integer(-123);

new

new(Str $arg) : SpaceObject

The new method expects a string representing a class name under the Data::Object namespace and returns a Data::Object::Space object.

new example
# given 'String'

my $space = Data::Object->new('String');

my $string = $space->build('hello world');

number

number(Num $arg) : NumberObject

The number constructor function returns a Data::Object::Number object for given argument.

number example
# given 123

my $object = Data::Object->number(123);

regexp

regexp(Regexp $arg) : RegexpObject

The regexp constructor function returns a Data::Object::Regexp object for given argument.

regexp example
# given qr(\w+)

my $object = Data::Object->regexp(qr(\w+));

scalar

scalar(Any $arg) : ScalarObject

The scalar constructor function returns a Data::Object::Scalar object for given argument.

scalar example
# given \*main

my $object = Data::Object->scalar(\*main);

string

string(Str $arg) : ScalarObject

The string constructor function returns a Data::Object::String object for given argument.

string example
# given 'hello'

my $object = Data::Object->string('hello');

undef

undef(Maybe[Undef] $arg) : UndefObject

The undef constructor function returns a Data::Object::Undef object for given argument.

undef example
# given undef

my $object = Data::Object->undef(undef);

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

Initiatives

Contributing

Reporting

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