Added _dump_file and improved how arrays/hashes clean up after themselves
[dbsrgits/DBM-Deep.git] / Changes
1 Revision history for DBM::Deep.
2
3 1.0004 Sep 25 00:00:00 2007 EDT
4     - Fixed the Changes file
5     - Added filter sugar methods to be more API-compatible with other DBMs
6     - Implemented _dump_file in order to display the file structure.
7       - Arrays now clean up after themselves better.
8
9 1.0003 Sep 24 14:00:00 2007 EDT
10     - THIS VERSION IS INCOMPATIBLE WITH FILES FROM ALL OTHER PRIOR VERSIONS.
11     - Further fixes for unshift/shift/splice and references (RT# 29583)
12     - To fix that, I had to put support for real references in.
13       - the 16 and 22 tests are now re-enabled.
14       - Yes, this means that real references work. See t/45_references.t
15
16 1.0002 Sep 20 22:00:00 2007 EDT
17     - (This version is compatible with 1.0001)
18     - Expanded _throw_error() so that it provides better information.
19       (Thanks brian d foy!)
20     - Fixed how shift, unshift, and splice work when there are references
21       being moved. It now no longer dies.
22     - Added diag in t/17_import.t to note that the failing tests on blead
23       are due to Clone being broken, not DBM::Deep. The tests will still
24       fail because I don't want users to install something that's broken
25       and deal with those bug reports.
26
27 1.0001 Mar 12 16:15:00 2007 EDT
28     - (This version is compatible with 1.0000)
29     - Added a missing dependency on IO::Scalar (RT #25387)
30     - Fixed how t/44_upgrade_db.t and utils/upgrade_db.pl worked
31       - utils/upgrade_db.pl now uses #!perl, not #!/usr/bin/perl
32       - t/44_upgrade_db.t now explicitly calls $^X
33         (Thanks merlyn!)
34
35 1.0000 Feb 26 22:30:00 2007 EST
36     - THIS VERSION IS INCOMPATIBLE WITH FILES FROM ALL OTHER PRIOR VERSIONS.
37       - To aid in this form of upgrades, DBM::Deep now checks the file format
38         version to make sure that it knows how to read it.
39       - db_upgrade.pl was added to utils/. This will -NOT- install onto
40         your system. This is deliberate.
41       - db_upgrade.pl will not handle developer release file formats. This
42         is due to the fact that all developer releases in preparation for a
43         given release share the same file version, even though the file
44         format may change. This is deliberate.
45     - Importing no longer takes place within a transaction
46     - The following parameters were added:
47       - data_sector_size - this determines the default size of a data sector.
48     - Correctly handle opening readonly files
49
50 0.99_04 Jan 24 22:30:00 2007 EST
51     - Added the missing lib/DBM/Deep.pod file to the MANIFEST
52     - Fixed a poorly-designed test that was failing depending on what Clone::Any
53       was using.
54     - All "use 5.6.0;" lines are now "use 5.006_000;" to avoid warnings about
55       unsupported vstrings in 5.9.x
56
57 0.99_03 Jan 23 22:30:00 2007 EST
58     - THIS VERSION IS INCOMPATIBLE WITH FILES FROM ALL OTHER PRIOR VERSIONS.
59       - The fileformat changed completely. I will be writing a converter, but
60         it's not there right now. Do NOT expect that this module will
61         correctly detect older versions and handle them sanely. Sanity will be
62         there for 1.00, but we're not there yet, are we?
63     - Converted to use FileHandle::Fmode to handle filehandle status checks
64     - Fixed bug with deleting already-deleted items on Win32 (reported by Nigel Sandever)
65     - The guts of how transactions work has been rewritten to better handle
66       some edgecases. This required a complete rewrite of the engine.
67     - Freespace management is now in place. It's not perfect, but it's there.
68     - The rewrite of the engine required a rewrite of how first_key/next_key
69       was implemented. This should result in significant speed improvements.
70     - Self-reference has been removed. This means you cannot do:
71           $db->{foo} = { x => 'y' };
72           $db->{bar} = $db->{foo};
73       I hope to be able to return this functionality by 1.00, but I cannot
74       promise anything. To do this properly, it requires refcounting in order
75       to correctly handle deletions and transactions. Once you move away from
76       a simple tree, everything becomes really hard.
77
78 0.99_02 Apr 28 05:00:00 2006 Pacific
79     - Added missing file to the MANIFEST
80
81 0.99_01 Apr 27 18:00:00 2006 Pacific
82     - Added explicit dependency on Perl 5.6.0
83       - Digest::MD5 requires 5.6.0
84       - Sub::Uplevel (dep of Test::Exception) requires 5.6.0
85     - Removed error()/clear_error()
86       - All error-handling is done with die()
87     - Broke out DBM::Deep's code into DBM::Deep::Engine
88     - Tied variables can no longer be assigned to a DBM::Deep object.
89       - This includes cross-file assignments.
90     - Autovivification now works
91       - This is a consequence of the fact that all assignments are tied.
92     - set_pack() and set_digest() have been removed.
93       - Instead, you will now pass the appropriate values into new()
94       - A pack_size parameter has been added to make 64-bit files easier
95     - Transactions now work
96
97 0.983 Apr 10 20:00:00 2006 Pacific
98     - Added patch inspired by Jeff Janes (Thanks!)
99       - Autovivification now works correctly
100       - The following now works correctly
101         my %hash = ( a => 1 );
102         $db->{hash} = \%hash;
103         $hash{b} = 2;
104         cmp_ok( $db->{hash}{b}, '==', 2 );
105     - (RT#18530) - DBM::Deep now plays nicely with -l
106
107 0.982 Mar 08 11:00:00 2006 Pacific
108     - Fixed smoketests that were failing on Win32
109     - Added restriction for Perl 5.6.0 or higher.
110       - Digest::MD5 and Sub::Uplevel (dep of Test::Exception) require 5.6+
111
112 0.981 Mar 06 11:00:00 2006 Pacific
113     - (RT#17947) - Fixed test that was failing on older Perls
114
115 0.98  Feb 28 11:00:00 2006 Pacific
116     - Added in patch by David Cantrell to allow use of DATA filehandle
117     - Fixed bug where attempting to export() a structure that used autobless would die
118     - Fixed arraytest slowness by localizing $SIG{__DIE__} to prevent Test::Builder's
119       $SIG{__DIE__} from being called. (q.v. http://perldoc.perl.org/functions/eval.html)
120     - More methods have been made private:
121         - root() is now _root()
122         - base_offset() is now _base_offset()
123         - fh() is now _fh()
124         - type() is now _type()
125         - precalc_sizes() is now _precalc_sizes()
126
127 0.97  Feb 24 10:00:00 2006 Pacific
128     - Reorganization of distribution to a more standard layout
129     - Migration to Module::Build with EU::MM backwards compatibility
130     - Migration of all tests to use Test::More and Test::Exception
131     - Added Devel::Cover report to DBM::Deep POD
132       - Test coverage improved to 89.6% (and climbing)
133     - The following methods have been renamed to reflect their private nature:
134         - init() is now _init()
135         - open() is now _open()
136         - close() is now _close()
137         - load_tag() is now _load_tag()
138         - index_lookup() is now _index_lookup()
139         - add_bucket() is now _add_bucket()
140         - get_bucket_value() is now _get_bucket_value()
141         - delete_bucket() is now _delete_bucket()
142         - bucket_exists() is now _bucket_exists()
143         - find_bucket_list() is now _find_bucket_list()
144         - traverse_index() is now _traverse_index()
145         - get_next_key() is now _get_next_key()
146         - copy_node() is now _copy_node()
147         - throw_error() is now _throw_error()
148     - The various tied classes have been broken out. This means that testing
149         "ref( $obj ) eq 'DBM::Deep'" will now fail. The correct test is
150         "eval { $obj->isa( 'DBM::Deep' ) }".
151     - The various methods like push and delete now have the same return values as
152       the standard builtins.
153     - TIEARRAY and TIEHASH now check their parameters more thoroughly
154     - Negative indices for arrays works as expected, including throwing the appropriate
155       errors.
156     - RT #16877 is fixed (DBM::Deep broken with Perl 5.9.3+).
157     - RT #14893 is fixed (tie() and new() use different parameter lists).
158     - A bug with optimize and threading is fixed.
159     - autobless has received some attention, resulting in a number of bugs fixed.
160     - Removed mode option as it just caused confusion.
161     - Removed volatile option as it is pretty useless (use locking instead)
162     - Locking now implicitly enables autoflush
163
164 0.96  Oct 14 09:55:00 2005 Pacific
165     - Fixed build (OS X hidden files killed it)
166     - You can now pass in an optional filehandle to the constructor
167
168 0.95  Oct 12 13:58:00 2005 Pacific
169     - Added optional autobless flag to preserve and restore blessed hashes
170     - Fixed bug where 0 could not be fetched using get_next_key
171     - Fixed bug where tie() constructor didn't accept a hash ref for args
172     - optimize() now preserves user/group/permissions
173     - Errors are now FATAL (meaning it calls die()), unless you set debug flag
174
175 0.94  Apr 13 19:00:26 2004 Pacific
176     - Fixed bug reported by John Cardenas (corruption at key level when
177          replace of less data was done on bucket)
178
179 0.93  Feb 15 19:53:17 2004 Pacific
180     - Fixed optmize() on Win32 where orig file couldn't be overwritten unless
181          filehandle was closed first.  This change introduces a potential race
182          condition when using locking and optmize() on Win32, but it can be 
183          fixed in the future using a soft copy instead of Perl's rename().
184
185 0.92  Feb 12 19:10:22 2004 Pacific
186     - Fixed bug where passing a reference to a different DBM::Deep object
187          would still result in an internal reference.
188     - Added export() method for recursively extracting hashes/arrays into
189          standard in-memory Perl structures.
190     - Added import() method for recursively importing existing Perl hash/
191          array structures
192     - Fixed bug where optimize() wouldn't work if base level of DB was
193          an array instead of a hash.
194
195 0.91  Feb 12 02:30:22 2004 Pacific
196     - Fixed bug with splice() when length of removed section was 0
197     - Updated POD re: circular refs and optimize()
198     - Had to jump version numbers to 0.91 because in previous releases
199          I used only a single digit after the decimal which was confusing
200          the CPAN indexer.
201
202 0.10  Feb 11 08:58:35 2004 Pacific
203     - Fixed bug where default file mode was CLEARING files (Thanks Rich!)
204     - Added experimental support for circular references
205     - Fixed bugs in shift(), unshift() and splice() where nested objects
206         in array would be recursively re-stored as basic hashes/arrays
207     - Fixed typos in POD docs
208
209 0.9   Feb 10 03:25:48 2004 Pacific
210     - Added Filters for storing/fetching keys/values
211     - Added hook for supplying own hashing algorithm
212     - FIxed some typos in POD docs, added new sections
213
214 0.8   Feb 8 02:38:22 2004 Pacific
215     - Renamed to DBM::Deep for CPAN
216     - Added optimize() method for rekindling unused space
217     - Now returning hybrid tie()/OO object from new()
218     - Basic error handling introduced
219     - Added debug mode for printing errors to STDERR
220     - Added TYPE_HASH and TYPE_ARRAY constants for "type" param
221     - Added clone() method for safe copying of objects
222     - Wrote POD documentation
223     - Added set_pack() function for manipulating LONG_SIZE / LONG_PACK
224     - Added aliases for most tied functions for public use
225     - Now setting binmode() on FileHandle for Win32
226     - Added 45 unit tests
227
228 0.7   Jan 4 11:31:50 2003 UTC
229     - Renamed to DeepDB
230     - Changed file signature to DPDB (not compatible with older versions)
231     - Converted array length to packed long instead of sprintf()ed string
232
233 0.6   Dec 31 15:12:03 2002 UTC
234     - Some misc optimizations for speed
235
236 0.5   Oct 18 08:55:29 2002 UTC
237     - support for force_return_next parameter in traverse_index() method for 
238       ultra-fast combined key search/removal
239
240 0.4   Oct 15 20:07:47 2002 UTC
241     - now making sure filehandle is open for all DB calls
242
243 0.3   Oct 3 19:04:13 2002 UTC
244     - fixed bug that could cause corrupted data when using locking
245
246 0.2   Aug 6 16:37:32 2002 UTC
247     - Removed base index caching, as it can cause problems when two processes 
248       are populating the db at the same time (even with locking)
249
250 0.1   Jun 3 08:06:26 2002 UTC
251     - initial release