NAME
Template::Plugin::DBM::Deep - Template Toolkit plugin for DBM::Deep
SYNOPSIS
[% USE db = DBM.Deep(file = "my.db" locking = 1 autoflush = 1);
db.lock;
db.flintstones = { "flintstone" = ["fred" "wilma"]
"rubble" = ["barney" "betty"] };
db.castaways = ["gilligan" "skipper" "professor" "and the rest" ];
db.unlock;
-%]
...
[% db.flintstones.rubble.0; %] -- barney
[% db.castaways.3; %] -- and the rest
DESCRIPTION
This module permits the direct use of DBM::Deep
, a persistent sharable store for nearly arbitrarily nested hashes and arrays, within Template Toolkit code.
The initial constructor returns the top-level DBM::Deep
object. All keyword arguments are passed to the DBM::Deep
constructor as a flat list. Any single positional argument is presumed to be the file
keyword parameter, permitting simple invocations like:
USE db = DBM.deep("my.db");
All appropriate method calls described in "OO Interface" in DBM::Deep are available. In addition, hash-like objects can use direct keys to get at values:
db.foo = "bar";
db.foo; # gets "bar"
And array-like objects can use direct indicies:
db.mylist = ["a" "b" "c"];
db.mylist.2; # gets "c"
Caution: VMethods do not work against the hash-like or array-like objects. However, you can use the export
method to get an unattached cloned copy of that portion of the database, and then the normal vmethods work:
"$key\n" FOR key IN db.export.keys;
Failure to export
first will result in attempting to access a hash element called keys
, which doesn't exist.
There are probably other limitations. If you find other weirdness, let me know so I can update this document.
SEE ALSO
AUTHOR
Randal L. Schwartz, <merlyn@stonehenge.com>
COPYRIGHT AND LICENSE
Copyright (C) 2004 by Randal L. Schwartz, Stonehenge Consulting Services, Inc.
This library is free software; you can redistribute it and/or modify it under the same terms as Perl itself, either Perl version 5.6.0 or, at your option, any later version of Perl 5 you may have available.