2003-03-16   Darren Duncan <perl@DarrenDuncan.net>

	* Release 1.081.

	* This is a small maintenance release that is mainly for improving
	documentation.  Similar maintenance releases are being done with all of my
	distributions simultaneously.  A lot of it was formatting issues that were
	easy to miss before; the other bullet points below list the non-formatting
	issues.  These files had formatting fixes: MultiValuedHash.pm, ChangeLog.

	* The distribution file layouts have also been standardized, with modules
	going in a "lib" folder and tests going in a "t" folder.  "test.pl" was
	changed to "t/Data-MultiValuedHash.t" and "MultiValuedHash.pm" was changed
	to "lib/Data/MultiValuedHash.pm".

	* Updated NAME in MultiValuedHash.pm to match the official registered
	module list.

	* Updated all Copyright statements to a better (and longer) version, which
	is dated 1999-2003.  Your rights to use these modules haven't changed, but
	they may now be easier to understand.  These statements appear once in the
	ReadMe file at the bottom (under "AUTHOR"), and twice in each module (.pm
	file), a full version at the bottom (under "AUTHOR") and a shorter version
	at the top (in code comments).

	* Added the "use warnings" pragma at the top of all files beside "use
	strict"; every occurance of "use strict" gained a "use warnings" whether it
	was in the module proper or in its test script or in its SYNOPSIS.  This
	should save users from having to put -w on the command line for them.

	* Incremented the module $VERSION number by 0.001, and all test scripts to
	require the new version.  Also, where any of my modules use others of my
	modules, they now require the latest version as of this writing, for
	simplicity of maintenance.

	* Updated all test scripts to read $verbose from @ARGV (command line
	arguments), and other test script improvements.

	* Updated these sections of the ReadMe file: ... STILL TO DO ...

2002-12-01   Darren Duncan <perl@DarrenDuncan.net>

	* Release 1.08.

	* The modules Data::MultiValuedHash and CGI::MultiValuedHash are now being 
	distributed separately from each other, largely so they can be maintained as 
	independant entities.  The 2 new distributions, Data-MultiValuedHash-1.08 
	and CGI-MultiValuedHash-1.08, replace the older MultiValuedHash-1.0703.  
	That said, to use the CGI module you still need the Data module, since the 
	first is a subclass of the second.

	* As part of the above separation, each of the new distributions has a copy
	of all the old supporting files with alterations to focus on the one module
	it is staying with: ChangeLog, Makefile.PL, MANIFEST, ReadMe, test.pl.  
	Both ChangeLog copies are identical for all releases before and including 
	1.08 (applying to both modules), but will differ for any later releases.

	* Minor bug fix release to remove any 'uninitialized value' warnings that
	appear when running the test suite with the -w option.  All of the
	uncovered warnings were in the Data::MultiValuedHash module, of which the
	test suite has already covered every method and method argument variation 
	(but the module had correct output before). 

	* However, many of the methods in CGI::MultiValuedHash are not yet included
	in the test suite, and may conceal bugs that a thorough suite would expose:
	to_file(), from_file(), to_html_encoded_table(),
	to_html_encoded_hidden_fields(), trim_bounding_whitespace(),
	batch_to_file(), batch_from_file().  That said, many of those methods have 
	been used in a production environment without problems to date.  
	These methods *have* been tested, with all their argument variations: 
	to_url_encoded_string(), from_url_encoded_string().

	* Updated the HTML generating methods in CGI::MultiValuedHash,
	to_html_encoded_table() and to_html_encoded_hidden_fields(), to add support
	for the stricter requirements of W3C's XHTML standard where possible.  See
	"http://www.w3.org/TR/xhtml1" for details on how this standard compares to
	HTML 4.  Mainly this means that the HTML now has lowercased tag and
	attribute names, and solitary tags like 'input' and 'br' have a trailing
	slash in them (eg: '<br />').  However, the changes should be
	backwards-compatible with older user agents (web browsers).  A bug was also
	fixed in the first method involving a mis-matched pair of 'table' tags.

	* Minor documentation fix in Data::MultiValuedHash for the splice() method; 
	the new version indicates which arguments are optional.

	* Several documentation updates in the README file; one is so that someone 
	can get an idea what this module does after looking only at the README.

