# NAME

Class::Accessor::Lite::Lazy - Class::Accessor::Lite with lazy accessor feature

# SYNOPSIS

    package MyPackage;

    use Class::Accessor::Lite::Lazy (
        rw_lazy => [
          # implicit builder method name is "_build_foo"
          qw(foo foo2),
          # or specify builder explicitly
          {
            xxx => 'method_name',
            yyy => sub {
              my $self = shift;
              ...
            },
          }
        ],
        ro_lazy => [ qw(bar) ],
        # Class::Accessor::Lite functionality is also available
        new => 1,
        rw  => [ qw(baz) ],
    );

    # or if you specify all attributes' builders explicitly
    use Class::Accessor::Lite::Lazy (
        rw_lazy => {
          foo => '_build_foo',
          bar => \&_build_bar,
        }
    );

    sub _build_foo {
        my $self = shift;
        ...
    }

    sub _build_bar {
        my $self = shift;
        ...
    }

# DESCRIPTION

Class::Accessor::Lite::Lazy provides a "lazy" accessor feature to [Class::Accessor::Lite](http://search.cpan.org/perldoc?Class::Accessor::Lite).

If a lazy accessor without any value set is called, a builder method is called to generate a value to set.

# THE USE STATEMENT

As [Class::Accessor::Lite](http://search.cpan.org/perldoc?Class::Accessor::Lite), the use statement provides the way to create lazy accessors.

- rw\_lazy => \\@name\_of\_the\_properties | \\%properties\_and\_builders

    Creates read / write lazy accessors.

- ro\_lazy => \\@name\_of\_the\_properties | \\%properties\_and\_builders

    Creates read-only lazy accessors.

- new, rw, ro, wo

    Same as [Class::Accessor::Lite](http://search.cpan.org/perldoc?Class::Accessor::Lite).

# FUNCTIONS

- `Class::Accessor::Lite::Lazy->mk_lazy_accessors(@name_of_the_properties)`

    Creates lazy accessors in current package.

- `Class::Accessor::Lite::Lazy->mk_ro_lazy_accessors(@name_of_the_properties)`

    Creates read-only lazy accessors in current package.

# SPECIFYING BUILDERS

As seen in SYNOPSIS, each attribute is specified by either a string or a hashref.

In the string form `$attr` you specify builders implicitly, the builder method name for the attribute _$attr_ is named \_build\__$attr_.

In the hashref form `{ $attr => $method_name | \&builder }` you can explicitly specify builders, each key is the attribute name and each value is
either a string which specifies the builder method name or a coderef itself.

# AUTHOR

motemen <motemen@gmail.com>

# SEE ALSO

[Class::Accessor::Lite](http://search.cpan.org/perldoc?Class::Accessor::Lite)

# LICENSE

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