New Upstream Snapshot - libdatetime-format-http-perl

Ready changes

Summary

Merged new upstream version: 0.3801+git20220608.1.6744877 (was: 0.42).

Resulting package

Built on 2022-11-18T16:22 (took 3m32s)

The resulting binary packages can be installed (if you have the apt repository enabled) by running one of:

apt install -t fresh-snapshots libdatetime-format-http-perl

Lintian Result

Diff

diff --git a/Build.PL b/Build.PL
index 01b695c..f83aac8 100644
--- a/Build.PL
+++ b/Build.PL
@@ -1,14 +1,14 @@
-use strict;
-
-use Module::Build;
-
-Module::Build->new( module_name => 'DateTime::Format::HTTP',
-                    dist_author => 'Christiaan Kras <ckras@cpan.org>',
-                    license     => 'perl',
-                    requires    => { 'DateTime'   => '0.17',
-                                     'HTTP::Date' => '1.44',
-                                     'Test::More' => '0.47',
-                                   },
-                    create_readme      => 1,
-                    create_makefile_pl => 'traditional',
-                  )->create_build_script;
+use strict;
+
+use Module::Build;
+
+Module::Build->new( module_name => 'DateTime::Format::HTTP',
+                    dist_author => 'Christiaan Kras <ckras@cpan.org>',
+                    license     => 'perl',
+                    requires    => { 'DateTime'   => '0.17',
+                                     'HTTP::Date' => '1.44',
+                                     'Test::More' => '0.47',
+                                   },
+                    create_readme      => 1,
+                    create_makefile_pl => 'traditional',
+                  )->create_build_script;
diff --git a/CREDITS b/CREDITS
index dbcdb23..9975a74 100644
--- a/CREDITS
+++ b/CREDITS
@@ -1,6 +1,6 @@
-CREDITS FOR DateTime::Format::HTTP 0.35
-
-Gisle Aas (GAAS) for writing HTTP::Date.
-
-Me, for never quite finishing HTTP::Date::XS.
-
+CREDITS FOR DateTime::Format::HTTP 0.35
+
+Gisle Aas (GAAS) for writing HTTP::Date.
+
+Me, for never quite finishing HTTP::Date::XS.
+
diff --git a/Changes b/Changes
index cae9371..5521b34 100644
--- a/Changes
+++ b/Changes
@@ -1,80 +1,80 @@
-0.42  2014-05-02
-
-- Forgot to properly update the version number...
-
-
-0.41  2014-05-02
-
-- Fix out-by-ten bug in nanosecond computation (Stephen Thirlwall)
-
-
-0.40  2010-10-31
-
-- format_isoz now actually changes the time zone. Fixes RT 62332 (DOUGDUDE)
-
-
-0.39  2010-07-03
-
-- No code changes from previous versions.
-
-
-0.38_01  2010-07-01
-
-- Making sure the nanosecond is a integer, and not a float making the creation
-  of a DateTime object fail. Fixes RT 58854 (Christiaan Kras)
-  
-- Repository moved from Subversion to Git. The repository can be located at
-  git://github.com/Htbaa/DateTime-Format-HTTP.git
-
-
-0.38  2009-04-05
-
-- No code changes from previous versions.
-
-- Shut up the verbose diagnostic output from the tests.
-
-- Fixed various bugs in the Build.PL, and generally modernized the
-  distro tarball. Hopefully this will fix problems some cpan testers
-  were seeing.
-
-
-0.37  2006-08-09
-
-- No code changes from previous versions, but there is no SIGNATURE
-  file, because this seems to cause more trouble than it's
-  worth. Fixes RT 17839.
-
-
-0.36  2004-02-10
-
-[ BACKWARDS INCOMPATIBILITY ]
-
-- The default time zone is now the floating time zone, not the local
-  time zone, because we cannot determine the local time zone reliably
-  on all systems.
-
-
-0.3501  2004-01-26
-
-- New maintainer - Dave Rolsky.
-
-- Switched to Module::Build.
-
-
-0.35  2003-08-16
-
-- Removed unused code.
-
-- Added support section to POD.
-
-- Modified wording of license section.
-
-
-0.34  2004-07-07
-
-- Bumped up DT::TZ requirements.
-
-
-0.33  2003-07-02
-
-- Initial release.
+0.42  2014-05-02
+
+- Forgot to properly update the version number...
+
+
+0.41  2014-05-02
+
+- Fix out-by-ten bug in nanosecond computation (Stephen Thirlwall)
+
+
+0.40  2010-10-31
+
+- format_isoz now actually changes the time zone. Fixes RT 62332 (DOUGDUDE)
+
+
+0.39  2010-07-03
+
+- No code changes from previous versions.
+
+
+0.38_01  2010-07-01
+
+- Making sure the nanosecond is a integer, and not a float making the creation
+  of a DateTime object fail. Fixes RT 58854 (Christiaan Kras)
+  
+- Repository moved from Subversion to Git. The repository can be located at
+  git://github.com/Htbaa/DateTime-Format-HTTP.git
+
+
+0.38  2009-04-05
+
+- No code changes from previous versions.
+
+- Shut up the verbose diagnostic output from the tests.
+
+- Fixed various bugs in the Build.PL, and generally modernized the
+  distro tarball. Hopefully this will fix problems some cpan testers
+  were seeing.
+
+
+0.37  2006-08-09
+
+- No code changes from previous versions, but there is no SIGNATURE
+  file, because this seems to cause more trouble than it's
+  worth. Fixes RT 17839.
+
+
+0.36  2004-02-10
+
+[ BACKWARDS INCOMPATIBILITY ]
+
+- The default time zone is now the floating time zone, not the local
+  time zone, because we cannot determine the local time zone reliably
+  on all systems.
+
+
+0.3501  2004-01-26
+
+- New maintainer - Dave Rolsky.
+
+- Switched to Module::Build.
+
+
+0.35  2003-08-16
+
+- Removed unused code.
+
+- Added support section to POD.
+
+- Modified wording of license section.
+
+
+0.34  2004-07-07
+
+- Bumped up DT::TZ requirements.
+
+
+0.33  2003-07-02
+
+- Initial release.
diff --git a/LICENSE b/LICENSE
index 9bb6486..9d0305b 100644
--- a/LICENSE
+++ b/LICENSE
@@ -1,383 +1,383 @@
-Terms of Perl itself
-
-a) the GNU General Public License as published by the Free
-   Software Foundation; either version 1, or (at your option) any
-   later version, or
-b) the "Artistic License"
-
----------------------------------------------------------------------------
-
-The General Public License (GPL)
-Version 2, June 1991
-
-Copyright (C) 1989, 1991 Free Software Foundation, Inc. 675 Mass Ave,
-Cambridge, MA 02139, USA. Everyone is permitted to copy and distribute
-verbatim copies of this license document, but changing it is not allowed.
-
-Preamble
-
-The licenses for most software are designed to take away your freedom to share
-and change it. By contrast, the GNU General Public License is intended to
-guarantee your freedom to share and change free software--to make sure the
-software is free for all its users. This General Public License applies to most of
-the Free Software Foundation's software and to any other program whose
-authors commit to using it. (Some other Free Software Foundation software is
-covered by the GNU Library General Public License instead.) You can apply it to
-your programs, too.
-
-When we speak of free software, we are referring to freedom, not price. Our
-General Public Licenses are designed to make sure that you have the freedom
-to distribute copies of free software (and charge for this service if you wish), that
-you receive source code or can get it if you want it, that you can change the
-software or use pieces of it in new free programs; and that you know you can do
-these things.
-
-To protect your rights, we need to make restrictions that forbid anyone to deny
-you these rights or to ask you to surrender the rights. These restrictions
-translate to certain responsibilities for you if you distribute copies of the
-software, or if you modify it.
-
-For example, if you distribute copies of such a program, whether gratis or for a
-fee, you must give the recipients all the rights that you have. You must make
-sure that they, too, receive or can get the source code. And you must show
-them these terms so they know their rights.
-
-We protect your rights with two steps: (1) copyright the software, and (2) offer
-you this license which gives you legal permission to copy, distribute and/or
-modify the software.
-
-Also, for each author's protection and ours, we want to make certain that
-everyone understands that there is no warranty for this free software. If the
-software is modified by someone else and passed on, we want its recipients to
-know that what they have is not the original, so that any problems introduced by
-others will not reflect on the original authors' reputations.
-
-Finally, any free program is threatened constantly by software patents. We wish
-to avoid the danger that redistributors of a free program will individually obtain
-patent licenses, in effect making the program proprietary. To prevent this, we
-have made it clear that any patent must be licensed for everyone's free use or
-not licensed at all.
-
-The precise terms and conditions for copying, distribution and modification
-follow.
-
-GNU GENERAL PUBLIC LICENSE
-TERMS AND CONDITIONS FOR COPYING, DISTRIBUTION AND
-MODIFICATION
-
-0. This License applies to any program or other work which contains a notice
-placed by the copyright holder saying it may be distributed under the terms of
-this General Public License. The "Program", below, refers to any such program
-or work, and a "work based on the Program" means either the Program or any
-derivative work under copyright law: that is to say, a work containing the
-Program or a portion of it, either verbatim or with modifications and/or translated
-into another language. (Hereinafter, translation is included without limitation in
-the term "modification".) Each licensee is addressed as "you".
-
-Activities other than copying, distribution and modification are not covered by
-this License; they are outside its scope. The act of running the Program is not
-restricted, and the output from the Program is covered only if its contents
-constitute a work based on the Program (independent of having been made by
-running the Program). Whether that is true depends on what the Program does.
-
-1. You may copy and distribute verbatim copies of the Program's source code as
-you receive it, in any medium, provided that you conspicuously and appropriately
-publish on each copy an appropriate copyright notice and disclaimer of warranty;
-keep intact all the notices that refer to this License and to the absence of any
-warranty; and give any other recipients of the Program a copy of this License
-along with the Program.
-
-You may charge a fee for the physical act of transferring a copy, and you may at
-your option offer warranty protection in exchange for a fee.
-
-2. You may modify your copy or copies of the Program or any portion of it, thus
-forming a work based on the Program, and copy and distribute such
-modifications or work under the terms of Section 1 above, provided that you also
-meet all of these conditions:
-
-a) You must cause the modified files to carry prominent notices stating that you
-changed the files and the date of any change.
-
-b) You must cause any work that you distribute or publish, that in whole or in
-part contains or is derived from the Program or any part thereof, to be licensed
-as a whole at no charge to all third parties under the terms of this License.
-
-c) If the modified program normally reads commands interactively when run, you
-must cause it, when started running for such interactive use in the most ordinary
-way, to print or display an announcement including an appropriate copyright
-notice and a notice that there is no warranty (or else, saying that you provide a
-warranty) and that users may redistribute the program under these conditions,
-and telling the user how to view a copy of this License. (Exception: if the
-Program itself is interactive but does not normally print such an announcement,
-your work based on the Program is not required to print an announcement.)
-
-These requirements apply to the modified work as a whole. If identifiable
-sections of that work are not derived from the Program, and can be reasonably
-considered independent and separate works in themselves, then this License,
-and its terms, do not apply to those sections when you distribute them as
-separate works. But when you distribute the same sections as part of a whole
-which is a work based on the Program, the distribution of the whole must be on
-the terms of this License, whose permissions for other licensees extend to the
-entire whole, and thus to each and every part regardless of who wrote it.
-
-Thus, it is not the intent of this section to claim rights or contest your rights to
-work written entirely by you; rather, the intent is to exercise the right to control
-the distribution of derivative or collective works based on the Program.
-
-In addition, mere aggregation of another work not based on the Program with the
-Program (or with a work based on the Program) on a volume of a storage or
-distribution medium does not bring the other work under the scope of this
-License.
-
-3. You may copy and distribute the Program (or a work based on it, under
-Section 2) in object code or executable form under the terms of Sections 1 and 2
-above provided that you also do one of the following:
-
-a) Accompany it with the complete corresponding machine-readable source
-code, which must be distributed under the terms of Sections 1 and 2 above on a
-medium customarily used for software interchange; or,
-
-b) Accompany it with a written offer, valid for at least three years, to give any
-third party, for a charge no more than your cost of physically performing source
-distribution, a complete machine-readable copy of the corresponding source
-code, to be distributed under the terms of Sections 1 and 2 above on a medium
-customarily used for software interchange; or,
-
-c) Accompany it with the information you received as to the offer to distribute
-corresponding source code. (This alternative is allowed only for noncommercial
-distribution and only if you received the program in object code or executable
-form with such an offer, in accord with Subsection b above.)
-
-The source code for a work means the preferred form of the work for making
-modifications to it. For an executable work, complete source code means all the
-source code for all modules it contains, plus any associated interface definition
-files, plus the scripts used to control compilation and installation of the
-executable. However, as a special exception, the source code distributed need
-not include anything that is normally distributed (in either source or binary form)
-with the major components (compiler, kernel, and so on) of the operating system
-on which the executable runs, unless that component itself accompanies the
-executable.
-
-If distribution of executable or object code is made by offering access to copy
-from a designated place, then offering equivalent access to copy the source
-code from the same place counts as distribution of the source code, even though
-third parties are not compelled to copy the source along with the object code.
-
-4. You may not copy, modify, sublicense, or distribute the Program except as
-expressly provided under this License. Any attempt otherwise to copy, modify,
-sublicense or distribute the Program is void, and will automatically terminate
-your rights under this License. However, parties who have received copies, or
-rights, from you under this License will not have their licenses terminated so long
-as such parties remain in full compliance.
-
-5. You are not required to accept this License, since you have not signed it.
-However, nothing else grants you permission to modify or distribute the Program
-or its derivative works. These actions are prohibited by law if you do not accept
-this License. Therefore, by modifying or distributing the Program (or any work
-based on the Program), you indicate your acceptance of this License to do so,
-and all its terms and conditions for copying, distributing or modifying the
-Program or works based on it.
-
-6. Each time you redistribute the Program (or any work based on the Program),
-the recipient automatically receives a license from the original licensor to copy,
-distribute or modify the Program subject to these terms and conditions. You
-may not impose any further restrictions on the recipients' exercise of the rights
-granted herein. You are not responsible for enforcing compliance by third parties
-to this License.
-
-7. If, as a consequence of a court judgment or allegation of patent infringement
-or for any other reason (not limited to patent issues), conditions are imposed on
-you (whether by court order, agreement or otherwise) that contradict the
-conditions of this License, they do not excuse you from the conditions of this
-License. If you cannot distribute so as to satisfy simultaneously your obligations
-under this License and any other pertinent obligations, then as a consequence
-you may not distribute the Program at all. For example, if a patent license would
-not permit royalty-free redistribution of the Program by all those who receive
-copies directly or indirectly through you, then the only way you could satisfy
-both it and this License would be to refrain entirely from distribution of the
-Program.
-
-If any portion of this section is held invalid or unenforceable under any particular
-circumstance, the balance of the section is intended to apply and the section as
-a whole is intended to apply in other circumstances.
-
-It is not the purpose of this section to induce you to infringe any patents or other
-property right claims or to contest validity of any such claims; this section has
-the sole purpose of protecting the integrity of the free software distribution
-system, which is implemented by public license practices. Many people have
-made generous contributions to the wide range of software distributed through
-that system in reliance on consistent application of that system; it is up to the
-author/donor to decide if he or she is willing to distribute software through any
-other system and a licensee cannot impose that choice.
-
-This section is intended to make thoroughly clear what is believed to be a
-consequence of the rest of this License.
-
-8. If the distribution and/or use of the Program is restricted in certain countries
-either by patents or by copyrighted interfaces, the original copyright holder who
-places the Program under this License may add an explicit geographical
-distribution limitation excluding those countries, so that distribution is permitted
-only in or among countries not thus excluded. In such case, this License
-incorporates the limitation as if written in the body of this License.
-
-9. The Free Software Foundation may publish revised and/or new versions of the
-General Public License from time to time. Such new versions will be similar in
-spirit to the present version, but may differ in detail to address new problems or
-concerns.
-
-Each version is given a distinguishing version number. If the Program specifies a
-version number of this License which applies to it and "any later version", you
-have the option of following the terms and conditions either of that version or of
-any later version published by the Free Software Foundation. If the Program does
-not specify a version number of this License, you may choose any version ever
-published by the Free Software Foundation.
-
-10. If you wish to incorporate parts of the Program into other free programs
-whose distribution conditions are different, write to the author to ask for
-permission. For software which is copyrighted by the Free Software Foundation,
-write to the Free Software Foundation; we sometimes make exceptions for this.
-Our decision will be guided by the two goals of preserving the free status of all
-derivatives of our free software and of promoting the sharing and reuse of
-software generally.
-
-NO WARRANTY
-
-11. BECAUSE THE PROGRAM IS LICENSED FREE OF CHARGE, THERE IS
-NO WARRANTY FOR THE PROGRAM, TO THE EXTENT PERMITTED BY
-APPLICABLE LAW. EXCEPT WHEN OTHERWISE STATED IN WRITING THE
-COPYRIGHT HOLDERS AND/OR OTHER PARTIES PROVIDE THE PROGRAM
-"AS IS" WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESSED OR
-IMPLIED, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
-MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. THE
-ENTIRE RISK AS TO THE QUALITY AND PERFORMANCE OF THE
-PROGRAM IS WITH YOU. SHOULD THE PROGRAM PROVE DEFECTIVE,
-YOU ASSUME THE COST OF ALL NECESSARY SERVICING, REPAIR OR
-CORRECTION.
-
-12. IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED
-TO IN WRITING WILL ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY
-WHO MAY MODIFY AND/OR REDISTRIBUTE THE PROGRAM AS
-PERMITTED ABOVE, BE LIABLE TO YOU FOR DAMAGES, INCLUDING ANY
-GENERAL, SPECIAL, INCIDENTAL OR CONSEQUENTIAL DAMAGES
-ARISING OUT OF THE USE OR INABILITY TO USE THE PROGRAM
-(INCLUDING BUT NOT LIMITED TO LOSS OF DATA OR DATA BEING
-RENDERED INACCURATE OR LOSSES SUSTAINED BY YOU OR THIRD
-PARTIES OR A FAILURE OF THE PROGRAM TO OPERATE WITH ANY
-OTHER PROGRAMS), EVEN IF SUCH HOLDER OR OTHER PARTY HAS
-BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGES.
-
-END OF TERMS AND CONDITIONS
-
-
----------------------------------------------------------------------------
-
-The Artistic License
-
-Preamble
-
-The intent of this document is to state the conditions under which a Package
-may be copied, such that the Copyright Holder maintains some semblance of
-artistic control over the development of the package, while giving the users of the
-package the right to use and distribute the Package in a more-or-less customary
-fashion, plus the right to make reasonable modifications.
-
-Definitions:
-
--    "Package" refers to the collection of files distributed by the Copyright
-     Holder, and derivatives of that collection of files created through textual
-     modification. 
--    "Standard Version" refers to such a Package if it has not been modified,
-     or has been modified in accordance with the wishes of the Copyright
-     Holder. 
--    "Copyright Holder" is whoever is named in the copyright or copyrights for
-     the package. 
--    "You" is you, if you're thinking about copying or distributing this Package.
--    "Reasonable copying fee" is whatever you can justify on the basis of
-     media cost, duplication charges, time of people involved, and so on. (You
-     will not be required to justify it to the Copyright Holder, but only to the
-     computing community at large as a market that must bear the fee.) 
--    "Freely Available" means that no fee is charged for the item itself, though
-     there may be fees involved in handling the item. It also means that
-     recipients of the item may redistribute it under the same conditions they
-     received it. 
-
-1. You may make and give away verbatim copies of the source form of the
-Standard Version of this Package without restriction, provided that you duplicate
-all of the original copyright notices and associated disclaimers.
-
-2. You may apply bug fixes, portability fixes and other modifications derived from
-the Public Domain or from the Copyright Holder. A Package modified in such a
-way shall still be considered the Standard Version.
-
-3. You may otherwise modify your copy of this Package in any way, provided
-that you insert a prominent notice in each changed file stating how and when
-you changed that file, and provided that you do at least ONE of the following:
-
-     a) place your modifications in the Public Domain or otherwise
-     make them Freely Available, such as by posting said modifications
-     to Usenet or an equivalent medium, or placing the modifications on
-     a major archive site such as ftp.uu.net, or by allowing the
-     Copyright Holder to include your modifications in the Standard
-     Version of the Package.
-
-     b) use the modified Package only within your corporation or
-     organization.
-
-     c) rename any non-standard executables so the names do not
-     conflict with standard executables, which must also be provided,
-     and provide a separate manual page for each non-standard
-     executable that clearly documents how it differs from the Standard
-     Version.
-
-     d) make other distribution arrangements with the Copyright Holder.
-
-4. You may distribute the programs of this Package in object code or executable
-form, provided that you do at least ONE of the following:
-
-     a) distribute a Standard Version of the executables and library
-     files, together with instructions (in the manual page or equivalent)
-     on where to get the Standard Version.
-
-     b) accompany the distribution with the machine-readable source of
-     the Package with your modifications.
-
-     c) accompany any non-standard executables with their
-     corresponding Standard Version executables, giving the
-     non-standard executables non-standard names, and clearly
-     documenting the differences in manual pages (or equivalent),
-     together with instructions on where to get the Standard Version.
-
-     d) make other distribution arrangements with the Copyright Holder.
-
-5. You may charge a reasonable copying fee for any distribution of this Package.
-You may charge any fee you choose for support of this Package. You may not
-charge a fee for this Package itself. However, you may distribute this Package in
-aggregate with other (possibly commercial) programs as part of a larger
-(possibly commercial) software distribution provided that you do not advertise
-this Package as a product of your own.
-
-6. The scripts and library files supplied as input to or produced as output from
-the programs of this Package do not automatically fall under the copyright of this
-Package, but belong to whomever generated them, and may be sold
-commercially, and may be aggregated with this Package.
-
-7. C or perl subroutines supplied by you and linked into this Package shall not
-be considered part of this Package.
-
-8. Aggregation of this Package with a commercial distribution is always permitted
-provided that the use of this Package is embedded; that is, when no overt attempt
-is made to make this Package's interfaces visible to the end user of the
-commercial distribution. Such use shall not be construed as a distribution of
-this Package.
-
-9. The name of the Copyright Holder may not be used to endorse or promote
-products derived from this software without specific prior written permission.
-
-10. THIS PACKAGE IS PROVIDED "AS IS" AND WITHOUT ANY EXPRESS OR
-IMPLIED WARRANTIES, INCLUDING, WITHOUT LIMITATION, THE IMPLIED
-WARRANTIES OF MERCHANTIBILITY AND FITNESS FOR A PARTICULAR
-PURPOSE.
-
-The End
-
-
+Terms of Perl itself
+
+a) the GNU General Public License as published by the Free
+   Software Foundation; either version 1, or (at your option) any
+   later version, or
+b) the "Artistic License"
+
+---------------------------------------------------------------------------
+
+The General Public License (GPL)
+Version 2, June 1991
+
+Copyright (C) 1989, 1991 Free Software Foundation, Inc. 675 Mass Ave,
+Cambridge, MA 02139, USA. Everyone is permitted to copy and distribute
+verbatim copies of this license document, but changing it is not allowed.
+
+Preamble
+
+The licenses for most software are designed to take away your freedom to share
+and change it. By contrast, the GNU General Public License is intended to
+guarantee your freedom to share and change free software--to make sure the
+software is free for all its users. This General Public License applies to most of
+the Free Software Foundation's software and to any other program whose
+authors commit to using it. (Some other Free Software Foundation software is
+covered by the GNU Library General Public License instead.) You can apply it to
+your programs, too.
+
+When we speak of free software, we are referring to freedom, not price. Our
+General Public Licenses are designed to make sure that you have the freedom
+to distribute copies of free software (and charge for this service if you wish), that
+you receive source code or can get it if you want it, that you can change the
+software or use pieces of it in new free programs; and that you know you can do
+these things.
+
+To protect your rights, we need to make restrictions that forbid anyone to deny
+you these rights or to ask you to surrender the rights. These restrictions
+translate to certain responsibilities for you if you distribute copies of the
+software, or if you modify it.
+
+For example, if you distribute copies of such a program, whether gratis or for a
+fee, you must give the recipients all the rights that you have. You must make
+sure that they, too, receive or can get the source code. And you must show
+them these terms so they know their rights.
+
+We protect your rights with two steps: (1) copyright the software, and (2) offer
+you this license which gives you legal permission to copy, distribute and/or
+modify the software.
+
+Also, for each author's protection and ours, we want to make certain that
+everyone understands that there is no warranty for this free software. If the
+software is modified by someone else and passed on, we want its recipients to
+know that what they have is not the original, so that any problems introduced by
+others will not reflect on the original authors' reputations.
+
+Finally, any free program is threatened constantly by software patents. We wish
+to avoid the danger that redistributors of a free program will individually obtain
+patent licenses, in effect making the program proprietary. To prevent this, we
+have made it clear that any patent must be licensed for everyone's free use or
+not licensed at all.
+
+The precise terms and conditions for copying, distribution and modification
+follow.
+
+GNU GENERAL PUBLIC LICENSE
+TERMS AND CONDITIONS FOR COPYING, DISTRIBUTION AND
+MODIFICATION
+
+0. This License applies to any program or other work which contains a notice
+placed by the copyright holder saying it may be distributed under the terms of
+this General Public License. The "Program", below, refers to any such program
+or work, and a "work based on the Program" means either the Program or any
+derivative work under copyright law: that is to say, a work containing the
+Program or a portion of it, either verbatim or with modifications and/or translated
+into another language. (Hereinafter, translation is included without limitation in
+the term "modification".) Each licensee is addressed as "you".
+
+Activities other than copying, distribution and modification are not covered by
+this License; they are outside its scope. The act of running the Program is not
+restricted, and the output from the Program is covered only if its contents
+constitute a work based on the Program (independent of having been made by
+running the Program). Whether that is true depends on what the Program does.
+
+1. You may copy and distribute verbatim copies of the Program's source code as
+you receive it, in any medium, provided that you conspicuously and appropriately
+publish on each copy an appropriate copyright notice and disclaimer of warranty;
+keep intact all the notices that refer to this License and to the absence of any
+warranty; and give any other recipients of the Program a copy of this License
+along with the Program.
+
+You may charge a fee for the physical act of transferring a copy, and you may at
+your option offer warranty protection in exchange for a fee.
+
+2. You may modify your copy or copies of the Program or any portion of it, thus
+forming a work based on the Program, and copy and distribute such
+modifications or work under the terms of Section 1 above, provided that you also
+meet all of these conditions:
+
+a) You must cause the modified files to carry prominent notices stating that you
+changed the files and the date of any change.
+
+b) You must cause any work that you distribute or publish, that in whole or in
+part contains or is derived from the Program or any part thereof, to be licensed
+as a whole at no charge to all third parties under the terms of this License.
+
+c) If the modified program normally reads commands interactively when run, you
+must cause it, when started running for such interactive use in the most ordinary
+way, to print or display an announcement including an appropriate copyright
+notice and a notice that there is no warranty (or else, saying that you provide a
+warranty) and that users may redistribute the program under these conditions,
+and telling the user how to view a copy of this License. (Exception: if the
+Program itself is interactive but does not normally print such an announcement,
+your work based on the Program is not required to print an announcement.)
+
+These requirements apply to the modified work as a whole. If identifiable
+sections of that work are not derived from the Program, and can be reasonably
+considered independent and separate works in themselves, then this License,
+and its terms, do not apply to those sections when you distribute them as
+separate works. But when you distribute the same sections as part of a whole
+which is a work based on the Program, the distribution of the whole must be on
+the terms of this License, whose permissions for other licensees extend to the
+entire whole, and thus to each and every part regardless of who wrote it.
+
+Thus, it is not the intent of this section to claim rights or contest your rights to
+work written entirely by you; rather, the intent is to exercise the right to control
+the distribution of derivative or collective works based on the Program.
+
+In addition, mere aggregation of another work not based on the Program with the
+Program (or with a work based on the Program) on a volume of a storage or
+distribution medium does not bring the other work under the scope of this
+License.
+
+3. You may copy and distribute the Program (or a work based on it, under
+Section 2) in object code or executable form under the terms of Sections 1 and 2
+above provided that you also do one of the following:
+
+a) Accompany it with the complete corresponding machine-readable source
+code, which must be distributed under the terms of Sections 1 and 2 above on a
+medium customarily used for software interchange; or,
+
+b) Accompany it with a written offer, valid for at least three years, to give any
+third party, for a charge no more than your cost of physically performing source
+distribution, a complete machine-readable copy of the corresponding source
+code, to be distributed under the terms of Sections 1 and 2 above on a medium
+customarily used for software interchange; or,
+
+c) Accompany it with the information you received as to the offer to distribute
+corresponding source code. (This alternative is allowed only for noncommercial
+distribution and only if you received the program in object code or executable
+form with such an offer, in accord with Subsection b above.)
+
+The source code for a work means the preferred form of the work for making
+modifications to it. For an executable work, complete source code means all the
+source code for all modules it contains, plus any associated interface definition
+files, plus the scripts used to control compilation and installation of the
+executable. However, as a special exception, the source code distributed need
+not include anything that is normally distributed (in either source or binary form)
+with the major components (compiler, kernel, and so on) of the operating system
+on which the executable runs, unless that component itself accompanies the
+executable.
+
+If distribution of executable or object code is made by offering access to copy
+from a designated place, then offering equivalent access to copy the source
+code from the same place counts as distribution of the source code, even though
+third parties are not compelled to copy the source along with the object code.
+
+4. You may not copy, modify, sublicense, or distribute the Program except as
+expressly provided under this License. Any attempt otherwise to copy, modify,
+sublicense or distribute the Program is void, and will automatically terminate
+your rights under this License. However, parties who have received copies, or
+rights, from you under this License will not have their licenses terminated so long
+as such parties remain in full compliance.
+
+5. You are not required to accept this License, since you have not signed it.
+However, nothing else grants you permission to modify or distribute the Program
+or its derivative works. These actions are prohibited by law if you do not accept
+this License. Therefore, by modifying or distributing the Program (or any work
+based on the Program), you indicate your acceptance of this License to do so,
+and all its terms and conditions for copying, distributing or modifying the
+Program or works based on it.
+
+6. Each time you redistribute the Program (or any work based on the Program),
+the recipient automatically receives a license from the original licensor to copy,
+distribute or modify the Program subject to these terms and conditions. You
+may not impose any further restrictions on the recipients' exercise of the rights
+granted herein. You are not responsible for enforcing compliance by third parties
+to this License.
+
+7. If, as a consequence of a court judgment or allegation of patent infringement
+or for any other reason (not limited to patent issues), conditions are imposed on
+you (whether by court order, agreement or otherwise) that contradict the
+conditions of this License, they do not excuse you from the conditions of this
+License. If you cannot distribute so as to satisfy simultaneously your obligations
+under this License and any other pertinent obligations, then as a consequence
+you may not distribute the Program at all. For example, if a patent license would
+not permit royalty-free redistribution of the Program by all those who receive
+copies directly or indirectly through you, then the only way you could satisfy
+both it and this License would be to refrain entirely from distribution of the
+Program.
+
+If any portion of this section is held invalid or unenforceable under any particular
+circumstance, the balance of the section is intended to apply and the section as
+a whole is intended to apply in other circumstances.
+
+It is not the purpose of this section to induce you to infringe any patents or other
+property right claims or to contest validity of any such claims; this section has
+the sole purpose of protecting the integrity of the free software distribution
+system, which is implemented by public license practices. Many people have
+made generous contributions to the wide range of software distributed through
+that system in reliance on consistent application of that system; it is up to the
+author/donor to decide if he or she is willing to distribute software through any
+other system and a licensee cannot impose that choice.
+
+This section is intended to make thoroughly clear what is believed to be a
+consequence of the rest of this License.
+
+8. If the distribution and/or use of the Program is restricted in certain countries
+either by patents or by copyrighted interfaces, the original copyright holder who
+places the Program under this License may add an explicit geographical
+distribution limitation excluding those countries, so that distribution is permitted
+only in or among countries not thus excluded. In such case, this License
+incorporates the limitation as if written in the body of this License.
+
+9. The Free Software Foundation may publish revised and/or new versions of the
+General Public License from time to time. Such new versions will be similar in
+spirit to the present version, but may differ in detail to address new problems or
+concerns.
+
+Each version is given a distinguishing version number. If the Program specifies a
+version number of this License which applies to it and "any later version", you
+have the option of following the terms and conditions either of that version or of
+any later version published by the Free Software Foundation. If the Program does
+not specify a version number of this License, you may choose any version ever
+published by the Free Software Foundation.
+
+10. If you wish to incorporate parts of the Program into other free programs
+whose distribution conditions are different, write to the author to ask for
+permission. For software which is copyrighted by the Free Software Foundation,
+write to the Free Software Foundation; we sometimes make exceptions for this.
+Our decision will be guided by the two goals of preserving the free status of all
+derivatives of our free software and of promoting the sharing and reuse of
+software generally.
+
+NO WARRANTY
+
+11. BECAUSE THE PROGRAM IS LICENSED FREE OF CHARGE, THERE IS
+NO WARRANTY FOR THE PROGRAM, TO THE EXTENT PERMITTED BY
+APPLICABLE LAW. EXCEPT WHEN OTHERWISE STATED IN WRITING THE
+COPYRIGHT HOLDERS AND/OR OTHER PARTIES PROVIDE THE PROGRAM
+"AS IS" WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESSED OR
+IMPLIED, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
+MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. THE
+ENTIRE RISK AS TO THE QUALITY AND PERFORMANCE OF THE
+PROGRAM IS WITH YOU. SHOULD THE PROGRAM PROVE DEFECTIVE,
+YOU ASSUME THE COST OF ALL NECESSARY SERVICING, REPAIR OR
+CORRECTION.
+
+12. IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED
+TO IN WRITING WILL ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY
+WHO MAY MODIFY AND/OR REDISTRIBUTE THE PROGRAM AS
+PERMITTED ABOVE, BE LIABLE TO YOU FOR DAMAGES, INCLUDING ANY
+GENERAL, SPECIAL, INCIDENTAL OR CONSEQUENTIAL DAMAGES
+ARISING OUT OF THE USE OR INABILITY TO USE THE PROGRAM
+(INCLUDING BUT NOT LIMITED TO LOSS OF DATA OR DATA BEING
+RENDERED INACCURATE OR LOSSES SUSTAINED BY YOU OR THIRD
+PARTIES OR A FAILURE OF THE PROGRAM TO OPERATE WITH ANY
+OTHER PROGRAMS), EVEN IF SUCH HOLDER OR OTHER PARTY HAS
+BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGES.
+
+END OF TERMS AND CONDITIONS
+
+
+---------------------------------------------------------------------------
+
+The Artistic License
+
+Preamble
+
+The intent of this document is to state the conditions under which a Package
+may be copied, such that the Copyright Holder maintains some semblance of
+artistic control over the development of the package, while giving the users of the
+package the right to use and distribute the Package in a more-or-less customary
+fashion, plus the right to make reasonable modifications.
+
+Definitions:
+
+-    "Package" refers to the collection of files distributed by the Copyright
+     Holder, and derivatives of that collection of files created through textual
+     modification. 
+-    "Standard Version" refers to such a Package if it has not been modified,
+     or has been modified in accordance with the wishes of the Copyright
+     Holder. 
+-    "Copyright Holder" is whoever is named in the copyright or copyrights for
+     the package. 
+-    "You" is you, if you're thinking about copying or distributing this Package.
+-    "Reasonable copying fee" is whatever you can justify on the basis of
+     media cost, duplication charges, time of people involved, and so on. (You
+     will not be required to justify it to the Copyright Holder, but only to the
+     computing community at large as a market that must bear the fee.) 
+-    "Freely Available" means that no fee is charged for the item itself, though
+     there may be fees involved in handling the item. It also means that
+     recipients of the item may redistribute it under the same conditions they
+     received it. 
+
+1. You may make and give away verbatim copies of the source form of the
+Standard Version of this Package without restriction, provided that you duplicate
+all of the original copyright notices and associated disclaimers.
+
+2. You may apply bug fixes, portability fixes and other modifications derived from
+the Public Domain or from the Copyright Holder. A Package modified in such a
+way shall still be considered the Standard Version.
+
+3. You may otherwise modify your copy of this Package in any way, provided
+that you insert a prominent notice in each changed file stating how and when
+you changed that file, and provided that you do at least ONE of the following:
+
+     a) place your modifications in the Public Domain or otherwise
+     make them Freely Available, such as by posting said modifications
+     to Usenet or an equivalent medium, or placing the modifications on
+     a major archive site such as ftp.uu.net, or by allowing the
+     Copyright Holder to include your modifications in the Standard
+     Version of the Package.
+
+     b) use the modified Package only within your corporation or
+     organization.
+
+     c) rename any non-standard executables so the names do not
+     conflict with standard executables, which must also be provided,
+     and provide a separate manual page for each non-standard
+     executable that clearly documents how it differs from the Standard
+     Version.
+
+     d) make other distribution arrangements with the Copyright Holder.
+
+4. You may distribute the programs of this Package in object code or executable
+form, provided that you do at least ONE of the following:
+
+     a) distribute a Standard Version of the executables and library
+     files, together with instructions (in the manual page or equivalent)
+     on where to get the Standard Version.
+
+     b) accompany the distribution with the machine-readable source of
+     the Package with your modifications.
+
+     c) accompany any non-standard executables with their
+     corresponding Standard Version executables, giving the
+     non-standard executables non-standard names, and clearly
+     documenting the differences in manual pages (or equivalent),
+     together with instructions on where to get the Standard Version.
+
+     d) make other distribution arrangements with the Copyright Holder.
+
+5. You may charge a reasonable copying fee for any distribution of this Package.
+You may charge any fee you choose for support of this Package. You may not
+charge a fee for this Package itself. However, you may distribute this Package in
+aggregate with other (possibly commercial) programs as part of a larger
+(possibly commercial) software distribution provided that you do not advertise
+this Package as a product of your own.
+
+6. The scripts and library files supplied as input to or produced as output from
+the programs of this Package do not automatically fall under the copyright of this
+Package, but belong to whomever generated them, and may be sold
+commercially, and may be aggregated with this Package.
+
+7. C or perl subroutines supplied by you and linked into this Package shall not
+be considered part of this Package.
+
+8. Aggregation of this Package with a commercial distribution is always permitted
+provided that the use of this Package is embedded; that is, when no overt attempt
+is made to make this Package's interfaces visible to the end user of the
+commercial distribution. Such use shall not be construed as a distribution of
+this Package.
+
+9. The name of the Copyright Holder may not be used to endorse or promote
+products derived from this software without specific prior written permission.
+
+10. THIS PACKAGE IS PROVIDED "AS IS" AND WITHOUT ANY EXPRESS OR
+IMPLIED WARRANTIES, INCLUDING, WITHOUT LIMITATION, THE IMPLIED
+WARRANTIES OF MERCHANTIBILITY AND FITNESS FOR A PARTICULAR
+PURPOSE.
+
+The End
+
+
diff --git a/MANIFEST b/MANIFEST
index e9df526..802adc2 100644
--- a/MANIFEST
+++ b/MANIFEST
@@ -1,15 +1,16 @@
-Build.PL
-Changes
-CREDITS
-lib/DateTime/Format/HTTP.pm
-LICENSE
-Makefile.PL
-MANIFEST			This list of files
-META.json
-META.yml
-README
-t/basic.t
-t/date.t
-t/pod-coverage.t
-t/pod.t
-t/time2str.t
+Build.PL
+Changes
+CREDITS
+lib/DateTime/Format/HTTP.pm
+LICENSE
+Makefile.PL
+MANIFEST			This list of files
+META.json
+META.yml
+README
+README.md
+t/basic.t
+t/date.t
+t/pod-coverage.t
+t/pod.t
+t/time2str.t
diff --git a/META.json b/META.json
index 0ea0c89..1b05d4b 100644
--- a/META.json
+++ b/META.json
@@ -1,43 +1,44 @@
-{
-   "abstract" : "Date conversion routines",
-   "author" : [
-      "Christiaan Kras <ckras@cpan.org>"
-   ],
-   "dynamic_config" : 1,
-   "generated_by" : "Module::Build version 0.38, CPAN::Meta::Converter version 2.133380",
-   "license" : [
-      "perl_5"
-   ],
-   "meta-spec" : {
-      "url" : "http://search.cpan.org/perldoc?CPAN::Meta::Spec",
-      "version" : "2"
-   },
-   "name" : "DateTime-Format-HTTP",
-   "prereqs" : {
-      "configure" : {
-         "requires" : {
-            "Module::Build" : "0.38"
-         }
-      },
-      "runtime" : {
-         "requires" : {
-            "DateTime" : "0.17",
-            "HTTP::Date" : "1.44",
-            "Test::More" : "0.47"
-         }
-      }
-   },
-   "provides" : {
-      "DateTime::Format::HTTP" : {
-         "file" : "lib/DateTime/Format/HTTP.pm",
-         "version" : "0.42"
-      }
-   },
-   "release_status" : "stable",
-   "resources" : {
-      "license" : [
-         "http://dev.perl.org/licenses/"
-      ]
-   },
-   "version" : "0.42"
-}
+{
+   "abstract" : "Date conversion routines",
+   "author" : [
+      "Christiaan Kras <ckras@cpan.org>"
+   ],
+   "dynamic_config" : 1,
+   "generated_by" : "Module::Build version 0.4231",
+   "license" : [
+      "perl_5"
+   ],
+   "meta-spec" : {
+      "url" : "http://search.cpan.org/perldoc?CPAN::Meta::Spec",
+      "version" : 2
+   },
+   "name" : "DateTime-Format-HTTP",
+   "prereqs" : {
+      "configure" : {
+         "requires" : {
+            "Module::Build" : "0.42"
+         }
+      },
+      "runtime" : {
+         "requires" : {
+            "DateTime" : "0.17",
+            "HTTP::Date" : "1.44",
+            "Test::More" : "0.47"
+         }
+      }
+   },
+   "provides" : {
+      "DateTime::Format::HTTP" : {
+         "file" : "lib/DateTime/Format/HTTP.pm",
+         "version" : "0.42"
+      }
+   },
+   "release_status" : "stable",
+   "resources" : {
+      "license" : [
+         "http://dev.perl.org/licenses/"
+      ]
+   },
+   "version" : "0.42",
+   "x_serialization_backend" : "JSON::PP version 4.07"
+}
diff --git a/META.yml b/META.yml
index 1c87abd..d8439f3 100644
--- a/META.yml
+++ b/META.yml
@@ -1,25 +1,26 @@
----
-abstract: Date conversion routines
-author:
-  - 'Christiaan Kras <ckras@cpan.org>'
-build_requires: {}
-configure_requires:
-  Module::Build: 0.38
-dynamic_config: 1
-generated_by: 'Module::Build version 0.38, CPAN::Meta::Converter version 2.133380'
-license: perl
-meta-spec:
-  url: http://module-build.sourceforge.net/META-spec-v1.4.html
-  version: 1.4
-name: DateTime-Format-HTTP
-provides:
-  DateTime::Format::HTTP:
-    file: lib/DateTime/Format/HTTP.pm
-    version: 0.42
-requires:
-  DateTime: 0.17
-  HTTP::Date: 1.44
-  Test::More: 0.47
-resources:
-  license: http://dev.perl.org/licenses/
-version: 0.42
+---
+abstract: 'Date conversion routines'
+author:
+  - 'Christiaan Kras <ckras@cpan.org>'
+build_requires: {}
+configure_requires:
+  Module::Build: '0.42'
+dynamic_config: 1
+generated_by: 'Module::Build version 0.4231, CPAN::Meta::Converter version 2.150010'
+license: perl
+meta-spec:
+  url: http://module-build.sourceforge.net/META-spec-v1.4.html
+  version: '1.4'
+name: DateTime-Format-HTTP
+provides:
+  DateTime::Format::HTTP:
+    file: lib/DateTime/Format/HTTP.pm
+    version: '0.42'
+requires:
+  DateTime: '0.17'
+  HTTP::Date: '1.44'
+  Test::More: '0.47'
+resources:
+  license: http://dev.perl.org/licenses/
+version: '0.42'
+x_serialization_backend: 'CPAN::Meta::YAML version 0.018'
diff --git a/Makefile.PL b/Makefile.PL
index eb88ba0..2cf35ec 100644
--- a/Makefile.PL
+++ b/Makefile.PL
@@ -1,16 +1,16 @@
-# Note: this file was auto-generated by Module::Build::Compat version 0.3800
-use ExtUtils::MakeMaker;
-WriteMakefile
-(
-  'PL_FILES' => {},
-  'INSTALLDIRS' => 'site',
-  'NAME' => 'DateTime::Format::HTTP',
-  'EXE_FILES' => [],
-  'VERSION_FROM' => 'lib/DateTime/Format/HTTP.pm',
-  'PREREQ_PM' => {
-                   'Test::More' => '0.47',
-                   'DateTime' => '0.17',
-                   'HTTP::Date' => '1.44'
-                 }
-)
-;
+# Note: this file was auto-generated by Module::Build::Compat version 0.4231
+use ExtUtils::MakeMaker;
+WriteMakefile
+(
+  'INSTALLDIRS' => 'site',
+  'PL_FILES' => {},
+  'PREREQ_PM' => {
+                   'DateTime' => '0.17',
+                   'HTTP::Date' => '1.44',
+                   'Test::More' => '0.47'
+                 },
+  'EXE_FILES' => [],
+  'VERSION_FROM' => 'lib/DateTime/Format/HTTP.pm',
+  'NAME' => 'DateTime::Format::HTTP'
+)
+;
diff --git a/README b/README
index 687d8f9..7bd3fed 100644
--- a/README
+++ b/README
@@ -1,134 +1,147 @@
-NAME
-    DateTime::Format::HTTP - Date conversion routines
-
-SYNOPSIS
-        use DateTime::Format::HTTP;
-
-        my $class = 'DateTime::Format::HTTP';
-        $string = $class->format_datetime($dt); # Format as GMT ASCII time
-        $time = $class->parse_datetime($string); # convert ASCII date to machine time
-
-DESCRIPTION
-    This module provides functions that deal the date formats used by the
-    HTTP protocol (and then some more).
-
-METHODS
-  parse_datetime( $str [, $zone] )
-    The parse_datetime() function converts a string to machine time. It
-    throws an error if the format of $str is unrecognized, or the time is
-    outside the representable range. The time formats recognized are listed
-    below.
-
-    The function also takes an optional second argument that specifies the
-    default time zone to use when converting the date. This parameter is
-    ignored if the zone is found in the date string itself. If this
-    parameter is missing, and the date string format does not contain any
-    zone specification, then the floating time zone is used.
-
-    The zone should be one that is recognized by DateTime::TimeZone.
-
-    Actual parsing is done with the HTTP::Date module. At the time of
-    writing it supports the formats listed next. Consult that module's
-    documentation in case the list has been changed.
-
-     "Wed, 09 Feb 1994 22:23:32 GMT"       -- HTTP format
-     "Thu Feb  3 17:03:55 GMT 1994"        -- ctime(3) format
-     "Thu Feb  3 00:00:00 1994",           -- ANSI C asctime() format
-     "Tuesday, 08-Feb-94 14:15:29 GMT"     -- old rfc850 HTTP format
-     "Tuesday, 08-Feb-1994 14:15:29 GMT"   -- broken rfc850 HTTP format
-
-     "03/Feb/1994:17:03:55 -0700"   -- common logfile format
-     "09 Feb 1994 22:23:32 GMT"     -- HTTP format (no weekday)
-     "08-Feb-94 14:15:29 GMT"       -- rfc850 format (no weekday)
-     "08-Feb-1994 14:15:29 GMT"     -- broken rfc850 format (no weekday)
-
-     "1994-02-03 14:15:29 -0100"    -- ISO 8601 format
-     "1994-02-03 14:15:29"          -- zone is optional
-     "1994-02-03"                   -- only date
-     "1994-02-03T14:15:29"          -- Use T as separator
-     "19940203T141529Z"             -- ISO 8601 compact format
-     "19940203"                     -- only date
-
-     "08-Feb-94"         -- old rfc850 HTTP format    (no weekday, no time)
-     "08-Feb-1994"       -- broken rfc850 HTTP format (no weekday, no time)
-     "09 Feb 1994"       -- proposed new HTTP format  (no weekday, no time)
-     "03/Feb/1994"       -- common logfile format     (no time, no offset)
-
-     "Feb  3  1994"      -- Unix 'ls -l' format
-     "Feb  3 17:03"      -- Unix 'ls -l' format
-
-     "11-15-96  03:52PM" -- Windows 'dir' format
-
-    The parser ignores leading and trailing whitespace. It also allow the
-    seconds to be missing and the month to be numerical in most formats.
-
-    If the year is missing, then we assume that the date is the first
-    matching date *before* current month. If the year is given with only 2
-    digits, then parse_date() will select the century that makes the year
-    closest to the current date.
-
-  format_datetime()
-    The "format_datetime()" method converts a DateTime to a string. If the
-    function is called without an argument, it will use the current time.
-
-    The string returned is in the format preferred for the HTTP protocol.
-    This is a fixed length subset of the format defined by RFC 1123,
-    represented in Universal Time (GMT). An example of a time stamp in this
-    format is:
-
-       Sun, 06 Nov 1994 08:49:37 GMT
-
-  format_iso( [$time] )
-    Same as format_datetime(), but returns a "YYYY-MM-DD hh:mm:ss"-formatted
-    string representing time in the local time zone. It is strongly
-    recommended that you use "format_isoz" or "format_datetime" instead (as
-    these provide time zone indication).
-
-  format_isoz( [$dt] )
-    Same as format_iso(), but returns a "YYYY-MM-DD hh:mm:ssZ"-formatted
-    string representing Universal Time.
-
-THANKS
-    Gisle Aas (GAAS) for writing HTTP::Date.
-
-    Iain, for never quite finishing "HTTP::Date::XS".
-
-SUPPORT
-    Support for this module is provided via the datetime@perl.org email
-    list. See http://lists.perl.org/ for more details.
-
-    Alternatively, log them via the CPAN RT system via the web or email:
-
-        http://rt.cpan.org/NoAuth/ReportBug.html?Queue=DateTime%3A%3AFormat%3A%3AHTTP
-        bug-datetime-format-http@rt.cpan.org
-
-    This makes it much easier for me to track things and thus means your
-    problem is less likely to be neglected.
-
-LICENCE AND COPYRIGHT
-    Copyright Iain Truskett, 2003. All rights reserved. Sections of the
-    documentation Gisle Aas, 1995-1999. Changes since version 0.35 copyright
-    David Rolsky, 2004.
-
-    This library is free software; you can redistribute it and/or modify it
-    under the same terms as Perl itself, either Perl version 5.000 or, at
-    your option, any later version of Perl 5 you may have available.
-
-    The full text of the licences can be found in the Artistic and COPYING
-    files included with this module, or in perlartistic and perlgpl as
-    supplied with Perl 5.8.1 and later.
-
-AUTHOR
-    Originally written by Iain Truskett <spoon@cpan.org>, who died on
-    December 29, 2003.
-
-    Maintained by Dave Rolsky <autarch@urth.org> and Christiaan Kras
-    <ckras@cpan.org>
-
-SEE ALSO
-    "datetime@perl.org" mailing list.
-
-    http://datetime.perl.org/
-
-    perl, DateTime, HTTP::Date, DateTime::TimeZone.
-
+NAME
+
+    DateTime::Format::HTTP - Date conversion routines
+
+SYNOPSIS
+
+        use DateTime::Format::HTTP;
+    
+        my $class = 'DateTime::Format::HTTP';
+        $string = $class->format_datetime($dt); # Format as GMT ASCII time
+        $time = $class->parse_datetime($string); # convert ASCII date to machine time
+
+DESCRIPTION
+
+    This module provides functions that deal the date formats used by the
+    HTTP protocol (and then some more).
+
+METHODS
+
+ parse_datetime( $str [, $zone] )
+
+    The parse_datetime() function converts a string to machine time. It
+    throws an error if the format of $str is unrecognized, or the time is
+    outside the representable range. The time formats recognized are listed
+    below.
+
+    The function also takes an optional second argument that specifies the
+    default time zone to use when converting the date. This parameter is
+    ignored if the zone is found in the date string itself. If this
+    parameter is missing, and the date string format does not contain any
+    zone specification, then the floating time zone is used.
+
+    The zone should be one that is recognized by DateTime::TimeZone.
+
+    Actual parsing is done with the HTTP::Date module. At the time of
+    writing it supports the formats listed next. Consult that module's
+    documentation in case the list has been changed.
+
+     "Wed, 09 Feb 1994 22:23:32 GMT"       -- HTTP format
+     "Thu Feb  3 17:03:55 GMT 1994"        -- ctime(3) format
+     "Thu Feb  3 00:00:00 1994",           -- ANSI C asctime() format
+     "Tuesday, 08-Feb-94 14:15:29 GMT"     -- old rfc850 HTTP format
+     "Tuesday, 08-Feb-1994 14:15:29 GMT"   -- broken rfc850 HTTP format
+    
+     "03/Feb/1994:17:03:55 -0700"   -- common logfile format
+     "09 Feb 1994 22:23:32 GMT"     -- HTTP format (no weekday)
+     "08-Feb-94 14:15:29 GMT"       -- rfc850 format (no weekday)
+     "08-Feb-1994 14:15:29 GMT"     -- broken rfc850 format (no weekday)
+    
+     "1994-02-03 14:15:29 -0100"    -- ISO 8601 format
+     "1994-02-03 14:15:29"          -- zone is optional
+     "1994-02-03"                   -- only date
+     "1994-02-03T14:15:29"          -- Use T as separator
+     "19940203T141529Z"             -- ISO 8601 compact format
+     "19940203"                     -- only date
+    
+     "08-Feb-94"         -- old rfc850 HTTP format    (no weekday, no time)
+     "08-Feb-1994"       -- broken rfc850 HTTP format (no weekday, no time)
+     "09 Feb 1994"       -- proposed new HTTP format  (no weekday, no time)
+     "03/Feb/1994"       -- common logfile format     (no time, no offset)
+    
+     "Feb  3  1994"      -- Unix 'ls -l' format
+     "Feb  3 17:03"      -- Unix 'ls -l' format
+    
+     "11-15-96  03:52PM" -- Windows 'dir' format
+
+    The parser ignores leading and trailing whitespace. It also allow the
+    seconds to be missing and the month to be numerical in most formats.
+
+    If the year is missing, then we assume that the date is the first
+    matching date before current month. If the year is given with only 2
+    digits, then parse_date() will select the century that makes the year
+    closest to the current date.
+
+ format_datetime()
+
+    The format_datetime() method converts a DateTime to a string. If the
+    function is called without an argument, it will use the current time.
+
+    The string returned is in the format preferred for the HTTP protocol.
+    This is a fixed length subset of the format defined by RFC 1123,
+    represented in Universal Time (GMT). An example of a time stamp in this
+    format is:
+
+       Sun, 06 Nov 1994 08:49:37 GMT
+
+ format_iso( [$time] )
+
+    Same as format_datetime(), but returns a "YYYY-MM-DD
+    hh:mm:ss"-formatted string representing time in the local time zone. It
+    is strongly recommended that you use format_isoz or format_datetime
+    instead (as these provide time zone indication).
+
+ format_isoz( [$dt] )
+
+    Same as format_iso(), but returns a "YYYY-MM-DD hh:mm:ssZ"-formatted
+    string representing Universal Time.
+
+THANKS
+
+    Gisle Aas (GAAS) for writing HTTP::Date.
+
+    Iain, for never quite finishing HTTP::Date::XS.
+
+SUPPORT
+
+    Support for this module is provided via the datetime@perl.org email
+    list. See http://lists.perl.org/ for more details.
+
+    Alternatively, log them via the CPAN RT system via the web or email:
+
+        http://rt.cpan.org/NoAuth/ReportBug.html?Queue=DateTime%3A%3AFormat%3A%3AHTTP
+        bug-datetime-format-http@rt.cpan.org
+
+    This makes it much easier for me to track things and thus means your
+    problem is less likely to be neglected.
+
+LICENCE AND COPYRIGHT
+
+    Copyright Iain Truskett, 2003. All rights reserved. Sections of the
+    documentation Gisle Aas, 1995-1999. Changes since version 0.35
+    copyright David Rolsky, 2004.
+
+    This library is free software; you can redistribute it and/or modify it
+    under the same terms as Perl itself, either Perl version 5.000 or, at
+    your option, any later version of Perl 5 you may have available.
+
+    The full text of the licences can be found in the Artistic and COPYING
+    files included with this module, or in perlartistic and perlgpl as
+    supplied with Perl 5.8.1 and later.
+
+AUTHOR
+
+    Originally written by Iain Truskett <spoon@cpan.org>, who died on
+    December 29, 2003.
+
+    Maintained by Dave Rolsky <autarch@urth.org> and Christiaan Kras
+    <ckras@cpan.org>
+
+SEE ALSO
+
+    datetime@perl.org mailing list.
+
+    http://datetime.perl.org/
+
+    perl, DateTime, HTTP::Date, DateTime::TimeZone.
+
diff --git a/README.md b/README.md
new file mode 100644
index 0000000..80b83d0
--- /dev/null
+++ b/README.md
@@ -0,0 +1,4 @@
+# DateTime-Format-HTTP
+Date conversion routines for Perl 5
+
+[![CI](https://github.com/Htbaa/DateTime-Format-HTTP/actions/workflows/ci.yml/badge.svg?branch=master)](https://github.com/Htbaa/DateTime-Format-HTTP/actions/workflows/ci.yml)
diff --git a/debian/changelog b/debian/changelog
index 2498511..770ea84 100644
--- a/debian/changelog
+++ b/debian/changelog
@@ -1,3 +1,9 @@
+libdatetime-format-http-perl (0.3801+git20220608.1.6744877-1) UNRELEASED; urgency=low
+
+  * New upstream snapshot.
+
+ -- Debian Janitor <janitor@jelmer.uk>  Fri, 18 Nov 2022 16:19:58 -0000
+
 libdatetime-format-http-perl (0.42-4) unstable; urgency=medium
 
   [ Debian Janitor ]
diff --git a/lib/DateTime/Format/HTTP.pm b/lib/DateTime/Format/HTTP.pm
index 13130fb..85dc913 100644
--- a/lib/DateTime/Format/HTTP.pm
+++ b/lib/DateTime/Format/HTTP.pm
@@ -1,254 +1,254 @@
-package DateTime::Format::HTTP;
-use strict;
-use warnings;
-use vars qw( $VERSION );
-
-$VERSION = '0.42';
-
-use DateTime;
-use HTTP::Date qw();
-
-use vars qw( @MoY %MoY);
-@MoY = qw(Jan Feb Mar Apr May Jun Jul Aug Sep Oct Nov Dec);
-@MoY{@MoY} = (1..12);
-
-sub format_datetime
-{
-    my ($self, $dt) = @_;
-    $dt = DateTime->now unless defined $dt;
-    $dt = $dt->clone->set_time_zone( 'GMT' );
-    return $dt->strftime( "%a, %d %b %Y %H:%M:%S GMT" );
-}
-
-
-sub parse_datetime
-{
-    my ($self, $str, $zone) = @_;
-    local $_;
-    die "No input string!" unless defined $str;
-
-    # fast exit for strictly conforming string
-    if ($str =~ /^
-	[SMTWF][a-z][a-z],
-	\ (\d\d)
-	\ ([JFMAJSOND][a-z][a-z])
-	\ (\d\d\d\d)
-	\ (\d\d):(\d\d):(\d\d)
-	\ GMT$/x) {
-	return DateTime->new(
-	    day => $1,
-	    month => $MoY{$2},
-	    year => $3,
-	    hour => $4,
-	    minute => $5,
-	    second => $6,
-	    time_zone => 'GMT'
-	);
-    }
-
-    my %d = $self->_parse_date($str);
-
-    unless (defined $d{time_zone})
-    {
-	$d{time_zone} = defined $zone ? $zone : 'floating';
-    }
-
-    my $frac = $d{second}; $frac -= ($d{second} = int($frac));
-    my $nano = 1_000_000_000 * $frac; $d{nanosecond} = int($nano + 0.5);
-    return DateTime->new( %d );
-}
-
-
-sub _parse_date
-{
-    my ($self, $str) = @_;
-    my @fields = qw( year month day hour minute second time_zone );
-    my %d;
-    my @values = HTTP::Date::parse_date( $str );
-    die "Could not parse date [$str]\n" unless @values;
-    @d{@fields} = @values;
-
-    if (defined $d{time_zone}) {
-	$d{time_zone} = "GMT" if $d{time_zone} =~ /^(Z|GMT|UTC?|[-+]?0+)$/ix;
-    }
-
-    return %d;
-}
-
-
-sub format_iso
-{
-    my ($self, $dt) = @_;
-    $dt = DateTime->now unless defined $dt;
-    sprintf("%04d-%02d-%02d %02d:%02d:%02d",
-	$dt->year, $dt->month, $dt->day,
-	$dt->hour, $dt->min, $dt->sec
-    );
-}
-
-
-sub format_isoz
-{
-    my ($self, $dt) = @_;
-    $dt = DateTime->now unless defined $dt;
-    $dt = $dt->clone->set_time_zone( 'UTC' );
-    sprintf("%04d-%02d-%02d %02d:%02d:%02dZ",
-	$dt->year, $dt->month, $dt->day,
-	$dt->hour, $dt->min, $dt->sec
-    );
-}
-
-1;
-
-
-__END__
-
-=head1 NAME
-
-DateTime::Format::HTTP - Date conversion routines
-
-=head1 SYNOPSIS
-
-    use DateTime::Format::HTTP;
-
-    my $class = 'DateTime::Format::HTTP';
-    $string = $class->format_datetime($dt); # Format as GMT ASCII time
-    $time = $class->parse_datetime($string); # convert ASCII date to machine time
-
-=head1 DESCRIPTION
-
-This module provides functions that deal the date formats used by the
-HTTP protocol (and then some more).
-
-=head1 METHODS
-
-=head2 parse_datetime( $str [, $zone] )
-
-The parse_datetime() function converts a string to machine time. It throws
-an error if the format of $str is unrecognized, or the time is outside
-the representable range. The time formats recognized are listed below.
-
-The function also takes an optional second argument that specifies the
-default time zone to use when converting the date. This parameter is
-ignored if the zone is found in the date string itself. If this
-parameter is missing, and the date string format does not contain
-any zone specification, then the floating time zone is used.
-
-The zone should be one that is recognized by L<DateTime::TimeZone>.
-
-Actual parsing is done with the L<HTTP::Date> module. At the time of
-writing it supports the formats listed next. Consult that module's
-documentation in case the list has been changed.
-
- "Wed, 09 Feb 1994 22:23:32 GMT"       -- HTTP format
- "Thu Feb  3 17:03:55 GMT 1994"        -- ctime(3) format
- "Thu Feb  3 00:00:00 1994",           -- ANSI C asctime() format
- "Tuesday, 08-Feb-94 14:15:29 GMT"     -- old rfc850 HTTP format
- "Tuesday, 08-Feb-1994 14:15:29 GMT"   -- broken rfc850 HTTP format
-
- "03/Feb/1994:17:03:55 -0700"   -- common logfile format
- "09 Feb 1994 22:23:32 GMT"     -- HTTP format (no weekday)
- "08-Feb-94 14:15:29 GMT"       -- rfc850 format (no weekday)
- "08-Feb-1994 14:15:29 GMT"     -- broken rfc850 format (no weekday)
-
- "1994-02-03 14:15:29 -0100"    -- ISO 8601 format
- "1994-02-03 14:15:29"          -- zone is optional
- "1994-02-03"                   -- only date
- "1994-02-03T14:15:29"          -- Use T as separator
- "19940203T141529Z"             -- ISO 8601 compact format
- "19940203"                     -- only date
-
- "08-Feb-94"         -- old rfc850 HTTP format    (no weekday, no time)
- "08-Feb-1994"       -- broken rfc850 HTTP format (no weekday, no time)
- "09 Feb 1994"       -- proposed new HTTP format  (no weekday, no time)
- "03/Feb/1994"       -- common logfile format     (no time, no offset)
-
- "Feb  3  1994"      -- Unix 'ls -l' format
- "Feb  3 17:03"      -- Unix 'ls -l' format
-
- "11-15-96  03:52PM" -- Windows 'dir' format
-
-The parser ignores leading and trailing whitespace.  It also allow the
-seconds to be missing and the month to be numerical in most formats.
-
-If the year is missing, then we assume that the date is the first
-matching date I<before> current month.  If the year is given with only
-2 digits, then parse_date() will select the century that makes the
-year closest to the current date.
-
-=head2 format_datetime()
-
-The C<format_datetime()> method converts a L<DateTime> to a string. If
-the function is called without an argument, it will use the current
-time.
-
-The string returned is in the format preferred for the HTTP protocol.
-This is a fixed length subset of the format defined by RFC 1123,
-represented in Universal Time (GMT).  An example of a time stamp
-in this format is:
-
-   Sun, 06 Nov 1994 08:49:37 GMT
-
-=head2 format_iso( [$time] )
-
-Same as format_datetime(), but returns a "YYYY-MM-DD hh:mm:ss"-formatted
-string representing time in the local time zone. It is B<strongly>
-recommended that you use C<format_isoz> or C<format_datetime> instead
-(as these provide time zone indication).
-
-=head2 format_isoz( [$dt] )
-
-Same as format_iso(), but returns a "YYYY-MM-DD hh:mm:ssZ"-formatted
-string representing Universal Time.
-
-=head1 THANKS
-
-Gisle Aas (GAAS) for writing L<HTTP::Date>.
-
-Iain, for never quite finishing C<HTTP::Date::XS>.
-
-=head1 SUPPORT
-
-Support for this module is provided via the datetime@perl.org email
-list. See http://lists.perl.org/ for more details.
-
-Alternatively, log them via the CPAN RT system via the web or email:
-
-    http://rt.cpan.org/NoAuth/ReportBug.html?Queue=DateTime%3A%3AFormat%3A%3AHTTP
-    bug-datetime-format-http@rt.cpan.org
-
-This makes it much easier for me to track things and thus means
-your problem is less likely to be neglected.
-
-=head1 LICENCE AND COPYRIGHT
-
-Copyright Iain Truskett, 2003. All rights reserved.
-Sections of the documentation Gisle Aas, 1995-1999.
-Changes since version 0.35 copyright David Rolsky, 2004.
-
-This library is free software; you can redistribute it and/or modify
-it under the same terms as Perl itself, either Perl version 5.000 or,
-at your option, any later version of Perl 5 you may have available.
-
-The full text of the licences can be found in the F<Artistic> and
-F<COPYING> files included with this module, or in L<perlartistic> and
-L<perlgpl> as supplied with Perl 5.8.1 and later.
-
-
-=head1 AUTHOR
-
-Originally written by Iain Truskett <spoon@cpan.org>, who died on
-December 29, 2003.
-
-Maintained by Dave Rolsky <autarch@urth.org> and Christiaan Kras <ckras@cpan.org>
-
-=head1 SEE ALSO
-
-C<datetime@perl.org> mailing list.
-
-http://datetime.perl.org/
-
-L<perl>, L<DateTime>, L<HTTP::Date>, L<DateTime::TimeZone>.
-
-=cut
-
+package DateTime::Format::HTTP;
+use strict;
+use warnings;
+use vars qw( $VERSION );
+
+$VERSION = '0.42';
+
+use DateTime;
+use HTTP::Date qw();
+
+use vars qw( @MoY %MoY);
+@MoY = qw(Jan Feb Mar Apr May Jun Jul Aug Sep Oct Nov Dec);
+@MoY{@MoY} = (1..12);
+
+sub format_datetime
+{
+    my ($self, $dt) = @_;
+    $dt = DateTime->now unless defined $dt;
+    $dt = $dt->clone->set_time_zone( 'GMT' );
+    return $dt->strftime( "%a, %d %b %Y %H:%M:%S GMT" );
+}
+
+
+sub parse_datetime
+{
+    my ($self, $str, $zone) = @_;
+    local $_;
+    die "No input string!" unless defined $str;
+
+    # fast exit for strictly conforming string
+    if ($str =~ /^
+	[SMTWF][a-z][a-z],
+	\ (\d\d)
+	\ ([JFMAJSOND][a-z][a-z])
+	\ (\d\d\d\d)
+	\ (\d\d):(\d\d):(\d\d)
+	\ GMT$/x) {
+	return DateTime->new(
+	    day => $1,
+	    month => $MoY{$2},
+	    year => $3,
+	    hour => $4,
+	    minute => $5,
+	    second => $6,
+	    time_zone => 'GMT'
+	);
+    }
+
+    my %d = $self->_parse_date($str);
+
+    unless (defined $d{time_zone})
+    {
+	$d{time_zone} = defined $zone ? $zone : 'floating';
+    }
+
+    my $frac = $d{second}; $frac -= ($d{second} = int($frac));
+    my $nano = 1_000_000_000 * $frac; $d{nanosecond} = int($nano + 0.5);
+    return DateTime->new( %d );
+}
+
+
+sub _parse_date
+{
+    my ($self, $str) = @_;
+    my @fields = qw( year month day hour minute second time_zone );
+    my %d;
+    my @values = HTTP::Date::parse_date( $str );
+    die "Could not parse date [$str]\n" unless @values;
+    @d{@fields} = @values;
+
+    if (defined $d{time_zone}) {
+	$d{time_zone} = "GMT" if $d{time_zone} =~ /^(Z|GMT|UTC?|[-+]?0+)$/ix;
+    }
+
+    return %d;
+}
+
+
+sub format_iso
+{
+    my ($self, $dt) = @_;
+    $dt = DateTime->now unless defined $dt;
+    sprintf("%04d-%02d-%02d %02d:%02d:%02d",
+	$dt->year, $dt->month, $dt->day,
+	$dt->hour, $dt->min, $dt->sec
+    );
+}
+
+
+sub format_isoz
+{
+    my ($self, $dt) = @_;
+    $dt = DateTime->now unless defined $dt;
+    $dt = $dt->clone->set_time_zone( 'UTC' );
+    sprintf("%04d-%02d-%02d %02d:%02d:%02dZ",
+	$dt->year, $dt->month, $dt->day,
+	$dt->hour, $dt->min, $dt->sec
+    );
+}
+
+1;
+
+
+__END__
+
+=head1 NAME
+
+DateTime::Format::HTTP - Date conversion routines
+
+=head1 SYNOPSIS
+
+    use DateTime::Format::HTTP;
+
+    my $class = 'DateTime::Format::HTTP';
+    $string = $class->format_datetime($dt); # Format as GMT ASCII time
+    $time = $class->parse_datetime($string); # convert ASCII date to machine time
+
+=head1 DESCRIPTION
+
+This module provides functions that deal the date formats used by the
+HTTP protocol (and then some more).
+
+=head1 METHODS
+
+=head2 parse_datetime( $str [, $zone] )
+
+The parse_datetime() function converts a string to machine time. It throws
+an error if the format of $str is unrecognized, or the time is outside
+the representable range. The time formats recognized are listed below.
+
+The function also takes an optional second argument that specifies the
+default time zone to use when converting the date. This parameter is
+ignored if the zone is found in the date string itself. If this
+parameter is missing, and the date string format does not contain
+any zone specification, then the floating time zone is used.
+
+The zone should be one that is recognized by L<DateTime::TimeZone>.
+
+Actual parsing is done with the L<HTTP::Date> module. At the time of
+writing it supports the formats listed next. Consult that module's
+documentation in case the list has been changed.
+
+ "Wed, 09 Feb 1994 22:23:32 GMT"       -- HTTP format
+ "Thu Feb  3 17:03:55 GMT 1994"        -- ctime(3) format
+ "Thu Feb  3 00:00:00 1994",           -- ANSI C asctime() format
+ "Tuesday, 08-Feb-94 14:15:29 GMT"     -- old rfc850 HTTP format
+ "Tuesday, 08-Feb-1994 14:15:29 GMT"   -- broken rfc850 HTTP format
+
+ "03/Feb/1994:17:03:55 -0700"   -- common logfile format
+ "09 Feb 1994 22:23:32 GMT"     -- HTTP format (no weekday)
+ "08-Feb-94 14:15:29 GMT"       -- rfc850 format (no weekday)
+ "08-Feb-1994 14:15:29 GMT"     -- broken rfc850 format (no weekday)
+
+ "1994-02-03 14:15:29 -0100"    -- ISO 8601 format
+ "1994-02-03 14:15:29"          -- zone is optional
+ "1994-02-03"                   -- only date
+ "1994-02-03T14:15:29"          -- Use T as separator
+ "19940203T141529Z"             -- ISO 8601 compact format
+ "19940203"                     -- only date
+
+ "08-Feb-94"         -- old rfc850 HTTP format    (no weekday, no time)
+ "08-Feb-1994"       -- broken rfc850 HTTP format (no weekday, no time)
+ "09 Feb 1994"       -- proposed new HTTP format  (no weekday, no time)
+ "03/Feb/1994"       -- common logfile format     (no time, no offset)
+
+ "Feb  3  1994"      -- Unix 'ls -l' format
+ "Feb  3 17:03"      -- Unix 'ls -l' format
+
+ "11-15-96  03:52PM" -- Windows 'dir' format
+
+The parser ignores leading and trailing whitespace.  It also allow the
+seconds to be missing and the month to be numerical in most formats.
+
+If the year is missing, then we assume that the date is the first
+matching date I<before> current month.  If the year is given with only
+2 digits, then parse_date() will select the century that makes the
+year closest to the current date.
+
+=head2 format_datetime()
+
+The C<format_datetime()> method converts a L<DateTime> to a string. If
+the function is called without an argument, it will use the current
+time.
+
+The string returned is in the format preferred for the HTTP protocol.
+This is a fixed length subset of the format defined by RFC 1123,
+represented in Universal Time (GMT).  An example of a time stamp
+in this format is:
+
+   Sun, 06 Nov 1994 08:49:37 GMT
+
+=head2 format_iso( [$time] )
+
+Same as format_datetime(), but returns a "YYYY-MM-DD hh:mm:ss"-formatted
+string representing time in the local time zone. It is B<strongly>
+recommended that you use C<format_isoz> or C<format_datetime> instead
+(as these provide time zone indication).
+
+=head2 format_isoz( [$dt] )
+
+Same as format_iso(), but returns a "YYYY-MM-DD hh:mm:ssZ"-formatted
+string representing Universal Time.
+
+=head1 THANKS
+
+Gisle Aas (GAAS) for writing L<HTTP::Date>.
+
+Iain, for never quite finishing C<HTTP::Date::XS>.
+
+=head1 SUPPORT
+
+Support for this module is provided via the datetime@perl.org email
+list. See http://lists.perl.org/ for more details.
+
+Alternatively, log them via the CPAN RT system via the web or email:
+
+    http://rt.cpan.org/NoAuth/ReportBug.html?Queue=DateTime%3A%3AFormat%3A%3AHTTP
+    bug-datetime-format-http@rt.cpan.org
+
+This makes it much easier for me to track things and thus means
+your problem is less likely to be neglected.
+
+=head1 LICENCE AND COPYRIGHT
+
+Copyright Iain Truskett, 2003. All rights reserved.
+Sections of the documentation Gisle Aas, 1995-1999.
+Changes since version 0.35 copyright David Rolsky, 2004.
+
+This library is free software; you can redistribute it and/or modify
+it under the same terms as Perl itself, either Perl version 5.000 or,
+at your option, any later version of Perl 5 you may have available.
+
+The full text of the licences can be found in the F<Artistic> and
+F<COPYING> files included with this module, or in L<perlartistic> and
+L<perlgpl> as supplied with Perl 5.8.1 and later.
+
+
+=head1 AUTHOR
+
+Originally written by Iain Truskett <spoon@cpan.org>, who died on
+December 29, 2003.
+
+Maintained by Dave Rolsky <autarch@urth.org> and Christiaan Kras <ckras@cpan.org>
+
+=head1 SEE ALSO
+
+C<datetime@perl.org> mailing list.
+
+http://datetime.perl.org/
+
+L<perl>, L<DateTime>, L<HTTP::Date>, L<DateTime::TimeZone>.
+
+=cut
+
diff --git a/t/basic.t b/t/basic.t
index 57d46ad..479590d 100644
--- a/t/basic.t
+++ b/t/basic.t
@@ -1,11 +1,11 @@
-#!/usr/bin/perl -w
-use strict;
-use lib 'inc';
-use Test::More tests => 2;
-
-BEGIN {
-    use_ok 'DateTime::Format::HTTP';
-}
-
-pass("All done");
-
+#!/usr/bin/perl -w
+use strict;
+use lib 'inc';
+use Test::More tests => 2;
+
+BEGIN {
+    use_ok 'DateTime::Format::HTTP';
+}
+
+pass("All done");
+
diff --git a/t/date.t b/t/date.t
index 04dfca9..ba8e6b3 100644
--- a/t/date.t
+++ b/t/date.t
@@ -1,204 +1,204 @@
-#!/usr/bin/perl -w
-use strict;
-use lib 'inc';
-use Test::More tests => 131;
-use vars qw( $class );
-
-BEGIN {
-    $class = 'DateTime::Format::HTTP';
-    use_ok $class;
-}
-
-require Time::Local if $^O eq "MacOS";
-my $offset = ($^O eq "MacOS") ? Time::Local::timegm(0,0,0,1,0,70) : 0;
-
-# test str2time for supported dates.  Test cases with 2 digit year
-# will probably break in year 2044.
-my(@tests) =
-(
-
- 'Thu, 03 Feb 1994 00:00:00 GMT',       # proposed new HTTP format
- 'Thursday, 03-Feb-94 00:00:00 GMT',    # old rfc850 HTTP format
- 'Thursday, 03-Feb-1994 00:00:00 GMT',  # broken rfc850 HTTP format
-
- 'Thu Feb  3 00:00:00 GMT 1994',        # ctime format
- 'Thu Feb  3 00:00:00 1994',            # same as ctime, except no TZ
-
- '03/Feb/1994:00:00:00 0000',   # common logfile format
- '03/Feb/1994:01:00:00 +0100',  # common logfile format
- '02/Feb/1994:23:00:00 -0100',  # common logfile format
-
- '03 Feb 1994 00:00:00 GMT',    # HTTP format (no weekday)
- '03-Feb-94 00:00:00 GMT',      # old rfc850 (no weekday)
- '03-Feb-1994 00:00:00 GMT',    # broken rfc850 (no weekday)
- '03-Feb-1994 00:00 GMT',       # broken rfc850 (no weekday, no seconds)
- '03-Feb-1994 00:00',           # VMS dir listing format
-
- '03-Feb-94',    # old rfc850 HTTP format    (no weekday, no time)
- '03-Feb-1994',  # broken rfc850 HTTP format (no weekday, no time)
- '03 Feb 1994',  # proposed new HTTP format  (no weekday, no time)
- '03/Feb/1994',  # common logfile format     (no time, no offset)
-
- #'Feb  3 00:00',     # Unix 'ls -l' format (can't really test it here)
- 'Feb  3 1994',       # Unix 'ls -l' format
-
- "02-03-94  12:00AM", # Windows 'dir' format
-
- # ISO 8601 formats
- '1994-02-03 00:00:00 +0000',
- '1994-02-03',
- '19940203',
- '1994-02-03T00:00:00+0000',
- '1994-02-02T23:00:00-0100',
- '1994-02-02T23:00:00-01:00',
- '1994-02-03T00:00:00 Z',
- '19940203T000000Z',
- '199402030000',
-
- # A few tests with extra space at various places
- '  03/Feb/1994      ',
- '  03   Feb   1994  0:00  ',
-);
-
-{
-    my $time = (760233600 + $offset);  # assume broken POSIX counting of seconds
-    $time = DateTime->from_epoch( epoch => $time );
-
-    for (@tests)
-    {
-        my $t = $class->parse_datetime($_, /GMT/i ? () : ('GMT'));
-        my $t2 = $class->parse_datetime(lc($_) => 'GMT' );
-        my $t3 = $class->parse_datetime(uc($_) => 'GMT' );
-
-        #diag "'$_'  =>  $t";
-        if ($t->epoch != $time->epoch )
-        {
-            diag "difference is: ".($t->epoch - $time->epoch);
-        }
-
-        is ( $t->epoch, $time->epoch, "str2time (1): $_" );
-        is ( $t2->epoch, $time->epoch, "str2time (2): $_" );
-        is ( $t3->epoch, $time->epoch, "str2time (3): $_" );
-    }
-
-    # test time2str
-    die "time2str failed"
-        unless $class->format_datetime($time) eq 'Thu, 03 Feb 1994 00:00:00 GMT';
-}
-
-{
-    # test the 'ls -l' format with missing year$
-    # round to nearest minute 3 days ago.
-    my $time = int((time - 3 * 24*60*60) /60)*60;
-    my ($min, $hr, $mday, $mon) = (gmtime $time)[1,2,3,4];
-    $mon = (qw(Jan Feb Mar Apr May Jun Jul Aug Sep Oct Nov Dec))[$mon];
-    my $str = sprintf("$mon %02d %02d:%02d", $mday, $hr, $min);
-    my $t = $class->parse_datetime($str);
-    is( $t->epoch, $time ); #, "str2time ls -l: '$str'  =>  $t ($time)\n");
-}
-
-for (undef, '', 'Garbage',
-     'Mandag 16. September 1996',
-     '1980-00-01',
-     '1980-13-01',
-     '1980-01-00',
-     '1980-01-32',
-     '1980-01-01 25:00:00',
-     '1980-01-01 00:61:00',
-    )
-{
-    my $desc = defined $_ ? "'$_'" : "undef";
-    $desc .= ' does not parse';
-
-    my $ok = ! defined eval { $class->parse_datetime($_) };
-    ok( $ok, $desc );
-}
-
-my $conv = sub {
-    my $str = shift;
-    $class->format_iso( $class->parse_datetime( $str ) );
-};
-
-my $t;
-
-$t = $conv->("11-12-96  0:00AM");
-is($t => "1996-11-12 00:00:00", $t);
-
-$t = $conv->("11-12-96 12:00AM");
-is($t => "1996-11-12 00:00:00", $t);
-
-$t = $conv->("11-12-96  0:00PM");
-is($t => "1996-11-12 12:00:00", $t);
-
-$t = $conv->("11-12-96 12:00PM");
-is($t => "1996-11-12 12:00:00", $t);
-
-$t = $conv->("11-12-96  1:05AM");
-is($t => "1996-11-12 01:05:00", $t);
-
-$t = $conv->("11-12-96 12:05AM");
-is($t => "1996-11-12 00:05:00", $t);
-
-$t = $conv->("11-12-96  1:05PM");
-is($t => "1996-11-12 13:05:00", $t);
-
-$t = $conv->("11-12-96 12:05PM");
-is($t => "1996-11-12 12:05:00", $t);
-
-my $dt = $class->parse_datetime("2000-01-01 00:00:01.234");
-$t = $dt->epoch;
-ok(
-    abs(($t - int($t)) - 0.234) > 0.000001,
-    "FRAC $t = ".$class->format_iso($dt)
-);
-is($dt->microsecond, 234_000, '.234s == 234_000us');
-is($dt->nanosecond, 234_000_000, '.234s == 234_000_000ns');
-
-$dt = $class->parse_datetime("2010-06-26T15:14:33.400753");
-$t = $dt->epoch;
-ok(
-    abs(($t - int($t)) - 0.400753) > 0.000001,
-    "FRAC $t = ".$class->format_iso($dt)
-);
-is($dt->microsecond, 400_753, '.400753s == 400_753us');
-is($dt->nanosecond, 400_753_000, '.400753s == 400_753_000ns');
-
-for my $ns (qw(1 12 123 1234 499999999 500000000 500000001 999753123 999999999)) {
-    $dt = $class->parse_datetime(sprintf("2010-06-26T15:14:33.%09d", $ns));
-    is($dt->nanosecond, $ns, ".${ns}s == ${ns}ns");
-}
-
-$a = $class->format_iso( );
-$b = $class->format_iso( DateTime->from_epoch( epoch => 500000 ) );
-
-my $az = $class->format_isoz( );
-my $bz = $class->format_isoz( DateTime->from_epoch( epoch => 500000 ) );
-
-for ($a,  $b)  {
-  like( $_ => qr/^\d{4}-\d\d-\d\d \d\d:\d\d:\d\d$/, "time2iso($_)" );
-}
-for ($az, $bz) {
-  like( $_ => qr/^\d{4}-\d\d-\d\d \d\d:\d\d:\d\dZ$/, "time2isoz($_)" );
-}
-
-{
-    # format_isoz must output date in UTC
-    my $eastern_date = DateTime->new(
-        year   => 2010,
-        month  => 10,
-        day    => 21,
-        hour   => 13,
-        minute => 8,
-        second => 23,
-        time_zone => 'America/New_York',
-    );
-
-    # Get the ISO "Z" format of the eastern zone date time
-    my $isoz = $class->format_isoz($eastern_date);
-
-    # Get the actual UTC date time
-    my $utc = $eastern_date->clone->set_time_zone('UTC');
-
-    is($isoz, $class->format_isoz($utc), 'format_isoz converts to UTC time zone');
-    is($eastern_date->time_zone->name, 'America/New_York', 'format_isoz does not modify input date\'s time zone');
-}
+#!/usr/bin/perl -w
+use strict;
+use lib 'inc';
+use Test::More tests => 131;
+use vars qw( $class );
+
+BEGIN {
+    $class = 'DateTime::Format::HTTP';
+    use_ok $class;
+}
+
+require Time::Local if $^O eq "MacOS";
+my $offset = ($^O eq "MacOS") ? Time::Local::timegm(0,0,0,1,0,70) : 0;
+
+# test str2time for supported dates.  Test cases with 2 digit year
+# will probably break in year 2044.
+my(@tests) =
+(
+
+ 'Thu, 03 Feb 1994 00:00:00 GMT',       # proposed new HTTP format
+ 'Thursday, 03-Feb-94 00:00:00 GMT',    # old rfc850 HTTP format
+ 'Thursday, 03-Feb-1994 00:00:00 GMT',  # broken rfc850 HTTP format
+
+ 'Thu Feb  3 00:00:00 GMT 1994',        # ctime format
+ 'Thu Feb  3 00:00:00 1994',            # same as ctime, except no TZ
+
+ '03/Feb/1994:00:00:00 0000',   # common logfile format
+ '03/Feb/1994:01:00:00 +0100',  # common logfile format
+ '02/Feb/1994:23:00:00 -0100',  # common logfile format
+
+ '03 Feb 1994 00:00:00 GMT',    # HTTP format (no weekday)
+ '03-Feb-94 00:00:00 GMT',      # old rfc850 (no weekday)
+ '03-Feb-1994 00:00:00 GMT',    # broken rfc850 (no weekday)
+ '03-Feb-1994 00:00 GMT',       # broken rfc850 (no weekday, no seconds)
+ '03-Feb-1994 00:00',           # VMS dir listing format
+
+ '03-Feb-94',    # old rfc850 HTTP format    (no weekday, no time)
+ '03-Feb-1994',  # broken rfc850 HTTP format (no weekday, no time)
+ '03 Feb 1994',  # proposed new HTTP format  (no weekday, no time)
+ '03/Feb/1994',  # common logfile format     (no time, no offset)
+
+ #'Feb  3 00:00',     # Unix 'ls -l' format (can't really test it here)
+ 'Feb  3 1994',       # Unix 'ls -l' format
+
+ "02-03-94  12:00AM", # Windows 'dir' format
+
+ # ISO 8601 formats
+ '1994-02-03 00:00:00 +0000',
+ '1994-02-03',
+ '19940203',
+ '1994-02-03T00:00:00+0000',
+ '1994-02-02T23:00:00-0100',
+ '1994-02-02T23:00:00-01:00',
+ '1994-02-03T00:00:00 Z',
+ '19940203T000000Z',
+ '199402030000',
+
+ # A few tests with extra space at various places
+ '  03/Feb/1994      ',
+ '  03   Feb   1994  0:00  ',
+);
+
+{
+    my $time = (760233600 + $offset);  # assume broken POSIX counting of seconds
+    $time = DateTime->from_epoch( epoch => $time );
+
+    for (@tests)
+    {
+        my $t = $class->parse_datetime($_, /GMT/i ? () : ('GMT'));
+        my $t2 = $class->parse_datetime(lc($_) => 'GMT' );
+        my $t3 = $class->parse_datetime(uc($_) => 'GMT' );
+
+        #diag "'$_'  =>  $t";
+        if ($t->epoch != $time->epoch )
+        {
+            diag "difference is: ".($t->epoch - $time->epoch);
+        }
+
+        is ( $t->epoch, $time->epoch, "str2time (1): $_" );
+        is ( $t2->epoch, $time->epoch, "str2time (2): $_" );
+        is ( $t3->epoch, $time->epoch, "str2time (3): $_" );
+    }
+
+    # test time2str
+    die "time2str failed"
+        unless $class->format_datetime($time) eq 'Thu, 03 Feb 1994 00:00:00 GMT';
+}
+
+{
+    # test the 'ls -l' format with missing year$
+    # round to nearest minute 3 days ago.
+    my $time = int((time - 3 * 24*60*60) /60)*60;
+    my ($min, $hr, $mday, $mon) = (gmtime $time)[1,2,3,4];
+    $mon = (qw(Jan Feb Mar Apr May Jun Jul Aug Sep Oct Nov Dec))[$mon];
+    my $str = sprintf("$mon %02d %02d:%02d", $mday, $hr, $min);
+    my $t = $class->parse_datetime($str);
+    is( $t->epoch, $time ); #, "str2time ls -l: '$str'  =>  $t ($time)\n");
+}
+
+for (undef, '', 'Garbage',
+     'Mandag 16. September 1996',
+     '1980-00-01',
+     '1980-13-01',
+     '1980-01-00',
+     '1980-01-32',
+     '1980-01-01 25:00:00',
+     '1980-01-01 00:61:00',
+    )
+{
+    my $desc = defined $_ ? "'$_'" : "undef";
+    $desc .= ' does not parse';
+
+    my $ok = ! defined eval { $class->parse_datetime($_) };
+    ok( $ok, $desc );
+}
+
+my $conv = sub {
+    my $str = shift;
+    $class->format_iso( $class->parse_datetime( $str ) );
+};
+
+my $t;
+
+$t = $conv->("11-12-96  0:00AM");
+is($t => "1996-11-12 00:00:00", $t);
+
+$t = $conv->("11-12-96 12:00AM");
+is($t => "1996-11-12 00:00:00", $t);
+
+$t = $conv->("11-12-96  0:00PM");
+is($t => "1996-11-12 12:00:00", $t);
+
+$t = $conv->("11-12-96 12:00PM");
+is($t => "1996-11-12 12:00:00", $t);
+
+$t = $conv->("11-12-96  1:05AM");
+is($t => "1996-11-12 01:05:00", $t);
+
+$t = $conv->("11-12-96 12:05AM");
+is($t => "1996-11-12 00:05:00", $t);
+
+$t = $conv->("11-12-96  1:05PM");
+is($t => "1996-11-12 13:05:00", $t);
+
+$t = $conv->("11-12-96 12:05PM");
+is($t => "1996-11-12 12:05:00", $t);
+
+my $dt = $class->parse_datetime("2000-01-01 00:00:01.234");
+$t = $dt->epoch;
+ok(
+    abs(($t - int($t)) - 0.234) > 0.000001,
+    "FRAC $t = ".$class->format_iso($dt)
+);
+is($dt->microsecond, 234_000, '.234s == 234_000us');
+is($dt->nanosecond, 234_000_000, '.234s == 234_000_000ns');
+
+$dt = $class->parse_datetime("2010-06-26T15:14:33.400753");
+$t = $dt->epoch;
+ok(
+    abs(($t - int($t)) - 0.400753) > 0.000001,
+    "FRAC $t = ".$class->format_iso($dt)
+);
+is($dt->microsecond, 400_753, '.400753s == 400_753us');
+is($dt->nanosecond, 400_753_000, '.400753s == 400_753_000ns');
+
+for my $ns (qw(1 12 123 1234 499999999 500000000 500000001 999753123 999999999)) {
+    $dt = $class->parse_datetime(sprintf("2010-06-26T15:14:33.%09d", $ns));
+    is($dt->nanosecond, $ns, ".${ns}s == ${ns}ns");
+}
+
+$a = $class->format_iso( );
+$b = $class->format_iso( DateTime->from_epoch( epoch => 500000 ) );
+
+my $az = $class->format_isoz( );
+my $bz = $class->format_isoz( DateTime->from_epoch( epoch => 500000 ) );
+
+for ($a,  $b)  {
+  like( $_ => qr/^\d{4}-\d\d-\d\d \d\d:\d\d:\d\d$/, "time2iso($_)" );
+}
+for ($az, $bz) {
+  like( $_ => qr/^\d{4}-\d\d-\d\d \d\d:\d\d:\d\dZ$/, "time2isoz($_)" );
+}
+
+{
+    # format_isoz must output date in UTC
+    my $eastern_date = DateTime->new(
+        year   => 2010,
+        month  => 10,
+        day    => 21,
+        hour   => 13,
+        minute => 8,
+        second => 23,
+        time_zone => 'America/New_York',
+    );
+
+    # Get the ISO "Z" format of the eastern zone date time
+    my $isoz = $class->format_isoz($eastern_date);
+
+    # Get the actual UTC date time
+    my $utc = $eastern_date->clone->set_time_zone('UTC');
+
+    is($isoz, $class->format_isoz($utc), 'format_isoz converts to UTC time zone');
+    is($eastern_date->time_zone->name, 'America/New_York', 'format_isoz does not modify input date\'s time zone');
+}
diff --git a/t/pod-coverage.t b/t/pod-coverage.t
index 2d1f47f..aa1f35b 100644
--- a/t/pod-coverage.t
+++ b/t/pod-coverage.t
@@ -1,14 +1,14 @@
-use strict;
-use warnings;
-
-use Test::More;
-
-
-plan skip_all => 'This test is only run for the module author'
-    unless -d '.svn' || $ENV{IS_MAINTAINER};
-
-eval "use Test::Pod::Coverage 1.04";
-plan skip_all => "Test::Pod::Coverage 1.04 required for testing POD coverage"
-    if $@;
-
-all_pod_coverage_ok();
+use strict;
+use warnings;
+
+use Test::More;
+
+
+plan skip_all => 'This test is only run for the module author'
+    unless -d '.svn' || $ENV{IS_MAINTAINER};
+
+eval "use Test::Pod::Coverage 1.04";
+plan skip_all => "Test::Pod::Coverage 1.04 required for testing POD coverage"
+    if $@;
+
+all_pod_coverage_ok();
diff --git a/t/pod.t b/t/pod.t
index ef52fcb..3f86494 100644
--- a/t/pod.t
+++ b/t/pod.t
@@ -1,13 +1,13 @@
-use strict;
-use warnings;
-
-use Test::More;
-
-
-plan skip_all => 'This test is only run for the module author'
-    unless -d '.svn' || $ENV{IS_MAINTAINER};
-
-eval "use Test::Pod 1.14";
-plan skip_all => "Test::Pod 1.14 required for testing POD" if $@;
-
-all_pod_files_ok();
+use strict;
+use warnings;
+
+use Test::More;
+
+
+plan skip_all => 'This test is only run for the module author'
+    unless -d '.svn' || $ENV{IS_MAINTAINER};
+
+eval "use Test::Pod 1.14";
+plan skip_all => "Test::Pod 1.14 required for testing POD" if $@;
+
+all_pod_files_ok();
diff --git a/t/time2str.t b/t/time2str.t
index e32242f..0fd4d70 100644
--- a/t/time2str.t
+++ b/t/time2str.t
@@ -1,26 +1,26 @@
-#!/usr/bin/perl -w
-use strict;
-use lib 'inc';
-use vars qw( $class );
-use Test::More tests => 3;
-use DateTime;
-
-BEGIN {
-    $class = 'DateTime::Format::HTTP';
-    use_ok $class;
-}
-
-require Time::Local if $^O eq "MacOS";
-my $offset = ($^O eq "MacOS") ? Time::Local::timegm(0,0,0,1,0,70) : 0;
-my $time = (760233600 + $offset);  # assume broken POSIX counting of seconds
-$time = DateTime->from_epoch( epoch => $time );
-
-# test time2str
-{
-    my $out = $class->format_datetime( $time );
-    my $wanted = 'Thu, 03 Feb 1994 00:00:00 GMT';
-    diag $out;
-    diag $wanted;
-    is ( $class->format_datetime($time) => $wanted, 'Basic' );
-    ok( $class->format_datetime() => 'no param');
-}
+#!/usr/bin/perl -w
+use strict;
+use lib 'inc';
+use vars qw( $class );
+use Test::More tests => 3;
+use DateTime;
+
+BEGIN {
+    $class = 'DateTime::Format::HTTP';
+    use_ok $class;
+}
+
+require Time::Local if $^O eq "MacOS";
+my $offset = ($^O eq "MacOS") ? Time::Local::timegm(0,0,0,1,0,70) : 0;
+my $time = (760233600 + $offset);  # assume broken POSIX counting of seconds
+$time = DateTime->from_epoch( epoch => $time );
+
+# test time2str
+{
+    my $out = $class->format_datetime( $time );
+    my $wanted = 'Thu, 03 Feb 1994 00:00:00 GMT';
+    diag $out;
+    diag $wanted;
+    is ( $class->format_datetime($time) => $wanted, 'Basic' );
+    ok( $class->format_datetime() => 'no param');
+}

Debdiff

File lists identical (after any substitutions)

No differences were encountered in the control files

More details

Full run details