Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Finding out the filename that called my function in PHP

How do I find out the filename of the script that called my function?

For example,

function sthing() {
echo __FILE__; // echoes myself
echo __CALLER_FILE__; // echoes the file that called me
}
like image 426
Tower Avatar asked Dec 20 '09 13:12

Tower


People also ask

What __ file __ contains in PHP?

__file__ is a variable that contains the path to the module that is currently being imported.

What is __ function in PHP?

PHP - The __construct FunctionA constructor allows you to initialize an object's properties upon creation of the object. If you create a __construct() function, PHP will automatically call this function when you create an object from a class. Notice that the construct function starts with two underscores (__)!


4 Answers

A solution might be to use the debug_backtrace function : in the backtrace, that kind of information should be present.

Or, as Gordon pointed out in a comment, you can also use debug_print_backtrace if you just want to output that information and not work with it.


For instance, with temp.php containing this :

<?php
include 'temp-2.php';
my_function();

and with temp-2.php containing this :

<?php
function my_function() {
    var_dump(debug_backtrace());
}


Calling temp.php (i.e. the first script) from my browser gets me this output :

array
  0 => 
    array
      'file' => string '/.../temp/temp.php' (length=46)
      'line' => int 5
      'function' => string 'my_function' (length=11)
      'args' => 
        array
          empty

In there, I have the "temp.php" filename -- which is the one in which the function has been called.


Of course, you'll have to test a bit more (especially in situations where the function is not in the "first level" included file, but in a file included by another one -- not sure debug_backtrace will help much, there...) ; but this might help you get a first idea...

like image 81
Pascal MARTIN Avatar answered Nov 11 '22 21:11

Pascal MARTIN


Try this code:

$key = array_search(__FUNCTION__, array_column(debug_backtrace(), 'function'));
var_dump(debug_backtrace()[$key]['file']);
like image 42
Mirko Pagliai Avatar answered Nov 11 '22 21:11

Mirko Pagliai


In addition to Pascal Martins's suggestion, you could install the PECL extension APD and use something like apd_callstack(), which (quoting example)

// returns an array containing an array of arrays.

Each array appears to contain:
[0] = function name
[1] = filename that contains function
[2] = *calling* line number in *calling* file
[3] = An array which is usually empty

But since this is a PECL extension and might interfere with Zend Optimizer, you might be better off going with debug_backtrace().

like image 3
Gordon Avatar answered Nov 11 '22 22:11

Gordon


2 lines - done:

$backfiles=debug_backtrace();
echo $file_called_from=$backfiles[0]['file']; // complete filepath

Or to crop out only the filename add the following

echo "<Br>";
echo basename($file_called_from); // for only the filename without the path
like image 2
Jay Lepore Avatar answered Nov 11 '22 21:11

Jay Lepore