Fix stack trace on objects that don't extend the Object class

git-svn-id: svn://svn.silverstripe.com/silverstripe/open/modules/sapphire/trunk@47716 467b73ca-7a2a-4603-9d3b-597d59a354a9
This commit is contained in:
Andrew O'Neil 2008-01-08 03:00:38 +00:00
parent 3ce88a07d9
commit 84a3cd29d0
2 changed files with 40 additions and 20 deletions

View File

@ -48,9 +48,18 @@ class Debug {
} }
static function text($val) { static function text($val) {
if(is_object($val) && $val->hasMethod('debug')) { if(is_object($val)) {
return $val->debug(); if(method_exists($val, 'hasMethod')) {
$hasDebugMethod = $val->hasMethod('debug');
} else { } else {
$hasDebugMethod = method_exists($val, 'debug');
}
if($hasDebugMethod) {
return $val->debug();
}
}
if(is_array($val)) { if(is_array($val)) {
$result = "<ul>\n"; $result = "<ul>\n";
foreach($val as $k => $v) { foreach($val as $k => $v) {
@ -68,7 +77,6 @@ class Debug {
return $val; return $val;
} }
}
/** /**
* Show a debugging message * Show a debugging message
@ -144,6 +152,7 @@ class Debug {
echo "<p style=\"color: white; background-color: red; margin: 0\">FATAL ERROR: $errstr<br />\n At line $errline in $errfile<br />\n<br />\n</p>\n"; echo "<p style=\"color: white; background-color: red; margin: 0\">FATAL ERROR: $errstr<br />\n At line $errline in $errfile<br />\n<br />\n</p>\n";
Debug::backtrace(); Debug::backtrace();
//Debug::show(debug_backtrace());
echo "<h2>Context</h2>\n"; echo "<h2>Context</h2>\n";
Debug::show($errcontext); Debug::show($errcontext);
@ -254,6 +263,8 @@ class Debug {
} }
} }
$result .= 'hi';
echo $result;
if($returnVal) return $result; if($returnVal) return $result;
else echo $result; else echo $result;
} }
@ -268,7 +279,16 @@ class Debug {
if(isset($item['function'])) $funcName .= $item['function']; if(isset($item['function'])) $funcName .= $item['function'];
if($showArgs && isset($item['args'])) { if($showArgs && isset($item['args'])) {
@$funcName .= "(" . implode(",", (array)$item['args']) .")"; $args = array();
foreach($item['args'] as $arg) {
if(!is_object($arg) || method_exists($arg, '__toString')) {
$args[] = (string) $arg;
} else {
$args[] = get_class($arg);
}
}
$funcName .= "(" . implode(",", $args) .")";
} }
return $funcName; return $funcName;