Вход Регистрация
Файл: gapps/vendor/symfony/var-dumper/Dumper/AbstractDumper.php
Строк: 197
<?php

/*
 * This file is part of the Symfony package.
 *
 * (c) Fabien Potencier <fabien@symfony.com>
 *
 * For the full copyright and license information, please view the LICENSE
 * file that was distributed with this source code.
 */

namespace SymfonyComponentVarDumperDumper;

use 
SymfonyComponentVarDumperClonerData;
use 
SymfonyComponentVarDumperClonerDumperInterface;

/**
 * Abstract mechanism for dumping a Data object.
 *
 * @author Nicolas Grekas <p@tchwork.com>
 */
abstract class AbstractDumper implements DataDumperInterfaceDumperInterface
{
    public static 
$defaultOutput 'php://output';

    protected 
$line '';
    protected 
$lineDumper;
    protected 
$outputStream;
    protected 
$decimalPoint// This is locale dependent
    
protected $indentPad '  ';

    private 
$charset;

    
/**
     * @param callable|resource|string|null $output  A line dumper callable, an opened stream or an output path, defaults to static::$defaultOutput
     * @param string                        $charset The default character encoding to use for non-UTF8 strings
     */
    
public function __construct($output null$charset null)
    {
        
$this->setCharset($charset ?: ini_get('php.output_encoding') ?: ini_get('default_charset') ?: 'UTF-8');
        
$this->decimalPoint = (string) 0.5;
        
$this->decimalPoint $this->decimalPoint[1];
        
$this->setOutput($output ?: static::$defaultOutput);
        if (!
$output && is_string(static::$defaultOutput)) {
            static::
$defaultOutput $this->outputStream;
        }
    }

    
/**
     * Sets the output destination of the dumps.
     *
     * @param callable|resource|string $output A line dumper callable, an opened stream or an output path
     *
     * @return callable|resource|string The previous output destination
     */
    
public function setOutput($output)
    {
        
$prev null !== $this->outputStream $this->outputStream $this->lineDumper;

        if (
is_callable($output)) {
            
$this->outputStream null;
            
$this->lineDumper $output;
        } else {
            if (
is_string($output)) {
                
$output fopen($output'wb');
            }
            
$this->outputStream $output;
            
$this->lineDumper = array($this'echoLine');
        }

        return 
$prev;
    }

    
/**
     * Sets the default character encoding to use for non-UTF8 strings.
     *
     * @param string $charset The default character encoding to use for non-UTF8 strings
     *
     * @return string The previous charset
     */
    
public function setCharset($charset)
    {
        
$prev $this->charset;

        
$charset strtoupper($charset);
        
$charset null === $charset || 'UTF-8' === $charset || 'UTF8' === $charset 'CP1252' $charset;

        
$this->charset $charset;

        return 
$prev;
    }

    
/**
     * Sets the indentation pad string.
     *
     * @param string $pad A string the will be prepended to dumped lines, repeated by nesting level
     *
     * @return string The indent pad
     */
    
public function setIndentPad($pad)
    {
        
$prev $this->indentPad;
        
$this->indentPad $pad;

        return 
$prev;
    }

    
/**
     * Dumps a Data object.
     *
     * @param Data                          $data   A Data object
     * @param callable|resource|string|null $output A line dumper callable, an opened stream or an output path
     */
    
public function dump(Data $data$output null)
    {
        
$exception null;
        if (
$output) {
            
$prevOutput $this->setOutput($output);
        }
        try {
            
$data->dump($this);
            
$this->dumpLine(-1);
        } catch (
Exception $exception) {
            
// Re-thrown below
        
} catch (Throwable $exception) {
            
// Re-thrown below
        
}
        if (
$output) {
            
$this->setOutput($prevOutput);
        }
        if (
null !== $exception) {
            throw 
$exception;
        }
    }

    
/**
     * Dumps the current line.
     *
     * @param int $depth The recursive depth in the dumped structure for the line being dumped
     */
    
protected function dumpLine($depth)
    {
        
call_user_func($this->lineDumper$this->line$depth$this->indentPad);
        
$this->line '';
    }

    
/**
     * Generic line dumper callback.
     *
     * @param string $line  The line to write
     * @param int    $depth The recursive depth in the dumped structure
     */
    
protected function echoLine($line$depth$indentPad)
    {
        if (-
!== $depth) {
            
fwrite($this->outputStreamstr_repeat($indentPad$depth).$line."n");
        }
    }

    
/**
     * Converts a non-UTF-8 string to UTF-8.
     *
     * @param string $s The non-UTF-8 string to convert
     *
     * @return string The string converted to UTF-8
     */
    
protected function utf8Encode($s)
    {
        if (
false !== $c = @iconv($this->charset'UTF-8'$s)) {
            return 
$c;
        }
        if (
'CP1252' !== $this->charset && false !== $c = @iconv('CP1252''UTF-8'$s)) {
            return 
$c;
        }

        return 
iconv('CP850''UTF-8'$s);
    }
}
Онлайн: 0
Реклама