NAME

Simo::Util - Utility Class for Simo

VERSION

Version 0.0203

DESCRIPTION

Simo::Util is Utitly class for Simo.

This provide some functionality to Simo.

1. Helper method to manipulate object

o function

2. Structured error system

err function

CAUTION

Simo::Util is yet experimental stage.

SYNOPSIS

use Simo::Util qw( o );

my( $title, $author ) = o($book)->get_attrs( 'title', 'author' );

my %hash = o($book)->get_attrs_as_hash( 'title', 'author' );
my $hash_ref = o($book)->get_attrs_as_hash( 'title', 'author' );

o($book)->set_attrs( title => 'Simple OO', author => 'kimoto' );

my $result = o($book_list)->run_methods(
    'select' => [ type => 'Commic' ],
    'sort' => [ 'desc' ],
    'get_result'
);



use Simo::Util qw( err );

# check error
if( err ){
    if( err->type eq 'err_type' ){
        my $msg = err->msg;
        my $pos = err->pos; # error position, which 'croak' create.
        my $info = err->info; # other than type, msg, pos is packed into info.
        
        my $a = $info->{ a };
        my $b = $ingo->{ b };
    }
}

EXPORT

By default, no funcion is exported.

All functions can be exported.

use Simo::Util qw( o err );

o() functions

o() is object wrapper.

wrapped object use useful methods provided by Simo::Wrapper.

Simo::Wrapper methods

get_attrs

You can get multiple attrs value.

my( $title, $author ) = o($book)->get_attrs( 'title', 'author' );

get_attrs_as_hash

You can get multiple attrs value as hash or hash ref.

my %hash = o($book)->get_attrs_as_hash( 'title', 'author' );

or

my $hash_ref = o($book)->get_attrs_as_hash( 'title', 'author' );

set_attrs

You can set multiple attrs valule.

o($book)->set_attrs( title => 'Simple OO', author => 'kimoto' );

This method return wrapped object. so you can call method continuous.

o($book)->set_attrs( title => 'good news' )->run_methods( 'sort' );

run_methods

This run some methods continuous.

my $result = o($book_list)->run_methods(
    'select' => [ type => 'Commic' ],
    'sort' => [ 'desc' ],
    'get_result'
);

Method args must be array ref. Please be carefull not to specify scalar or list.

my $result = o($book_list)->run_methods(
    'select' => ( type => 'Commic' ), # this is not work.
    'sort' => 'desc', # this is also not work.
);

You can omit args.

my $result = o($book_list)->run_methods(
    'get_result' # omit args
);

You can get last method return value.

err() function

export err function

use Simo::Util qw( err );

See also Simo::Error

get error object;

The following is sample

# check error
if( err ){
    if( err->type eq 'err_type' ){
        my $msg = err->msg;
        my $pos = err->pos; # error position, which 'croak' create.
        my $info = err->info; # other than type, msg, pos is packed into info.
        
        my $a = $info->{ a };
        my $b = $ingo->{ b };
    }
}

AUTHOR

Yuki Kimoto, <kimoto.yuki at gmail.com>

BUGS

Please report any bugs or feature requests to bug-simo-util at rt.cpan.org, or through the web interface at http://rt.cpan.org/NoAuth/ReportBug.html?Queue=Simo-Util. I will be notified, and then you'll automatically be notified of progress on your bug as I make changes.

SUPPORT

You can find documentation for this module with the perldoc command.

perldoc Simo::Util

You can also look for information at:

ACKNOWLEDGEMENTS

COPYRIGHT & LICENSE

Copyright 2009 Yuki Kimoto, all rights reserved.

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