NAME

Data::Typed::Expression - Parsing typed expressions

VERSION

Version 0.005

SYNOPSIS

use Data::Typed::Expression;
use Data::Typed::Expression::Env;

my $env = Data::Typed::Expression::Env->new({
    vertex => {
        id  => 'int',
        lon => 'double',
        lat => 'double'
    },
    arc => {
        from => 'vertex',
        to   => 'vertex',
        cost => 'double'
    },
    graph => {
        arcs     => 'arc[]',
        vertices => 'vertex[]'
    },
    'int' => undef, 'double' => undef
}, {
    G => 'graph',
    i => 'int'
});
my $expr = Data::Typed::Expression->new('G.arcs[G.v[i]+1]');

$env->validate($expr);
                                                                  

DESCRIPTION

When I was writing a LaTeX paper on mathematical model of an optimization problem, I was in a need to use C-like expressions to illustrate ideas I was writing about. I felt really uncomfortable beacuse I couldn't easily validate the expressions I was using. Hence this module.

The module can parse standard C expressions (or rather a small subset of them) and validate them in the context of some types. Validation step checks if the types of values on which artihmetics is performed are numeric, whether array indices are of int type and if compund types (struct-s) have components referenced by the expression.

The idea was born on this Perlmonks thread: http://perlmonks.org/?node_id=807424.

METHODS

new

Creates a new expression object. The only argument is a string containing expression to be parsed.

The method dies if the expression can't be parsed (i.e. is invalid or to complicated).

Usefulness of an object itself is limited. Pass the object to e.g. Data::Typed::Expression::Env to check type correctness of the expression.