diff --git a/NEWS b/NEWS
index a21f2985..317b5656 100644
--- a/NEWS
+++ b/NEWS
@@ -1,3 +1,4 @@
+- enhance reporting precision of debug_print_var modifier (cybot, boots)
- make html_select_date work consistently with 0000-00-00 00:00:00 and
0000-00-00 inputs (cybot, boots)
- fix wrong handling of insert's name attribute. (messju)
diff --git a/libs/plugins/modifier.debug_print_var.php b/libs/plugins/modifier.debug_print_var.php
index d28956a0..aeba8e15 100644
--- a/libs/plugins/modifier.debug_print_var.php
+++ b/libs/plugins/modifier.debug_print_var.php
@@ -22,33 +22,64 @@
*/
function smarty_modifier_debug_print_var($var, $depth = 0, $length = 40)
{
- $_replace = array("\n"=>'\n', "\r"=>'\r', "\t"=>'\t');
- if (is_array($var)) {
- $results = "Array (".count($var).")";
- foreach ($var as $curr_key => $curr_val) {
- $return = smarty_modifier_debug_print_var($curr_val, $depth+1, $length);
- $results .= "
".str_repeat(' ', $depth*2)."".strtr($curr_key, $_replace)." => $return";
- }
- } else if (is_object($var)) {
- $object_vars = get_object_vars($var);
- $results = "".get_class($var)." Object (".count($object_vars).")";
- foreach ($object_vars as $curr_key => $curr_val) {
- $return = smarty_modifier_debug_print_var($curr_val, $depth+1, $length);
- $results .= "
".str_repeat(' ', $depth*2)."$curr_key => $return";
- }
- } else if (is_resource($var)) {
- $results = ''.(string)$var.'';
- } else if (empty($var) && $var != "0") {
- $results = 'empty';
- } else {
- if (strlen($var) > $length ) {
- $results = substr($var, 0, $length-3).'...';
- } else {
- $results = $var;
- }
- $results = htmlspecialchars($results);
- $results = strtr($results, $_replace);
+ $_replace = array(
+ "\n" => '\n',
+ "\r" => '\r',
+ "\t" => '\t'
+ );
+
+ switch (gettype($var)) {
+ case 'array' :
+ $results = 'Array (' . count($var) . ')';
+ foreach ($var as $curr_key => $curr_val) {
+ $results .= '
' . str_repeat(' ', $depth * 2)
+ . '' . strtr($curr_key, $_replace) . ' => '
+ . smarty_modifier_debug_print_var($curr_val, ++$depth, $length);
+ }
+ break;
+ case 'object' :
+ $object_vars = get_object_vars($var);
+ $results = '' . get_class($var) . ' Object (' . count($object_vars) . ')';
+ foreach ($object_vars as $curr_key => $curr_val) {
+ $results .= '
' . str_repeat(' ', $depth * 2)
+ . '' . strtr($curr_key, $_replace) . ' => '
+ . smarty_modifier_debug_print_var($curr_val, ++$depth, $length);
+ }
+ break;
+ case 'boolean' :
+ case 'NULL' :
+ case 'resource' :
+ if (true === $var) {
+ $results = 'true';
+ } elseif (false === $var) {
+ $results = 'false';
+ } elseif (null === $var) {
+ $results = 'null';
+ } else {
+ $results = htmlspecialchars((string) $var);
+ }
+ $results = '' . $results . '';
+ break;
+ case 'integer' :
+ case 'float' :
+ $results = htmlspecialchars((string) $var);
+ break;
+ case 'string' :
+ $results = strtr($var, $_replace);
+ if (strlen($var) > $length ) {
+ $results = substr($var, 0, $length - 3) . '...';
+ }
+ $results = htmlspecialchars('"' . $results . '"');
+ break;
+ case 'unknown type' :
+ default :
+ $results = strtr((string) $var, $_replace);
+ if (strlen($results) > $length ) {
+ $results = substr($results, 0, $length - 3) . '...';
+ }
+ $results = htmlspecialchars($results);
}
+
return $results;
}