Edit report at https://bugs.php.net/bug.php?id=49115&edit=1
ID: 49115 Comment by: anto dot justus at gmail dot com Reported by: php at davidstockton dot com Summary: date('M', strtotime('February')) prints "March" Status: Bogus Type: Bug Package: Date/time related Operating System: Windows XP/Linux PHP Version: 5.2.10 Block user comment: N Private report: N New Comment: hi.. You have used date("M", mktime(0, 0, 0, $i)) In this issue there is no initialization of date so it took 30 as default initialize date it will check for the availability of the date, if it is available it will consider the month or it will not take month in account. for example you can check the diff with using : date("M", mktime(0, 0, 0, $i,[2011])); it will consider only the month which have 30 and more days - default [30] date("M", mktime(0, 0, 0, $i,30,[2011])); it will consider only the month which have 30 and more days date("M", mktime(0, 0, 0, $i,31,[2011])); it will consider only the month which have 31 and more days date("M", mktime(0, 0, 0, $i,1,[2011])); it will consider only the month which have 1 and more days The calendar has 12 months with 30 or 31 days except February. So february is exception in this case. ( february have less than 30 days) The possible solution will be of using 1 as the 5th argument to initialize the month. you need to make a not of initializing the month to 1, since 1st is common to all the 12 months. you can use : date("M", mktime(0, 0, 0, $i,1,[2011])); year is optional it will take current year as default. Previous Comments: ------------------------------------------------------------------------ [2009-07-31 14:58:54] php at davidstockton dot com Sorry to belabor the point, but why is "February 2009" reset to February 1, 2009 (since the day is not provided), but "February" is not? In that case the current year is used (not provided) and the current day is used (also not provided). In the February 2009 example the day is not provided, but the day is reset to 1 which I think is a reasonable adjustment. I would think that February with an implied year matching the current year should behave the same as February with an implied year (no provided year). Thank you again.) ------------------------------------------------------------------------ [2009-07-31 08:34:03] der...@php.net Yup, that's correct. With the "month year" format, we reset the day to 1. ------------------------------------------------------------------------ [2009-07-31 03:55:41] php at davidstockton dot com I guess my above assumption is not correct either which means there's something else going on that I don't understand. For example, <?php echo date('F', strtotime('February 2009')), "\n"; echo date('F', strtotime('February 1')), "\n"; ?> Both lines output the expected "February" even though I've not specified a day of the month in the first scenario but the timestamp given by strtotime corresponds to February 1, 2009. If the function fills in the defaults from the current date, I'd expect to still see March for the 1st line.) ------------------------------------------------------------------------ [2009-07-31 02:57:44] php at davidstockton dot com Interesting. So I'd guess that if I run this same test tomorrow, I'll be seeing January March March May May July July August October October December December I think I understand why it would be doing this, but it still seems pretty weird. Is the assumption that strtotime fills in every part of the date/time with whatever the current time happens to be correct?) ------------------------------------------------------------------------ [2009-07-30 23:29:17] ras...@php.net date() is doing what it is supposed to. You are passing it a timestamp in March. strtotime() returns a timestamp in March because you have not been specific enough. When you just give it a month and nothing else, it makes some assumptions. For example, it takes the current year and the current date. So, you are asking strtotime for February 30, 2009 which actually doesn't exist since February doesn't have 30 days, so it gives you the closest match which is March 2nd. Not a bug. You just have to be more explicit. Like "February 1" ------------------------------------------------------------------------ The remainder of the comments for this report are too long. To view the rest of the comments, please view the bug report online at https://bugs.php.net/bug.php?id=49115 -- Edit this bug report at https://bugs.php.net/bug.php?id=49115&edit=1