if ($plainText) {
$dump = self::ansiEscapeWrap(('"' . implode((PHP_EOL . str_repeat(self::PLAINTEXT_INDENT, ($level + 1))), str_split($croppedValue, 76)) . '"'), '33', $ansiColors) . ' (' . strlen($value) . ' chars)';
} else {
- $dump = sprintf('\'<span class="debug-string">%s</span>\' (%s chars)', implode('<br />' . str_repeat(self::HTML_INDENT, ($level + 1)), str_split(htmlspecialchars($croppedValue), 76)), strlen($value));
+ $dump = sprintf('\'<span class="extbase-debug-string">%s</span>\' (%s chars)', implode('<br />' . str_repeat(self::HTML_INDENT, ($level + 1)), str_split(htmlspecialchars($croppedValue), 76)), strlen($value));
}
} elseif (is_numeric($value)) {
$dump = sprintf('%s (%s)', self::ansiEscapeWrap($value, '35', $ansiColors), gettype($value));
if ($plainText) {
$header = self::ansiEscapeWrap('array', '36', $ansiColors);
} else {
- $header = '<span class="debug-type">array</span>';
+ $header = '<span class="extbase-debug-type">array</span>';
}
$header .= $count > 0 ? '(' . $count . ' item' . ($count > 1 ? 's' : '') . ')' : '(empty)';
if ($level >= self::$maxDepth) {
if ($plainText) {
$header .= ' ' . self::ansiEscapeWrap('max depth', '47;30', $ansiColors);
} else {
- $header .= '<span class="debug-filtered">max depth</span>';
+ $header .= '<span class="extbase-debug-filtered">max depth</span>';
}
} 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 >';
+ $header = ($level > 1 && $count > 0 ? '<input type="checkbox" /><span class="extbase-debug-header" >' : '<span>') . $header . '</span >';
}
}
if ($level > 1 && $count > 0 && !$plainText) {
- $dump = '<span class="debug-tree">' . $header . '<span class="debug-content">' . $content . '</span></span>';
+ $dump = '<span class="extbase-debugger-tree">' . $header . '<span class="extbase-debug-content">' . $content . '</span></span>';
} else {
$dump = $header . $content;
}
if ($plainText) {
return $header . $content;
} else {
- return '<span class="debug-tree">' . $header . '<span class="debug-content">' . $content . '</span></span>';
+ return '<span class="extbase-debugger-tree">' . $header . '<span class="extbase-debug-content">' . $content . '</span></span>';
}
}
if ($plainText) {
$dump .= self::ansiEscapeWrap($className, '36', $ansiColors);
} else {
- $dump .= '<span class="debug-type">' . $className . '</span>';
+ $dump .= '<span class="extbase-debug-type">' . $className . '</span>';
}
if ($object instanceof \TYPO3\CMS\Core\SingletonInterface) {
$scope = 'singleton';
if ($plainText) {
$dump .= ' ' . self::ansiEscapeWrap($scope, '44;37', $ansiColors);
} else {
- $dump .= $scope ? '<span class="debug-scope">' . $scope . '</span>' : '';
+ $dump .= $scope ? '<span class="extbase-debug-scope">' . $scope . '</span>' : '';
}
if ($object instanceof \TYPO3\CMS\Extbase\DomainObject\AbstractDomainObject) {
if ($object->_isDirty()) {
if ($plainText) {
$dump .= ' ' . self::ansiEscapeWrap(($persistenceType . ' ' . $domainObjectType), '42;30', $ansiColors);
} else {
- $dump .= '<span class="debug-ptype">' . ($persistenceType ? $persistenceType . ' ' : '') . $domainObjectType . '</span>';
+ $dump .= '<span class="extbase-debug-ptype">' . ($persistenceType ? $persistenceType . ' ' : '') . $domainObjectType . '</span>';
}
if (strpos(implode('|', self::$blacklistedClassNames), get_class($object)) > 0) {
if ($plainText) {
$dump .= ' ' . self::ansiEscapeWrap('filtered', '47;30', $ansiColors);
} else {
- $dump .= '<span class="debug-filtered">filtered</span>';
+ $dump .= '<span class="extbase-debug-filtered">filtered</span>';
}
} elseif (self::$renderedObjects->contains($object) && !$plainText) {
- $dump = '<a href="javascript:;" onclick="document.location.hash=\'#' . spl_object_hash($object) . '\';" class="debug-seeabove">' . $dump . '<span class="debug-filtered">see above</span></a>';
+ $dump = '<a href="javascript:;" onclick="document.location.hash=\'#' . spl_object_hash($object) . '\';" class="extbase-debug-seeabove">' . $dump . '<span class="extbase-debug-filtered">see above</span></a>';
} elseif ($level >= self::$maxDepth && !$object instanceof \DateTime) {
if ($plainText) {
$dump .= ' ' . self::ansiEscapeWrap('max depth', '47;30', $ansiColors);
} else {
- $dump .= '<span class="debug-filtered">max depth</span>';
+ $dump .= '<span class="extbase-debug-filtered">max depth</span>';
}
} elseif ($level > 1 && !$object instanceof \DateTime && !$plainText) {
if (($object instanceof \Countable && empty($object)) || empty($classReflection->getProperties())) {
$dump = '<span>' . $dump . '</span>';
} else {
- $dump = '<input type="checkbox" id="' . spl_object_hash($object) . '" /><span class="debug-header">' . $dump . '</span>';
+ $dump = '<input type="checkbox" id="' . spl_object_hash($object) . '" /><span class="extbase-debug-header">' . $dump . '</span>';
}
}
if ($object instanceof \Countable) {
if (self::isBlacklisted($property)) {
continue;
}
- $dump .= PHP_EOL . str_repeat(self::PLAINTEXT_INDENT, $level) . ($plainText ? '' : '<span class="debug-property">') . self::ansiEscapeWrap($property->getName(), '37', $ansiColors) . ($plainText ? '' : '</span>') . ' => ';
+ $dump .= PHP_EOL . str_repeat(self::PLAINTEXT_INDENT, $level) . ($plainText ? '' : '<span class="extbase-debug-property">') . self::ansiEscapeWrap($property->getName(), '37', $ansiColors) . ($plainText ? '' : '</span>') . ' => ';
$property->setAccessible(TRUE);
$dump .= self::renderDump($property->getValue($object), $level, $plainText, $ansiColors);
if ($object instanceof \TYPO3\CMS\Extbase\DomainObject\AbstractDomainObject && !$object->_isNew() && $object->_isDirty($property->getName())) {
if ($plainText) {
$dump .= ' ' . self::ansiEscapeWrap('modified', '43;30', $ansiColors);
} else {
- $dump .= '<span class="debug-dirty">modified</span>';
+ $dump .= '<span class="extbase-debug-dirty">modified</span>';
}
}
}
static protected function renderCollection($collection, $level, $plainText, $ansiColors) {
$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 .= PHP_EOL . str_repeat(self::PLAINTEXT_INDENT, $level) . ($plainText ? '' : '<span class="extbase-debug-property">') . self::ansiEscapeWrap($key, '37', $ansiColors) . ($plainText ? '' : '</span>') . ' => ';
$dump .= self::renderDump($value, $level, $plainText, $ansiColors);
}
if ($collection instanceof \Iterator) {
if (!$plainText && self::$stylesheetEchoed === FALSE) {
echo '
<style type=\'text/css\'>
- .debug-tree{position:relative;}
- .debug-tree input{position:absolute;top:0;left:0;cursor:pointer;opacity:0;z-index:2;}
- .debug-tree input ~ .debug-content{display:none;}
- .debug-tree .debug-header:before{content:"+";padding:0 2px 0 2px;margin:0 3px 0 3px;font-size:1em;font-weight:bold;color:#004fb0;border:1px #004fb0 solid;}
- .debug-tree input:checked ~ .debug-content{display:inline;}
- .debug-tree input:checked ~ .debug-header:before{content:"-";}
- .Extbase-Utility-Debugger-VarDump{display:block;text-align:left;background:#b9b9b9;border:10px solid #b9b9b9;-moz-border-radius:10px;-webkit-border-radius:10px;border-radius:10px;-moz-box-shadow:0 0 20px #333;-webkit-box-shadow:0 0 20px #333;box-shadow:0 0 20px #333;z-index:999;color:#000;margin:20px 0 0;}
- .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;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 .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-filtered{background-color:#8c8c8c;}
- .Extbase-Utility-Debugger-VarDump-Center .debug-seeabove{text-decoration:none;font-style:italic;font-weight:400;}
- .Extbase-Utility-Debugger-VarDump-Center .debug-property{color:#555;line-height:16px;padding:1px 2px;}
+ .extbase-debugger-tree{position:relative}
+ .extbase-debugger-tree input{position:absolute;top:0;left:0;height:14px;width:14px;margin:0;cursor:pointer;opacity:0;z-index:2}
+ .extbase-debugger-tree input~.extbase-debug-content{display:none}
+ .extbase-debugger-tree .extbase-debug-header:before{position:relative;top:3px;content:"";padding:0;line-height:10px;height:12px;width:12px;text-align:center;margin:0 3px 0 0;background-image:url();display:inline-block}
+ .extbase-debugger-tree input:checked~.extbase-debug-content{display:inline}
+ .extbase-debugger-tree input:checked~.extbase-debug-header:before{background-image:url()}
+ .extbase-debugger{display:block;text-align:left;background:#2a2a2a;border:1px solid #2a2a2a;box-shadow:0 3px 0 rgba(0,0,0,.5);color:#000;margin:20px;overflow:hidden;border-radius:4px}
+ .extbase-debugger-floating{position:relative;z-index:999}
+ .extbase-debugger-top{background:#444;font-size:12px;font-family:monospace;color:#f1f1f1;padding:6px 15px}
+ .extbase-debugger-center{padding:0 15px;margin:15px 0;background-image:repeating-linear-gradient(to bottom,transparent 0,transparent 20px,#252525 20px,#252525 40px)}
+ .extbase-debugger-center,.extbase-debugger-center .extbase-debug-string,.extbase-debugger-center a,.extbase-debugger-center p,.extbase-debugger-center pre,.extbase-debugger-center strong{font-size:12px;font-weight:400;font-family:monospace;line-height:20px;color:#f1f1f1}
+ .extbase-debugger-center pre{background-color:transparent;margin:0;padding:0;border:0;word-wrap:break-word;color:#999}
+ .extbase-debugger-center .extbase-debug-string{color:#ce9178;white-space:normal}
+ .extbase-debugger-center .extbase-debug-type{color:#569CD6;padding-right:4px}
+ .extbase-debugger-center .extbase-debug-unregistered{background-color:#dce1e8}
+ .extbase-debugger-center .extbase-debug-filtered,.extbase-debugger-center .extbase-debug-proxy,.extbase-debugger-center .extbase-debug-ptype,.extbase-debugger-center .extbase-debug-scope{color:#fff;font-size:10px;line-height:12px;padding:2px 4px;margin-right:2px;position:relative;top:-1px}
+ .extbase-debugger-center .extbase-debug-scope{background-color:#497AA2}
+ .extbase-debugger-center .extbase-debug-ptype{background-color:#698747}
+ .extbase-debugger-center .extbase-debug-dirty{background-color:#FFFFB6}
+ .extbase-debugger-center .extbase-debug-filtered{background-color:#4F4F4F}
+ .extbase-debugger-center .extbase-debug-seeabove{text-decoration:none;font-style:italic}
+ .extbase-debugger-center .extbase-debug-property{color:#f1f1f1}
</style>';
self::$stylesheetEchoed = TRUE;
}
$output = $title . PHP_EOL . self::renderDump($variable, 0, TRUE, $ansiColors) . PHP_EOL . PHP_EOL;
} else {
$output = '
- <div class="Extbase-Utility-Debugger-VarDump ' . ($return ? 'Extbase-Utility-Debugger-VarDump-Inline' : 'Extbase-Utility-Debugger-VarDump-Floating') . '">
- <div class="Extbase-Utility-Debugger-VarDump-Top">' . htmlspecialchars($title) . '</div>
- <div class="Extbase-Utility-Debugger-VarDump-Center">
+ <div class="extbase-debugger ' . ($return ? 'extbase-debugger-inline' : 'extbase-debugger-floating') . '">
+ <div class="extbase-debugger-top">' . htmlspecialchars($title) . '</div>
+ <div class="extbase-debugger-center">
<pre dir="ltr">' . self::renderDump($variable, 0, FALSE, FALSE) . '</pre>
</div>
</div>