Newsgroups: php.internals Path: news.php.net Xref: news.php.net php.internals:86111 Return-Path: Mailing-List: contact internals-help@lists.php.net; run by ezmlm Delivered-To: mailing list internals@lists.php.net Received: (qmail 88902 invoked from network); 4 May 2015 20:25:39 -0000 Received: from unknown (HELO lists.php.net) (127.0.0.1) by localhost with SMTP; 4 May 2015 20:25:39 -0000 Authentication-Results: pb1.pair.com smtp.mail=derick@php.net; spf=unknown; sender-id=unknown Authentication-Results: pb1.pair.com header.from=derick@php.net; sender-id=unknown Received-SPF: unknown (pb1.pair.com: domain php.net does not designate 82.113.146.227 as permitted sender) X-PHP-List-Original-Sender: derick@php.net X-Host-Fingerprint: 82.113.146.227 xdebug.org Linux 2.6 Received: from [82.113.146.227] ([82.113.146.227:55465] helo=xdebug.org) by pb1.pair.com (ecelerity 2.1.1.9-wez r(12769M)) with ESMTP id 22/C0-16879-FB5D7455 for ; Mon, 04 May 2015 16:25:35 -0400 Received: from localhost (localhost [IPv6:::1]) by xdebug.org (Postfix) with ESMTPS id 1C50B10C8C4; Mon, 4 May 2015 21:25:31 +0100 (BST) Date: Mon, 4 May 2015 21:25:31 +0100 (BST) X-X-Sender: derick@whisky.home.derickrethans.nl To: David Lundgren cc: PHP Developers Mailing List In-Reply-To: <5547CD9C.9040404@syberisle.net> Message-ID: References: <55479144.7060704@gmail.com> <5547CD9C.9040404@syberisle.net> User-Agent: Alpine 2.11 (DEB 23 2013-08-11) MIME-Version: 1.0 Content-Type: TEXT/PLAIN; charset=US-ASCII Subject: Re: [PHP-DEV] Adding weekdays to DateTime resets the time From: derick@php.net (Derick Rethans) Hi, This indeed looks like a bug - Happy to have a look at it to fix in timelib: https://github.com/derickr/timelib cheers, Derick On Mon, 4 May 2015, David Lundgren wrote: > There is actually already a bug for about this: > https://bugs.php.net/bug.php?id=54909 > > I ran into this several months ago when I upgraded a project from 5.3.2 > to 5.5 and found that in 5.3.6 the behavior had changed. I ended up > working around it in my code. It was definitely annoying but had we > upgraded PHP versions sooner I wouldn't have had any issue with this in > the time crunch I had. > > Our unit tests around that code, while complex, became that much better > to actually account for the finer details of date/time. > > - Dave > > On 5/4/15 12:49 PM, Stelian Mocanita wrote: > > I think the best approach would be to open a bug under https://bugs.php.net/ > > since this does > > not look like intended behavior. > > > > Regards, > > Stelian > > > > On Mon, May 4, 2015 at 5:33 PM, Markus Fasselt > > wrote: > > > >> Hi, > >> > >> when I modify a DateTime object and add or subtract weekdays, it happens > >> that the current time is reset to 00:00:00. > >> > >> This effect does not occur when I add days. I also experienced the same > >> behavior with strototime. > >> > >>> >>> > >>> $a = new DateTime(strtotime('2015-05-04 17:22')); > >>> var_dump((string) $a->format('Y-m-d H:i:s')); // 2015-05-04 17:22:00 > >>> $a->modify('+1 day'); > >>> var_dump((string) $a->format('Y-m-d H:i:s')); // 2015-05-05 17:22:00 > >>> $a->modify('+1 weekday'); > >>> var_dump((string) $a->format('Y-m-d H:i:s')); 2015-05-06 00:00:00 > >>> > >>> var_dump(date('Y-m-d H:i:s', strtotime('+1 weekday'))); // 2015-05-05 > >> 00:00:00 > >> > >> http://3v4l.org/554H4 > >> > >> There seems to be slighly different behavior between the different PHP > >> versions. strotime always had this behavior. DateTime::modify() worked > >> correct until PHP 5.3.5. > >> > >> I don't know if this behavior was changed on purpose (I didn't find > >> something on it). If so, why? Otherwise I would suggest to fix this, as > >> it is really confusing. > >> > >> Regards, > >> Markus > >> > >> -- > >> PHP Internals - PHP Runtime Development Mailing List > >> To unsubscribe, visit: http://www.php.net/unsub.php > >> > > > > > -- http://derickrethans.nl | http://xdebug.org Like Xdebug? Consider a donation: http://xdebug.org/donate.php twitter: @derickr and @xdebug Posted with an email client that doesn't mangle email: alpine