NAME

Data::Validate::Structure - handle a structure in custom ways

SYNOPSIS

use Data::Validate::Structure;

my $structure = Structure->new( $data );

# Check sub structures matches exactly
$structure == $structure2

# Check sub structures matches equaly (array order not important)
$structure eq $structure

# Check structure contains all of structure2 at least
$structure >= $structure2

# Check structure2 contains all of structure at least
$structure <= $structure2

# structure much contain structure2 but not equal it
$structure > $structure2

# structure2 must contain structure but not equal it
$structure < $structure2

# Make sure structure does not exactly match structure2
$structure != $structure2

# Remove all parts of structure2 from structure
$structure - $structure2
$structure -= $structure2

# Merge two structures together
$structure + $structure2
$structure += $structure2

DESCRIPTION

Take a structure and attempt to allow some basic structure
to structure testing.

METHODS

$class->new( $structure )

Create a new structure.

$structure->disabled()

Internal method, wht to do when a function is disabled.

$structure->equal( $otherstructure )

Test that structure is the same as other structure.

$structure->notequal( $otherstructure )

Test that structure is not the same as other structure.

$structure->_equal( $otherstructure )

Internal method for testing structural equiverlance.

$structure->identical( $otherstructure )

Return true if structure is identical.

$structure->notidentical( $otherstructure )

Return true if structure is not identical.

$structure->_identical( $otherstructure )

Return true if structure is identical (internal).

$structure->_autoself()

Return true if the caller was internal.

$structure->autovalue()

Return the structure

$structure->autoname()

Return the structure name

$structure->autobool()

Returns the truth of the structure

$structure->structure()

Return the structure directly

$structure->name()

Return the name directly

$structure->_eq( $otherstructure, %p )

Return true if other structure is equle.

$structure->_eq_hash( $otherhash, %p )

Return true if other hash is equle.

$structure->_eq_array( $otherarray )

Return true if other array is equle.

$structure->plus( $otherstructure )

Return the current structure plus another structure

$structure->pluseq( $otherstructure )

Append another structure.

$structure->_plus( $otherstructure )

Internal method for merging two structures.

$structure->_pluseq( $otherstructure )

Internal method for returning two structures.

$structure->_plus_hash( $otherstructure )

Return the current hash plus another hash

$structure->_plus_array( $otherstructure )

Return the current array plus another array

$structure->_plus_scalar( $otherstructure )

Deal with conflicting scalar data (atm we ignore)

$structure->subtract( $otherstructure )

Return the current structure minus a sub structure

$structure->subeq( $otherstructure )

Remove a sub structure from the current structure.

$structure->_sub_array( $otherstructure )

Remove array elements using structure (NOT FINISHED).

$structure->_sub_hash( $otherstructure )

Return the current hash minus a sub hash

$structure->_sub_scalar( $otherstructure )

Remove a scalar so long as it's eq

$structure->_sctref( $otherstructure )

Get the structure reference and the object.

$structure->_clone( $otherstructure )

Make a clone of a structure.

$structure->_sctclone( $otherstructure )

Make a structure object clone.

$structure->_sctdeal( $otherstructure )

Sort out each request so that it goes to the right place
and so that the comparisons are fair.

AUTHOR

I<Martin Owens> Copyright 2007, GPLv3