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
- libdatetime-format-http-perl_0.3801+git20220608.1.6744877-1~jan+nus1.dsc
- libdatetime-format-http-perl_0.3801+git20220608.1.6744877-1~jan+nus1_all.deb
- libdatetime-format-http-perl_0.3801+git20220608.1.6744877-1~jan+nus1_amd64.buildinfo
- libdatetime-format-http-perl_0.3801+git20220608.1.6744877-1~jan+nus1_amd64.changes
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