3v4l.org

run code in 300+ PHP versions simultaneously
<?php function a($depth = 0) { //return last backtrace call. If backtrace bigger then 3, return third call. if($depth === 1000) { return array_slice(array_filter(array_slice(debug_backtrace(false, 3), 0, 3)), -1, 1); } return a(++$depth, str_repeat("a", 1000)); } var_dump(a());
Finding entry points
Branch analysis from position: 0
1 jumps found. (Code = 62) Position 1 = -2
filename:       /in/kcGs1
function name:  (null)
number of ops:  6
compiled vars:  none
line      #* E I O op                           fetch          ext  return  operands
-------------------------------------------------------------------------------------
   13     0  E >   INIT_FCALL                                               'var_dump'
          1        INIT_FCALL                                               'a'
          2        DO_FCALL                                      0  $0      
          3        SEND_VAR                                                 $0
          4        DO_ICALL                                                 
          5      > RETURN                                                   1

Function a:
Finding entry points
Branch analysis from position: 0
2 jumps found. (Code = 43) Position 1 = 3, Position 2 = 21
Branch analysis from position: 3
1 jumps found. (Code = 62) Position 1 = -2
Branch analysis from position: 21
1 jumps found. (Code = 62) Position 1 = -2
filename:       /in/kcGs1
function name:  a
number of ops:  32
compiled vars:  !0 = $depth
line      #* E I O op                           fetch          ext  return  operands
-------------------------------------------------------------------------------------
    3     0  E >   RECV_INIT                                        !0      0
    6     1        IS_IDENTICAL                                             !0, 1000
          2      > JMPZ                                                     ~1, ->21
    7     3    >   INIT_FCALL                                               'array_slice'
          4        INIT_FCALL                                               'array_filter'
          5        INIT_FCALL                                               'array_slice'
          6        INIT_FCALL                                               'debug_backtrace'
          7        SEND_VAL                                                 <false>
          8        SEND_VAL                                                 3
          9        DO_ICALL                                         $2      
         10        SEND_VAR                                                 $2
         11        SEND_VAL                                                 0
         12        SEND_VAL                                                 3
         13        DO_ICALL                                         $3      
         14        SEND_VAR                                                 $3
         15        DO_ICALL                                         $4      
         16        SEND_VAR                                                 $4
         17        SEND_VAL                                                 -1
         18        SEND_VAL                                                 1
         19        DO_ICALL                                         $5      
         20      > RETURN                                                   $5
   10    21    >   INIT_FCALL_BY_NAME                                       'a'
         22        PRE_INC                                          ~6      !0
         23        SEND_VAL_EX                                              ~6
         24        INIT_FCALL                                               'str_repeat'
         25        SEND_VAL                                                 'a'
         26        SEND_VAL                                                 1000
         27        DO_ICALL                                         $7      
         28        SEND_VAR_NO_REF_EX                                       $7
         29        DO_FCALL                                      0  $8      
         30      > RETURN                                                   $8
   11    31*     > RETURN                                                   null

End of function a

Generated using Vulcan Logic Dumper, using php 8.0.0


preferences:
203.1 ms | 1399 KiB | 24 Q