2001-07-16   Darren Duncan <perl@DarrenDuncan.net>

	* Release 1.0703.

	* This minor release deals with some more "ambiguous call" warnings of the 
	sort that release 1.07 addressed, since I didn't get to them all in 1.0702.  
	Both modules are now at version 1.0703.  In CGI::MultiValuedHash, the POD 
	was updated in Synopsis and The Default File Format; for the latter case, I 
	hope that I removed ambiguity regarding how compatible my default file 
	format is with Boulderio.  Thanks to Jonathan Snyder 
	<jonathan@mail.method.com> for alerting me to the fixed problems.

2001-05-28   Darren Duncan <perl@DarrenDuncan.net>

	* Release 1.0702.

	* This minor release deals with some more "ambiguous call" warnings of the 
	sort that release 1.07 addressed, since I didn't get to them all that time.  
	There are also minor POD updates in this release.  Both modules are now at 
	version 1.0702.

2001-04-20   Darren Duncan <perl@DarrenDuncan.net>

	* Release 1.0701.

	* This release should take care of some install problems because the modules 
	are now inside folders like lib/CGI and lib/Data whereas they were just in 
	CGI and Data before.  Thanks to Jost (kriegjcb@CMC01SE.rz.ruhr-uni-bochum.de) 
	for alerting me to this problem.  I'm afraid I still don't know much about 
	Makefiles.

2001-04-12   Darren Duncan <perl@DarrenDuncan.net>

	* Release 1.07.

	* This release should take care of a number of warnings like 
	"Ambiguous call resolved as CORE::values()" which appear on some systems 
	when -w is used.  These spring from the fact that Data::MultiValuedHash 
	has methods with the same names as the following built-in functions: keys(), 
	values(), exists(), push(), unshift(), pop(), shift(), delete().  To fix 
	this, I have changed all such calls to built-in functions so that they 
	explicitely say CORE::*.  However, the modules were working before, as Perl 
	seemed to be resolving the ambiguity in the correct way.

	* Thanks to Geir Johannessen (geir.johannessen@nextra.com) for alerting me 
	to the above warnings.

2001-03-17   Darren Duncan <perl@DarrenDuncan.net>

	* Release 1.06.

	* This release is the first one that includes the CPAN standard file
	"test.pl", which was created following the previous release.  The install 
	instructions in the ReadMe file were updated to reflect that "make test" 
	should now work.  "Test.pl" was used to discover several bugs that my 
	production use of the modules didn't; their fixes are detailed below.

	* Removed gratuitous arguments from clone() that allowed one to specify a 
	subset of keys for the clone to have.  This way, clone() is fully standard 
	and does what one would intuitively expect, namely make an identical copy.

	* Added new method fetch_mvh() to Data::MultiValuedHash which replaces the 
	functionality dropped from clone().  fetch_mvh() has the same calling 
	conventions as fetch_all(), except that an MVH object is returned instead of 
	a literal hash of array refs.

	* Fixed bug in Data::MultiValuedHash where the store_all() method didn't 
	properly handle the import of case-sensitive keys into a case-insensitive 
	MVH.  Specifically, keys were added but associated values were lost.

	* Fixed bug in Data::MultiValuedHash where the splice() method didn't 
	properly handle missing LENGTH arguments.  That is, if one called 
	"splice( KEY, -1 )" then that should remove the last element of the array, 
	but it instead acted like LENGTH had a value of 0, so nothing was removed 
	or returned.  This issue appears to be related to Perl's built-in splice 
	function, which treats "splice( KEY, 1 )" and "splice( KEY, 1, undef )" or 
	"splice( KEY, 1, () )" differently.  So the fix for my splice() method 
	involved having two separate calls to Perl's splice() depending on whether 
	its OFFSET argument is defined or not.

	* Added several new POD sections to the end of CGI::MultiValuedHash that give 
	an overview of using url-encoding/decoding and file-import/export features, 
	mainly describing what the file format or encoding formats look like.

2001-03-14   Darren Duncan <perl@DarrenDuncan.net>

	* Release 1.0501.

	* Fixed bug in CGI::MultiValuedHash where the method to_html_encoded_table() 
	was misnamed as to_html_encoded_hidden_fields(), which is the same as a 
	separate method that also exists.  This module's version was increased to 
	1.0501 to reflect the change.

