Topic maps, dbm storage (synchronous)
NOTE: THIS PACKAGE IS NOW DEPRECATED NOTE: USE TM::ResourceAble::MLDBM INSTEAD use TM::Materialized::MLDBM2; { my $tm = new TM::Materialized::MLDBM2 (file => '/tmp/map.dbm'); # modify the map here..... } # it goes out of scope here, and all changes are written back automagically # later in the game { my $tm = new TM::Materialized::MLDBM2 (file => '/tmp/map.dbm'); # we are back in business, no sync necessary }
This package just implements \s-1TM\s0 with a BerkeleyDB store. Unlike TM::Materialized::MLDBM this module does not need explicit synchronisation with the external resource (the \s-1DBM\s0 file here). It ties content-wise with the \s-1DBM\s0 file at constructor time and unties at \s-1DESTROY\s0 time.
The advantage of this storage form is that there is little memory usage. Only those fractions of the map are loaded which are actually needed. If one has very intense interactions with the map (as a query processor has), then this storage technique is not optimal.
The constructor expects a hash with the following keys:
This contains the file name of the \s-1DBM\s0 file to tie to.
\s-1TM\s0, TM::Materialized::MLDBM
Copyright 200[68], Robert Barta <[email protected]>, All rights reserved.
This library is free software; you can redistribute it and/or modify it under the same terms as Perl itself. http://www.perl.com/perl/misc/Artistic.html