-
Notifications
You must be signed in to change notification settings - Fork 8k
Open
derickr/timelib
#170Description
Description
The following code:
<?php
strtotime("2.37685 weeks");Resulted in this output:
1613443020
The code interpreted 2.37685 weeks as 02:37 (hours) and 685 weeks. This is non logical input of course (and not GNU compliant). But this isn't a very logical interpretation of this value from a human perspective and can easily be used incorrectly by users of the code without noticing.
The parser decided to not be able to recognize weeks, then fallback to hours, interpret up to 2 decimals (compliant with hour parsing), then split the remainder and continue parsing, interpreting the rest as the input for weeks.
This has been a known (usability) issue since 2007, when it was first encountered by Wikipedia, but an upstream ticket was never filed until now.
PHP Version
PHP 8.4.16 (cli) (built: Dec 16 2025 16:03:34) (NTS)
Copyright (c) The PHP Group
Built by Homebrew
Zend Engine v4.4.16, Copyright (c) Zend Technologies
with Xdebug v3.4.0, Copyright (c) 2002-2024, by Derick Rethans
with Zend OPcache v8.4.16, Copyright (c), by Zend Technologies
Operating System
macos
Reactions are currently unavailable