NAME

Object::KVC - Searchable Key Value Coding

SYNOPSIS

use Object::KVC;

my $object1 = Object::KVC::Hash->new();
my $object2 = Object::KVC::Hash->new();

$object1->set( "id", Object::KVC::String->new("id1234") );
$object2->set( "id", Object::KVC::String->new("id1234") );

print $object1->get( "id" )->as_string();

$object1->equals( $object2 ) ? print "Yes, the objects are equal";

my $object_1 = Object::KVC::Hash->new();
$object_1->set( "id",        Object::KVC::String->new("id1234") );
$object_1->set( "last_name", Object::KVC::String->new("Hofstadter") );
my $object_n = Object::KVC::Hash->new();    

$object_n->set( "id", Object::KVC::String->new("id9999") );

my $container = Object::KVC::List->new();

$container->add( $object_1 );
$container->add( $object_n );

my $search = Object::KVC::Hash->new();
$search->set( "id", Object::KVC::String->new("id1234") );

my $search_result = Object::KVC::List->new();

$container->matches( $search, $search_result );

foreach my $object ( $search_result->iter() ) {
    print $object->get("last_name")->as_string() if ( $object->has_defined("last_name") );
    print "\n";
}

DESCRIPTION

Key Value Coding uses a hash key instead of an accessor method to access the values of an object. Key Value Coding is generic; it allows a variety of objects to be modeled without having to write a large number of classes.

The Object::KVC classes are built to allow simple SQL-like searches and manipulation of "schema-free" data.

The Object::KVC::Hash class values must be wrapped in an object supporting the "equals," "contains," and "intersects" methods in order to allow two Object::KVC::Hash objects to be compared.

The Object::KVC::Hash search methods are used by the Object::KVC::List container class to implement the search functionality.

The actual implementation of the value wrapper class search methods effectively customizes the actual search behaviour.

COPYRIGHT AND LICENSE

Object::KVC Copyright (C) 2012 Trystan Johnson

This library is free software; you can redistribute it and/or modify it under the same terms as Perl itself, either Perl version 5.8.8 or, at your option, any later version of Perl 5 you may have available.