php.net |  support |  documentation |  report a bug |  advanced search |  search howto |  statistics |  random bug |  login
Doc Bug #76588 var_export change variable state
Submitted: 2018-07-06 13:30 UTC Modified: 2020-06-14 22:26 UTC
Votes:1
Avg. Score:3.0 ± 0.0
Reproduced:1 of 1 (100.0%)
Same Version:1 (100.0%)
Same OS:1 (100.0%)
From: sukei13 at gmail dot com Assigned:
Status: Verified Package: Date/time related
PHP Version: Irrelevant OS:
Private report: No CVE-ID: None
Have you experienced this issue?
Rate the importance of this bug to you:

 [2018-07-06 13:30 UTC] sukei13 at gmail dot com
Description:
------------
The result of a comparison (soft: ==) between two date intervals change when the variable has been exported (var_export) earlier. The var_export function affect the internal state of the DateInterval object in some way. The following test script show this weird behavior. Note that this test has been made on other objects too (such as DateTime or DateTimeImmutable) but DateInterval seems to be the only object involved in this issue.

Test script:
---------------
<?php

$a = new DateInterval('P2Y4DT6H8M');
$b = new DateInterval('P2Y4DT6H8M');

var_dump($a == $b); // true

var_export($b, true);

var_dump($a == $b); // false

Expected result:
----------------
bool(true)
bool(true)

Actual result:
--------------
bool(true)
bool(false)

Patches

Add a Patch

Pull Requests

Add a Pull Request

History

AllCommentsChangesGit/SVN commitsRelated reports
 [2018-07-06 13:37 UTC] sukei13 at gmail dot com
Doing further tests, it appears that the print_r function has the same behavior as var_export.
 [2018-07-13 22:10 UTC] cmb@php.net
-Package: *General Issues +Package: Date/time related
 [2020-06-14 22:26 UTC] cmb@php.net
-Status: Open +Status: Verified -Type: Bug +Type: Documentation Problem
 [2020-06-14 22:26 UTC] cmb@php.net
Comparing DateInterval instances cannot be well defined (consider
e.g. P1M and P30D); as of PHP 7.4.0, comparisons raise a warning
and evaluate to FALSE.  Prior to that version, their behavior was,
let's say, undefined.

While that change is noted in the migration guide[1], it is not
yet documented in the manual proper (not sure, *where* this should
be documented).

[1] <https://www.php.net/manual/en/migration74.incompatible.php#migration74.incompatible.datetime>
 
PHP Copyright © 2001-2020 The PHP Group
All rights reserved.
Last updated: Tue Oct 20 02:01:23 2020 UTC