[BUGFIX] Fix small DebuggerUtility issues
authorAlexander Schnitzler <alex.schnitzler@typovision.de>
Fri, 16 Nov 2012 10:11:25 +0000 (11:11 +0100)
committerAlexander Schnitzler <typo3@alexanderschnitzler.de>
Sat, 17 Nov 2012 13:20:15 +0000 (14:20 +0100)
* adjust css for better/safer margins
* respect ArrayAccess
* fix level depth in array rendering
* fix wrong display of max depth with arrays
* remove expand icon for empty objects/collections

Releases: 6.0
Fixes: #43051
Change-Id: I6641d53df7b9591598c738b9ea55ba96939d2224
Reviewed-on: http://review.typo3.org/16516
Reviewed-by: Mattias Nilsson
Tested-by: Mattias Nilsson
Reviewed-by: Anja Leichsenring
Tested-by: Anja Leichsenring
Reviewed-by: Alexander Schnitzler
Tested-by: Alexander Schnitzler
typo3/sysext/extbase/Classes/Utility/DebuggerUtility.php

index 499f1a3..32cda18 100644 (file)
@@ -127,24 +127,29 @@ class DebuggerUtility {
         * @return string
         */
        static protected function renderArray($array, $level, $plainText = FALSE, $ansiColors = FALSE) {
         * @return string
         */
        static protected function renderArray($array, $level, $plainText = FALSE, $ansiColors = FALSE) {
-               $type = is_array($array) ? 'array' : get_class($array);
+               $content = '';
+               $count = count($array);
+
                if ($plainText) {
                if ($plainText) {
-                       $header = self::ansiEscapeWrap($type, '36', $ansiColors);
+                       $header = self::ansiEscapeWrap('array', '36', $ansiColors);
                } else {
                } else {
-                       $header = '<span class="debug-type">' . $type . '</span>';
+                       $header = '<span class="debug-type">array</span>';
                }
                }
-               $header .= count($array) > 0 ? ' (' . count($array) . ' items)' : ' (empty)';
+               $header .= $count > 0 ? '(' . $count . ' item' . ($count > 1 ? 's' : '') . ')' : '(empty)';
                if ($level >= self::$maxDepth) {
                        if ($plainText) {
                if ($level >= self::$maxDepth) {
                        if ($plainText) {
-                               $content = ' ' . self::ansiEscapeWrap('max depth', '47;30', $ansiColors);
+                               $header .= ' ' . self::ansiEscapeWrap('max depth', '47;30', $ansiColors);
                        } else {
                        } else {
-                               $content = '<span class="debug-filtered">max depth</span>';
+                               $header .= '<span class="debug-filtered">max depth</span>';
                        }
                } else {
                        $content = self::renderCollection($array, $level, $plainText, $ansiColors);
                        }
                } else {
                        $content = self::renderCollection($array, $level, $plainText, $ansiColors);
+                       if (!$plainText) {
+                               $header = ($level > 1 && $count > 0 ? '<input type="checkbox" /><span class="debug-header" >' : '<span>') . $header . '</span >';
+                       }
                }
                }
-               if ($level > 1 && count($array) > 0 && !$plainText) {
-                       $dump = '<span class="debug-tree"><input type="checkbox" /><span class="debug-header">' . $header . '</span><span class="debug-content">' . $content . '</span></span>';
+               if ($level > 1 && $count > 0 && !$plainText) {
+                       $dump = '<span class="debug-tree">' . $header . '<span class="debug-content">' . $content . '</span></span>';
                } else {
                        $dump = $header . $content;
                }
                } else {
                        $dump = $header . $content;
                }
@@ -216,6 +221,7 @@ class DebuggerUtility {
                $dump = '';
                $persistenceType = '';
                $className = get_class($object);
                $dump = '';
                $persistenceType = '';
                $className = get_class($object);
+               $classReflection = new \ReflectionClass($className);
                if ($plainText) {
                        $dump .= self::ansiEscapeWrap($className, '36', $ansiColors);
                } else {
                if ($plainText) {
                        $dump .= self::ansiEscapeWrap($className, '36', $ansiColors);
                } else {
@@ -253,7 +259,7 @@ class DebuggerUtility {
                if ($plainText) {
                        $dump .= ' ' . self::ansiEscapeWrap(($persistenceType . ' ' . $domainObjectType), '42;30', $ansiColors);
                } else {
                if ($plainText) {
                        $dump .= ' ' . self::ansiEscapeWrap(($persistenceType . ' ' . $domainObjectType), '42;30', $ansiColors);
                } else {
-                       $dump .= '<span class="debug-ptype">' . $persistenceType . ' ' . $domainObjectType . '</span>';
+                       $dump .= '<span class="debug-ptype">' . ($persistenceType ? $persistenceType . ' ' : '') . $domainObjectType . '</span>';
                }
                if (strpos(implode('|', self::$blacklistedClassNames), get_class($object)) > 0) {
                        if ($plainText) {
                }
                if (strpos(implode('|', self::$blacklistedClassNames), get_class($object)) > 0) {
                        if ($plainText) {
@@ -270,7 +276,11 @@ class DebuggerUtility {
                                $dump .= '<span class="debug-filtered">max depth</span>';
                        }
                } elseif ($level > 1 && !$object instanceof \DateTime && !$plainText) {
                                $dump .= '<span class="debug-filtered">max depth</span>';
                        }
                } elseif ($level > 1 && !$object instanceof \DateTime && !$plainText) {
-                       $dump = '<input type="checkbox" id="' . spl_object_hash($object) . '" /><span class="debug-header">' . $dump . '</span>';
+                       if (($object instanceof \Countable && count($object) === 0) || (count($classReflection->getProperties()) === 0)) {
+                               $dump = '<span>' . $dump . '</span>';
+                       } else {
+                               $dump = '<input type="checkbox" id="' . spl_object_hash($object) . '" /><span class="debug-header">' . $dump . '</span>';
+                       }
                }
                if ($object instanceof \Countable) {
                        $dump .= count($object) > 0 ? ' (' . count($object) . ' items)' : ' (empty)';
                }
                if ($object instanceof \Countable) {
                        $dump .= count($object) > 0 ? ' (' . count($object) . ' items)' : ' (empty)';
@@ -293,7 +303,7 @@ class DebuggerUtility {
         */
        static protected function renderContent($object, $level, $plainText, $ansiColors) {
                $dump = '';
         */
        static protected function renderContent($object, $level, $plainText, $ansiColors) {
                $dump = '';
-               if ($object instanceof \TYPO3\CMS\Extbase\Persistence\ObjectStorage || $object instanceof \Iterator) {
+               if ($object instanceof \TYPO3\CMS\Extbase\Persistence\ObjectStorage || $object instanceof \Iterator || $object instanceof \ArrayObject) {
                        $dump .= self::renderCollection($object, $level, $plainText, $ansiColors);
                } else {
                        self::$renderedObjects->attach($object);
                        $dump .= self::renderCollection($object, $level, $plainText, $ansiColors);
                } else {
                        self::$renderedObjects->attach($object);
@@ -332,7 +342,7 @@ class DebuggerUtility {
                $dump = '';
                foreach ($collection as $key => $value) {
                        $dump .= PHP_EOL . str_repeat(self::PLAINTEXT_INDENT, $level) . ($plainText ? '' : '<span class="debug-property">') . self::ansiEscapeWrap($key, '37', $ansiColors) . ($plainText ? '' : '</span>') . ' => ';
                $dump = '';
                foreach ($collection as $key => $value) {
                        $dump .= PHP_EOL . str_repeat(self::PLAINTEXT_INDENT, $level) . ($plainText ? '' : '<span class="debug-property">') . self::ansiEscapeWrap($key, '37', $ansiColors) . ($plainText ? '' : '</span>') . ' => ';
-                       $dump .= self::renderDump($value, $level + 1, $plainText, $ansiColors);
+                       $dump .= self::renderDump($value, $level, $plainText, $ansiColors);
                }
                return $dump;
        }
                }
                return $dump;
        }
@@ -396,12 +406,12 @@ class DebuggerUtility {
                                        .Extbase-Utility-Debugger-VarDump-Floating{position:relative;width:96%;margin:40px auto;}
                                        .Extbase-Utility-Debugger-VarDump-Top{background:#eee;font:normal bold 12px \'Lucida Grande\',sans-serif;padding:5px;}
                                        .Extbase-Utility-Debugger-VarDump-Center{background:#b9b9b9 url() 0 18px repeat;font:normal normal 11px/18px Monospaced,\'Lucida Console\',monospace;padding:18px 10px;}
                                        .Extbase-Utility-Debugger-VarDump-Floating{position:relative;width:96%;margin:40px auto;}
                                        .Extbase-Utility-Debugger-VarDump-Top{background:#eee;font:normal bold 12px \'Lucida Grande\',sans-serif;padding:5px;}
                                        .Extbase-Utility-Debugger-VarDump-Center{background:#b9b9b9 url() 0 18px repeat;font:normal normal 11px/18px Monospaced,\'Lucida Console\',monospace;padding:18px 10px;}
-                                       .Extbase-Utility-Debugger-VarDump-Center pre{background-color:transparent;margin:0;}
+                                       .Extbase-Utility-Debugger-VarDump-Center pre{background-color:transparent;margin:0;padding:0;}
                                        .Extbase-Utility-Debugger-VarDump-Center,.Extbase-Utility-Debugger-VarDump-Center pre,.Extbase-Utility-Debugger-VarDump-Center p,.Extbase-Utility-Debugger-VarDump-Center a,.Extbase-Utility-Debugger-VarDump-Center strong,.Extbase-Utility-Debugger-VarDump-Center .debug-string{font:normal normal 11px/18px Monospaced,\'Lucida Console\',monospace;}
                                        .Extbase-Utility-Debugger-VarDump-Center .debug-string{color:#000;white-space:normal;}
                                        .Extbase-Utility-Debugger-VarDump-Center .debug-type{color:#004fb0;padding-right:4px;}
                                        .Extbase-Utility-Debugger-VarDump-Center .debug-unregistered{background-color:#dce1e8;}
                                        .Extbase-Utility-Debugger-VarDump-Center,.Extbase-Utility-Debugger-VarDump-Center pre,.Extbase-Utility-Debugger-VarDump-Center p,.Extbase-Utility-Debugger-VarDump-Center a,.Extbase-Utility-Debugger-VarDump-Center strong,.Extbase-Utility-Debugger-VarDump-Center .debug-string{font:normal normal 11px/18px Monospaced,\'Lucida Console\',monospace;}
                                        .Extbase-Utility-Debugger-VarDump-Center .debug-string{color:#000;white-space:normal;}
                                        .Extbase-Utility-Debugger-VarDump-Center .debug-type{color:#004fb0;padding-right:4px;}
                                        .Extbase-Utility-Debugger-VarDump-Center .debug-unregistered{background-color:#dce1e8;}
-                                       .Extbase-Utility-Debugger-VarDump-Center .debug-scope,.Extbase-Utility-Debugger-VarDump-Center .debug-ptype,.Extbase-Utility-Debugger-VarDump-Center .debug-proxy,.Extbase-Utility-Debugger-VarDump-Center .debug-filtered{color:#FFF;font-size:10px;line-height:16px;padding:1px 4px;}
+                                       .Extbase-Utility-Debugger-VarDump-Center .debug-scope,.Extbase-Utility-Debugger-VarDump-Center .debug-ptype,.Extbase-Utility-Debugger-VarDump-Center .debug-proxy,.Extbase-Utility-Debugger-VarDump-Center .debug-filtered{color:#FFF;font-size:10px;line-height:16px;padding:1px 4px;margin-right:2px;}
                                        .Extbase-Utility-Debugger-VarDump-Center .debug-scope{background-color:#3e7fe1;}
                                        .Extbase-Utility-Debugger-VarDump-Center .debug-ptype{background-color:#6FBC16;}
                                        .Extbase-Utility-Debugger-VarDump-Center .debug-dirty{background-color:#FFFF00;}
                                        .Extbase-Utility-Debugger-VarDump-Center .debug-scope{background-color:#3e7fe1;}
                                        .Extbase-Utility-Debugger-VarDump-Center .debug-ptype{background-color:#6FBC16;}
                                        .Extbase-Utility-Debugger-VarDump-Center .debug-dirty{background-color:#FFFF00;}