diff options
Diffstat (limited to '')
-rw-r--r-- | library/vendor/Zend/Log/Formatter/Simple.php | 106 |
1 files changed, 106 insertions, 0 deletions
diff --git a/library/vendor/Zend/Log/Formatter/Simple.php b/library/vendor/Zend/Log/Formatter/Simple.php new file mode 100644 index 0000000..b2c2376 --- /dev/null +++ b/library/vendor/Zend/Log/Formatter/Simple.php @@ -0,0 +1,106 @@ +<?php +/** + * Zend Framework + * + * LICENSE + * + * This source file is subject to the new BSD license that is bundled + * with this package in the file LICENSE.txt. + * It is also available through the world-wide-web at this URL: + * http://framework.zend.com/license/new-bsd + * If you did not receive a copy of the license and are unable to + * obtain it through the world-wide-web, please send an email + * to license@zend.com so we can send you a copy immediately. + * + * @category Zend + * @package Zend_Log + * @subpackage Formatter + * @copyright Copyright (c) 2005-2015 Zend Technologies USA Inc. (http://www.zend.com) + * @license http://framework.zend.com/license/new-bsd New BSD License + * @version $Id$ + */ + +/** Zend_Log_Formatter_Abstract */ + +/** + * @category Zend + * @package Zend_Log + * @subpackage Formatter + * @copyright Copyright (c) 2005-2015 Zend Technologies USA Inc. (http://www.zend.com) + * @license http://framework.zend.com/license/new-bsd New BSD License + * @version $Id$ + */ +class Zend_Log_Formatter_Simple extends Zend_Log_Formatter_Abstract +{ + /** + * @var string + */ + protected $_format; + + const DEFAULT_FORMAT = '%timestamp% %priorityName% (%priority%): %message%'; + + /** + * Class constructor + * + * @param null|string $format Format specifier for log messages + * @return void + * @throws Zend_Log_Exception + */ + public function __construct($format = null) + { + if ($format === null) { + $format = self::DEFAULT_FORMAT . PHP_EOL; + } + + if (!is_string($format)) { + throw new Zend_Log_Exception('Format must be a string'); + } + + $this->_format = $format; + } + + /** + * Factory for Zend_Log_Formatter_Simple classe + * + * @param array|Zend_Config $options + * @return Zend_Log_Formatter_Simple + */ + public static function factory($options) + { + $format = null; + if (null !== $options) { + if ($options instanceof Zend_Config) { + $options = $options->toArray(); + } + + if (array_key_exists('format', $options)) { + $format = $options['format']; + } + } + + return new self($format); + } + + /** + * Formats data into a single line to be written by the writer. + * + * @param array $event event data + * @return string formatted line to write to the log + */ + public function format($event) + { + $output = $this->_format; + + foreach ($event as $name => $value) { + if ((is_object($value) && !method_exists($value,'__toString')) + || is_array($value) + ) { + $value = gettype($value); + } + + $output = str_replace("%$name%", $value, $output); + } + + return $output; + } +} |