3v4l.org

run code in 300+ PHP versions simultaneously
<?php // Query timestamp of entry //returns like this $entrydatetime = "2013-11-20 17:36:18"; //get current time $now = new \DateTime(); // Use DateTime on $entrydatetime $entrydatetime = new \DateTime($entrydatetime); // Seconds echo $now->getTimestamp() - $entrydatetime->getTimestamp() . "seconds\n"; // Human readable is more complex $age = $now->diff($entrydatetime); // DateInterval if ($age->y > 0) { echo $age->y == 1 ? '1 year ago' : ($age->y . ' years ago'); } else if ($age->m > 0) { echo $age->m == 1 ? '1 month ago' : ($age->m . ' months ago'); } else if ($age->days > 0) { echo $age->days == 1 ? '1 day ago' : ($age->days . ' days ago'); } else { echo $age->format('%h hours, %i minutes ago'); }
Finding entry points
Branch analysis from position: 0
2 jumps found. (Code = 43) Position 1 = 22, Position 2 = 32
Branch analysis from position: 22
2 jumps found. (Code = 43) Position 1 = 25, Position 2 = 27
Branch analysis from position: 25
1 jumps found. (Code = 42) Position 1 = 30
Branch analysis from position: 30
1 jumps found. (Code = 42) Position 1 = 62
Branch analysis from position: 62
1 jumps found. (Code = 62) Position 1 = -2
Branch analysis from position: 27
1 jumps found. (Code = 42) Position 1 = 62
Branch analysis from position: 62
Branch analysis from position: 32
2 jumps found. (Code = 43) Position 1 = 35, Position 2 = 45
Branch analysis from position: 35
2 jumps found. (Code = 43) Position 1 = 38, Position 2 = 40
Branch analysis from position: 38
1 jumps found. (Code = 42) Position 1 = 43
Branch analysis from position: 43
1 jumps found. (Code = 42) Position 1 = 62
Branch analysis from position: 62
Branch analysis from position: 40
1 jumps found. (Code = 42) Position 1 = 62
Branch analysis from position: 62
Branch analysis from position: 45
2 jumps found. (Code = 43) Position 1 = 48, Position 2 = 58
Branch analysis from position: 48
2 jumps found. (Code = 43) Position 1 = 51, Position 2 = 53
Branch analysis from position: 51
1 jumps found. (Code = 42) Position 1 = 56
Branch analysis from position: 56
1 jumps found. (Code = 42) Position 1 = 62
Branch analysis from position: 62
Branch analysis from position: 53
1 jumps found. (Code = 42) Position 1 = 62
Branch analysis from position: 62
Branch analysis from position: 58
1 jumps found. (Code = 62) Position 1 = -2
filename:       /in/kJb1O
function name:  (null)
number of ops:  63
compiled vars:  !0 = $entrydatetime, !1 = $now, !2 = $age
line      #* E I O op                           fetch          ext  return  operands
-------------------------------------------------------------------------------------
    6     0  E >   ASSIGN                                                   !0, '2013-11-20+17%3A36%3A18'
   10     1        NEW                                              $4      'DateTime'
          2        DO_FCALL                                      0          
          3        ASSIGN                                                   !1, $4
   13     4        NEW                                              $7      'DateTime'
          5        SEND_VAR_EX                                              !0
          6        DO_FCALL                                      0          
          7        ASSIGN                                                   !0, $7
   17     8        INIT_METHOD_CALL                                         !1, 'getTimestamp'
          9        DO_FCALL                                      0  $10     
         10        INIT_METHOD_CALL                                         !0, 'getTimestamp'
         11        DO_FCALL                                      0  $11     
         12        SUB                                              ~12     $10, $11
         13        CONCAT                                           ~13     ~12, 'seconds%0A'
         14        ECHO                                                     ~13
   21    15        INIT_METHOD_CALL                                         !1, 'diff'
         16        SEND_VAR_EX                                              !0
         17        DO_FCALL                                      0  $14     
         18        ASSIGN                                                   !2, $14
   24    19        FETCH_OBJ_R                                      ~16     !2, 'y'
         20        IS_SMALLER                                               0, ~16
         21      > JMPZ                                                     ~17, ->32
   25    22    >   FETCH_OBJ_R                                      ~18     !2, 'y'
         23        IS_EQUAL                                                 ~18, 1
         24      > JMPZ                                                     ~19, ->27
         25    >   QM_ASSIGN                                        ~20     '1+year+ago'
         26      > JMP                                                      ->30
         27    >   FETCH_OBJ_R                                      ~21     !2, 'y'
         28        CONCAT                                           ~22     ~21, '+years+ago'
         29        QM_ASSIGN                                        ~20     ~22
         30    >   ECHO                                                     ~20
         31      > JMP                                                      ->62
   26    32    >   FETCH_OBJ_R                                      ~23     !2, 'm'
         33        IS_SMALLER                                               0, ~23
         34      > JMPZ                                                     ~24, ->45
   27    35    >   FETCH_OBJ_R                                      ~25     !2, 'm'
         36        IS_EQUAL                                                 ~25, 1
         37      > JMPZ                                                     ~26, ->40
         38    >   QM_ASSIGN                                        ~27     '1+month+ago'
         39      > JMP                                                      ->43
         40    >   FETCH_OBJ_R                                      ~28     !2, 'm'
         41        CONCAT                                           ~29     ~28, '+months+ago'
         42        QM_ASSIGN                                        ~27     ~29
         43    >   ECHO                                                     ~27
         44      > JMP                                                      ->62
   28    45    >   FETCH_OBJ_R                                      ~30     !2, 'days'
         46        IS_SMALLER                                               0, ~30
         47      > JMPZ                                                     ~31, ->58
   29    48    >   FETCH_OBJ_R                                      ~32     !2, 'days'
         49        IS_EQUAL                                                 ~32, 1
         50      > JMPZ                                                     ~33, ->53
         51    >   QM_ASSIGN                                        ~34     '1+day+ago'
         52      > JMP                                                      ->56
         53    >   FETCH_OBJ_R                                      ~35     !2, 'days'
         54        CONCAT                                           ~36     ~35, '+days+ago'
         55        QM_ASSIGN                                        ~34     ~36
         56    >   ECHO                                                     ~34
         57      > JMP                                                      ->62
   31    58    >   INIT_METHOD_CALL                                         !2, 'format'
         59        SEND_VAL_EX                                              '%25h+hours%2C+%25i+minutes+ago'
         60        DO_FCALL                                      0  $37     
         61        ECHO                                                     $37
   32    62    > > RETURN                                                   1

Generated using Vulcan Logic Dumper, using php 8.0.0


preferences:
155.74 ms | 1399 KiB | 13 Q