mirror of
https://github.com/zhamao-robot/zhamao-logger.git
synced 2026-07-02 14:25:40 +08:00
Compare commits
2 Commits
1.1.3
...
add-caller
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
0ee6e43f06 | ||
|
|
9da98fde5a |
@@ -17,7 +17,7 @@ class ConsoleLogger extends AbstractLogger
|
||||
*
|
||||
* @var string
|
||||
*/
|
||||
public static $format = '[%date%] [%level%] %body%';
|
||||
public static $format = '[%date%] [%level%] %caller% %body%';
|
||||
|
||||
/**
|
||||
* 日志输出日期格式
|
||||
@@ -139,6 +139,27 @@ class ConsoleLogger extends AbstractLogger
|
||||
return self::VERSION;
|
||||
}
|
||||
|
||||
/**
|
||||
* 插入字段到指定字段之前,或之后
|
||||
* @param string $field 字段名
|
||||
* @param string $alter 要插入的字段
|
||||
* @param string $position 插入位置,before 或 after
|
||||
*/
|
||||
public static function alterFormat(string $field, string $alter, string $position = 'before'): void
|
||||
{
|
||||
$format = self::$format;
|
||||
$pos = strpos($format, $field);
|
||||
if ($pos === false) {
|
||||
return;
|
||||
}
|
||||
if ($position === 'before') {
|
||||
$format = substr_replace($format, $alter, $pos, 0);
|
||||
} else {
|
||||
$format = substr_replace($format, $alter, $pos + strlen($field), 0);
|
||||
}
|
||||
self::$format = $format;
|
||||
}
|
||||
|
||||
/**
|
||||
* 添加静态上下文
|
||||
*/
|
||||
@@ -215,8 +236,13 @@ class ConsoleLogger extends AbstractLogger
|
||||
}
|
||||
|
||||
$output = str_replace(
|
||||
['%date%', '%level%', '%body%'],
|
||||
[date(self::$date_format), strtoupper(substr(self::$levels[$level], 0, 4)), $message],
|
||||
['%date%', '%level%', '%body%', '%caller%'],
|
||||
[
|
||||
date(self::$date_format),
|
||||
strtoupper(substr(self::$levels[$level], 0, 4)),
|
||||
$message,
|
||||
$this->getCaller(),
|
||||
],
|
||||
self::$format
|
||||
);
|
||||
$output = $this->interpolate($output, array_merge($this->static_context, $context));
|
||||
@@ -230,7 +256,7 @@ class ConsoleLogger extends AbstractLogger
|
||||
if ($this->decorated) {
|
||||
$output = $this->colorize($output, $level) . PHP_EOL;
|
||||
} else {
|
||||
$output = $output . PHP_EOL;
|
||||
$output .= PHP_EOL;
|
||||
}
|
||||
// use stream
|
||||
if ($this->stream) {
|
||||
@@ -313,4 +339,23 @@ class ConsoleLogger extends AbstractLogger
|
||||
|
||||
return strtr($message, $replace);
|
||||
}
|
||||
|
||||
/**
|
||||
* 获取调用者信息
|
||||
*/
|
||||
private function getCaller(): string
|
||||
{
|
||||
$trace = debug_backtrace(DEBUG_BACKTRACE_IGNORE_ARGS, 2);
|
||||
$caller = $trace[1] ?? [];
|
||||
$file = $caller['file'] ?? '';
|
||||
if ($file) {
|
||||
// 截取路径,获取 src 之后至多两级目录
|
||||
$path = substr($file, strpos($file, 'src') + 4);
|
||||
$path = explode(DIRECTORY_SEPARATOR, $path);
|
||||
$path = array_slice($path, 0, 2);
|
||||
} else {
|
||||
$path = ['unknown'];
|
||||
}
|
||||
return implode(' > ', $path);
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user