开发者

function name($param, $line = __LINE__, $file = __FILE__) {};

开发者 https://www.devze.com 2023-01-10 08:15 出处:网络
Is it possible to have a function automatically contain the line number and the file that the function was CALLED in,

Is it possible to have a function automatically contain the line number and the file that the function was CALLED in,

as if i call __LINE__ or __FILE__ in the function it will use the line and file the function definition is in.

but i dont want to have to pass __LINE__ and __FILE__ into the function every time.

so if i set them as the default params, do they come from the function definition, or where it is bei开发者_JS百科ng called from?


Doing what you suggest doesn't seem to work.

You can do it like this, but I'm not sure why you want to do it and that there isn't a better approach to what you are trying to achieve - see Wrikken's answer.

<?php

function test() {
    $backtrace = debug_backtrace();
    $last = $backtrace[0];
    echo "{$last['function']}() called from {$last['file']} line {$last['line']}\r\n"; 
}



test();


The only way would be using debug_backtrace(), but as the name says: it is for debugging. Your code should not attach any meaning or functionality in production based on where/when it's called.


It's so late but maybe can be useful, you can use get_called_class(), for the name of class who is called, and do not pass like a parameter insted of CLASS.


if you want to use this information in some kind of error message, there is a function trigger_error() which will raise PHP native error, so, therefore, it will be shown in usual PHP manner - with filename, line number and supplied text.

Most neat feature of this function is behaving according to current error handling settings:

ini_set('display_errors',1);
trigger_error("Horrible bug found!");

will print out directly to screen an error message like this:

Notice: Horrible bug found! in /path/file.php on line 2

very handy for developing
while this code

ini_set('display_errors',0);
ini_set('log_errors',1);
trigger_error("Horrible bug found!");

will be put into error log for the future reference
obligatory for the production

0

精彩评论

暂无评论...
验证码 换一张
取 消