2001-03-08   Darren Duncan <perl@DarrenDuncan.net>

	* Release 1.05.

	* Added method splice() to Data::MultiValuedHash so as to round out the set 
	of standard array manipulation functions.

	* Added static function batch_new() to Data::HashOfArrays which emulates the 
	symantecs of calling new() multiple times with a list of initializers; as 
	many new MVH objects are made as there are elements in the list.

	* Added programmer documentation to the private method 
	_reduce_hash_from_subset() so people know how to use this method.  Due to its 
	private nature, it is not covered in the POD.

	* Added static functions batch_to_file() and batch_from_file() to 
	CGI::MultiValuedHash so that an entire list of MVH objects can be written to 
	or read from a file at once.  Symantecs are similar to calling the to_file() 
	and from_file() methods.  batch_from_file() will read to the end of the file 
	by default, but can be restricted by an argument to stop after a certain 
	number of objects are retrieved.

2001-03-07   Darren Duncan <perl@DarrenDuncan.net>

	* Release 1.04.

	* This release is the first one that includes the CPAN standard files 
	"Makefile.PL" and "MANIFEST", which were all created following 
	the previous release.  The content of "Manifest" was previously inside the 
	"ReadMe" file.  Improved the install instructions in my ReadMe file.

	* Added a hook to the initialize() method in Data::MultiValuedHash for 
	handling initializers that aren't hashes.  CGI::MultiValuedHash now uses 
	that hook for handling more initializer types, rather than overloading all 
	of initialize().

	* Many small changes were made to methods in Data::MultiValuedHash so that 
	they work better or the code is more readable.

	* Added "Method Relationship Overview" section to the POD of Data::MVH.

	* Changed the ignores_case() method so that you can now change that property.
	When changing this property from false to true, any existing keys are 
	lowercased, which can not be reversed (except from a backup).

	* Added method fetch_hash() to Data::MVH which returns a hash containing 
	all of the keys and one for each; values are all taken from the array 
	index specified with an argument.  fetch_first() and fetch_last() have 
	been changed to use this to implement themselves, since they are the same 
	except with implicit indexes of 0 or -1.

	* Added INDEXES argument to fetch() and fetch_all() so that a caller can 
	restrict a range of values to be returned for each key, much as the KEYS 
	argument of some methods restrict which keys are returned; the new argument
	does not have a COMPLEMENT modifier, however. 

	* Added a method to CGI::MultiValuedHash for outputting the object's keys 
	and values in an HTML table.

2001-01-03   Darren Duncan <perl@DarrenDuncan.net>

	* Release 1.03.

	* This release is the first one following official registrations with 
	"The Perl 5 Module List".  The updated entries would look like this:

Data::
::MultiValuedHash bdpO Hash whose keys have multiple ordered values DUNCAND

CGI::
::MultiValuedHash bdpO Store and manipulate url-encoded data        DUNCAND

	* This release contains my "Data::MultiValuedHash" and "CGI::MultiValuedHash" 
	modules, which were previously a part of the following distributions 
	under the temporary name of "CGI::HashOfArrays":
		- "libdwg": v1.0 r2000-07-23, v1.11 r2000-08-23
		- "CGI-FormGenerator": v0.9 r2000-09-04, v0.9201 r2000-12-26

	* These modules require Perl version 5.004.

	* Code changes since CGI::HashOfArrays consist mainly in its separation into 
	two modules, named above.  This took care of a longstanding logistical 
	problem concerning whether the module was a generic data structure 
	or a tool for encoding/decoding CGI data.  The CGI:: module is a subclass of 
	the Data:: module, so you can use it like you used the old module.
	Thanks to Johan Vromans <jvromans@squirrel.nl> for suggesting the split.

	* The POD also received significant updates.  Thanks to Steve Benson 
	<steve.benson@stanford.edu> for suggesting improvements to initialize().

	* Added method store_value() to Data::MultiValuedHash.

2000-12-26   Darren Duncan <perl@DarrenDuncan.net>

	* CGI-FormGenerator 0.9201, the last version of any distribution to include
CGI::HashOfArrays, was released.

2000-07-23   Darren Duncan <perl@DarrenDuncan.net>

	* libdwg 1.0, the first version of any distribution to include
CGI::HashOfArrays, was released on CPAN.

2000-04-21   Darren Duncan <perl@DarrenDuncan.net>

	* Completed primary development on this module.

2000-01-28   Darren Duncan <perl@DarrenDuncan.net>

	* Began development on the final version of this module.

	* Module based on a template created by h2xs 1.18.

1999-07-29 thru 1999-11-13

	* Worked on prototype of code that ended up in this module.