Tie::Queue - Introduction
Tie::Queue - Tie an ARRAY over a TokyTyrant DB ( see http://tokyocabinet.sourceforge.net )
SYNOPSIS
use Tie::Queue;
use Data::Dumper;
## Queue creation
# This queue is not re-initialised at each execution of the script
# the default namespace is 'Tie-Queue'
# and each item are non serialized
tie my @a, 'Tie::Queue', '127.0.0.1', 1978, 0;
# This queue is NOT re-initialised at each execution of the script
# and each item are non serialized
# the namespace is 'second_queue'
tie my @b, 'Tie::Queue', '127.0.0.1', 1978, 1 , 0 , 'second_queue';
## put some data in the queue
for ( 101 .. 110 )
{
push @a, $_;
}
for ( 1001 .. 1005 )
{
push @ab, $_;
}
push @b, 'some text';
push
## show the content of the queue
print Dumper( \@a );
## print the size of the queue
print "size of array=". scalar @a. "\n";
## remove the latest pushed element from the queue ( the newest)
$res1 = pop @a;
print "latest element $res1\n";
print "size of array=". scalar @a. "\n";
print Dumper( \@a );
$res2 = $a[3];
print "element 3 = $res2\n";
## remove the first element from the queue ( the oldest )
$res3 = shift @a;
print "first element $res3\n";
print "size of array=". scalar @a. "\n";
print Dumper( \@a );
if ( exists $a[4] )
{
print "elem 4 exists\n";
}
else
{
print "elem 4 NOT exists\n";
}
if ( exists $a[40] )
{
print "elem 40 exists\n";
}
else
{
print "elem 40 is NOT existing\n";
}
(tied @a)->CLEAR;
print "size of array=". scalar @a. "\n";
########################
# this queue is re-initialised at each execution of the script
# and each item are serialized
# and the name space is 'third_queue_serialized'
tie my @c, 'Tie::Queue', '127.0.0.1', 1978, 1 , 1 , 'third_queue_serialized';
my %test = ( a => 'key_a', b => 'key_B' , c => 3 );
print Dumper(\%test);
push @d , \%test;
my $r = pop @d;
print Dumper($r)
#######################
DESCRIPTION
Tie an ARRAY over a TokyTyrant DB and allow to push, pop shift data;
This module require TokyoTyrant (database and perl module.)
If the serialisation is required, the module Data::Serilizer is also required
The normal ARRAY function present are
push
pop
shift
exists
scalar
storesize ( to allow undef @a)
Specific function
CLEAR
SYNC
REPAIR
The following function are not implemented.
EXTEND
STORE
DELETE
SPLICE
Basic functions
* only the queue relevant functions are present *
tie
Tie an array over a DB
my $t = tie( my @myarray, "Tie::Queue", '127.0.0.1', 1978, 1 , 1 , 'first_name' , 1 , 0 );
Six optional parameter are allowed
1) the IP where the TokyoTyrant is running ( default 127.0.0.1 )
2) the port on which the TokyoTyrant is listenning ( default 1978 )
3) a flag to delete at start the DB ( default 0 )
4) a flag to serialize/deserialize on the fly the data stored in the DB
5) a namespace to allow more than one queue on the same DB ( default Tie-Queue )
6) a flag to activate or deactivate auto_sync ( default 1 )
7) a flag to prevent undef value to be pushed ( default 0 )
8) a flag to use self-healing feature or reset a queue if the data queue is corrupted ( default 0 )
9) a flag to add some debug info on correctable error ( default 0 )
10) a flag to prevent insertion of duplicate value ( default 0 )
PUSH
Add an element at the end of the array
push @myarray , 45646;
POP
Extract the latest element from the array ( the newest )
my $data = pop @myarray;
SHIFT
Extract the first element from the array ( the oldest )
my $data = shift @myarray;
EXISTS
Test if an element in the array exist
print "element exists\n" if (exists $myarray[5]);
FETCH
Retrieve a specific element from the array
my $data = $myarray[6];
FETCHSIZE
Get the size of the array
my $data = scalar(@myarray);
SYNC
Force a sync of the DB ( not usefull is auto_sync is on)
$t->SYNC;
CLEAR
Delete all element in the array
$t->CLEAR;
DESTROY
Normal destructor call when untied the array
Normaly never called by user
REPAIR
Force a rescan of all elements in the queue and recreate the right indexes
Functions not Implemented
* Most of then are not related to a QUEUE *
UNSHIFT
Not implemented
EXTEND
Not implemented
STORE
Not implemented
STORESIZE
to resize the array ( this allow a re-initialisation of the array by undef @a )
DELETE
Not implemented
AUTHOR
Fabrice Dulaunoy <fabrice_at_dulaunoy_dot_com>
SEE ALSO
- TokyoTyrant from Mikio Hirabayashi <mikio_at_users_dot_sourceforge_dot_net>
TODO
- make test
LICENSE
Under the GNU GPL2
This program is free software; you can redistribute it and/or modify it
under the terms of the GNU General Public
License as published by the Free Software Foundation; either version 2
of the License, or (at your option) any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
See the GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program; if not, write to the
Free Software Foundation, Inc., 59 Temple Place,
Suite 330, Boston, MA 02111-1307 USA
Tie::Queue Copyright (C) 2009 DULAUNOY Fabrice
Tie::Queue comes with ABSOLUTELY NO WARRANTY;
This is free software, and you are welcome to redistribute
it under certain conditions;