3v4l.org

run code in 300+ PHP versions simultaneously
<?php /** * Test Skript for the bug at: http://de.php.net/manual/en/datetime.sub.php#101175 */ $current = '20130117010101'; $dateString = '20130115000000'; $preserveAfterDate = new DateTime($current); $preserveAfterDate->setTime(0,0,0); // sub() get called 2 times, first here $preserveAfterDate->sub(new DateInterval('P5D')); $fileDate = new DateTime($dateString); var_dump($fileDate->format('Y-m-d H:i:s')); var_dump($preserveAfterDate->format('Y-m-d H:i:s')); // sub gets called again from diff() ?!?!?! $difference = $preserveAfterDate->diff($fileDate); var_dump($preserveAfterDate->format('Y-m-d H:i:s')); var_dump($difference->format('%r%a'));
Finding entry points
Branch analysis from position: 0
1 jumps found. (Code = 62) Position 1 = -2
filename:       /in/IgNEQ
function name:  (null)
number of ops:  50
compiled vars:  !0 = $current, !1 = $dateString, !2 = $preserveAfterDate, !3 = $fileDate, !4 = $difference
line      #* E I O op                           fetch          ext  return  operands
-------------------------------------------------------------------------------------
    5     0  E >   ASSIGN                                                   !0, '20130117010101'
    6     1        ASSIGN                                                   !1, '20130115000000'
    8     2        NEW                                              $7      'DateTime'
          3        SEND_VAR_EX                                              !0
          4        DO_FCALL                                      0          
          5        ASSIGN                                                   !2, $7
    9     6        INIT_METHOD_CALL                                         !2, 'setTime'
          7        SEND_VAL_EX                                              0
          8        SEND_VAL_EX                                              0
          9        SEND_VAL_EX                                              0
         10        DO_FCALL                                      0          
   11    11        INIT_METHOD_CALL                                         !2, 'sub'
         12        NEW                                              $11     'DateInterval'
         13        SEND_VAL_EX                                              'P5D'
         14        DO_FCALL                                      0          
         15        SEND_VAR_NO_REF_EX                                       $11
         16        DO_FCALL                                      0          
   15    17        NEW                                              $14     'DateTime'
         18        SEND_VAR_EX                                              !1
         19        DO_FCALL                                      0          
         20        ASSIGN                                                   !3, $14
   16    21        INIT_FCALL                                               'var_dump'
         22        INIT_METHOD_CALL                                         !3, 'format'
         23        SEND_VAL_EX                                              'Y-m-d+H%3Ai%3As'
         24        DO_FCALL                                      0  $17     
         25        SEND_VAR                                                 $17
         26        DO_ICALL                                                 
   18    27        INIT_FCALL                                               'var_dump'
         28        INIT_METHOD_CALL                                         !2, 'format'
         29        SEND_VAL_EX                                              'Y-m-d+H%3Ai%3As'
         30        DO_FCALL                                      0  $19     
         31        SEND_VAR                                                 $19
         32        DO_ICALL                                                 
   20    33        INIT_METHOD_CALL                                         !2, 'diff'
         34        SEND_VAR_EX                                              !3
         35        DO_FCALL                                      0  $21     
         36        ASSIGN                                                   !4, $21
   21    37        INIT_FCALL                                               'var_dump'
         38        INIT_METHOD_CALL                                         !2, 'format'
         39        SEND_VAL_EX                                              'Y-m-d+H%3Ai%3As'
         40        DO_FCALL                                      0  $23     
         41        SEND_VAR                                                 $23
         42        DO_ICALL                                                 
   23    43        INIT_FCALL                                               'var_dump'
         44        INIT_METHOD_CALL                                         !4, 'format'
         45        SEND_VAL_EX                                              '%25r%25a'
         46        DO_FCALL                                      0  $25     
         47        SEND_VAR                                                 $25
         48        DO_ICALL                                                 
         49      > RETURN                                                   1

Generated using Vulcan Logic Dumper, using php 8.0.0


preferences:
152.03 ms | 1400 KiB | 15 Q