2009-10-17 02:03:43 +00:00
|
|
|
<?php
|
2009-08-23 20:27:02 +00:00
|
|
|
/*
|
|
|
|
* $Id$
|
|
|
|
*
|
|
|
|
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
|
|
|
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
|
|
|
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
|
|
|
* A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
|
|
|
|
* OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
|
|
|
* SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
|
|
|
|
* LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
|
|
|
* DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
|
|
|
* THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
|
|
|
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
|
|
|
* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
|
|
*
|
|
|
|
* This software consists of voluntary contributions made by many individuals
|
|
|
|
* and is licensed under the LGPL. For more information, see
|
|
|
|
* <http://www.doctrine-project.org>.
|
|
|
|
*/
|
|
|
|
|
2009-11-17 01:29:20 +00:00
|
|
|
namespace Doctrine\Common\Cli\Printers;
|
2009-10-17 02:03:43 +00:00
|
|
|
|
2009-11-17 01:29:20 +00:00
|
|
|
use Doctrine\Common\Cli\Style;
|
2009-08-23 20:27:02 +00:00
|
|
|
|
2009-08-25 04:46:46 +00:00
|
|
|
/**
|
|
|
|
* CLI Output Printer.
|
|
|
|
* Abstract class responsable to provide basic methods to support output
|
|
|
|
* styling and excerpt limited by output margin.
|
|
|
|
*
|
|
|
|
* @license http://www.opensource.org/licenses/lgpl-license.php LGPL
|
|
|
|
* @link www.doctrine-project.org
|
|
|
|
* @since 2.0
|
|
|
|
* @version $Revision$
|
|
|
|
* @author Guilherme Blanco <guilhermeblanco@hotmail.com>
|
|
|
|
* @author Jonathan Wage <jonwage@gmail.com>
|
|
|
|
* @author Roman Borschel <roman@code-factory.org>
|
|
|
|
*/
|
2009-08-23 20:27:02 +00:00
|
|
|
abstract class AbstractPrinter
|
|
|
|
{
|
2009-08-25 04:46:46 +00:00
|
|
|
/**
|
|
|
|
* @var resource Output Stream
|
|
|
|
*/
|
2009-08-23 20:27:02 +00:00
|
|
|
protected $_stream;
|
|
|
|
|
2009-08-25 04:46:46 +00:00
|
|
|
/**
|
|
|
|
* @var integer Maximum column size
|
|
|
|
*/
|
2009-08-23 20:27:02 +00:00
|
|
|
protected $_maxColumnSize;
|
|
|
|
|
2009-08-25 04:46:46 +00:00
|
|
|
/**
|
|
|
|
* @var array Array of Styles
|
|
|
|
*/
|
2009-08-23 20:27:02 +00:00
|
|
|
protected $_styles;
|
|
|
|
|
2009-08-25 04:46:46 +00:00
|
|
|
/**
|
|
|
|
* Creates an instance of Printer
|
|
|
|
*
|
|
|
|
* @param resource $stream Output Stream
|
|
|
|
*/
|
2009-08-23 20:27:02 +00:00
|
|
|
public function __construct($stream = STDOUT)
|
|
|
|
{
|
|
|
|
$this->_stream = $stream;
|
2009-10-17 02:03:43 +00:00
|
|
|
$this->_maxColumnSize = 80;
|
2009-08-23 20:27:02 +00:00
|
|
|
|
|
|
|
$this->_initStyles();
|
|
|
|
}
|
|
|
|
|
2009-08-25 04:46:46 +00:00
|
|
|
/**
|
|
|
|
* Initializes Printer Styles
|
|
|
|
*
|
|
|
|
*/
|
2009-08-23 20:27:02 +00:00
|
|
|
protected function _initStyles()
|
|
|
|
{
|
|
|
|
// Defines base styles
|
|
|
|
$this->addStyles(array(
|
|
|
|
'ERROR' => new Style(),
|
|
|
|
'INFO' => new Style(),
|
|
|
|
'COMMENT' => new Style(),
|
2009-10-17 02:03:43 +00:00
|
|
|
'HEADER' => new Style(),
|
2009-08-23 20:27:02 +00:00
|
|
|
'NONE' => new Style(),
|
|
|
|
));
|
|
|
|
}
|
|
|
|
|
2009-08-25 04:46:46 +00:00
|
|
|
/**
|
|
|
|
* Add a collection of styles to the Printer.
|
|
|
|
* To include them, just call the method with the following structure:
|
|
|
|
*
|
|
|
|
* [php]
|
|
|
|
* $printer->addStyles(array(
|
|
|
|
* 'ERROR' => new Style('BLACK', 'DEFAULT', array('BOLD' => true)),
|
|
|
|
* ...
|
|
|
|
* ));
|
|
|
|
*
|
|
|
|
* @param array $tasks CLI Tasks to be included
|
|
|
|
*/
|
2009-08-23 20:27:02 +00:00
|
|
|
public function addStyles($styles)
|
|
|
|
{
|
|
|
|
foreach ($styles as $name => $style) {
|
|
|
|
$this->addStyle($name, $style);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2009-08-25 04:46:46 +00:00
|
|
|
/**
|
|
|
|
* Add a single Style to Printer.
|
|
|
|
* Example of inclusion to support a new Style:
|
|
|
|
*
|
|
|
|
* [php]
|
|
|
|
* $printer->addStyle('ERROR', new Style('BLACK', 'DEFAULT', array('BOLD' => true)));
|
|
|
|
*
|
|
|
|
* @param string $name Style name
|
|
|
|
* @param Style $style Style instance
|
|
|
|
*/
|
2009-08-23 20:27:02 +00:00
|
|
|
public function addStyle($name, Style $style)
|
|
|
|
{
|
|
|
|
$this->_styles[strtoupper($name)] = $style;
|
|
|
|
}
|
|
|
|
|
2009-08-25 04:46:46 +00:00
|
|
|
/**
|
|
|
|
* Retrieves a defined Style.
|
|
|
|
*
|
|
|
|
* @return Style
|
|
|
|
*/
|
2009-08-23 20:27:02 +00:00
|
|
|
public function getStyle($name)
|
|
|
|
{
|
2009-10-07 07:45:08 +00:00
|
|
|
if (is_string($name)) {
|
|
|
|
$name = strtoupper($name);
|
|
|
|
return isset($this->_styles[$name]) ? $this->_styles[$name] : null;
|
|
|
|
} else {
|
|
|
|
return $name;
|
|
|
|
}
|
2009-08-23 20:27:02 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Sets the maximum column size (defines the CLI margin).
|
|
|
|
*
|
2009-10-17 02:03:43 +00:00
|
|
|
* @param integer $maxColumnSize The maximum column size for a message
|
2009-08-23 20:27:02 +00:00
|
|
|
*/
|
|
|
|
public function setMaxColumnSize($maxColumnSize)
|
|
|
|
{
|
2009-10-17 02:03:43 +00:00
|
|
|
$this->_maxColumnSize = $maxColumnSize;
|
2009-08-23 20:27:02 +00:00
|
|
|
}
|
2009-11-17 01:29:20 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Writes to the output stream.
|
|
|
|
*
|
|
|
|
* @param string $message Message to be outputted
|
|
|
|
*/
|
|
|
|
public function output($message)
|
|
|
|
{
|
|
|
|
fwrite($this->_stream, $message);
|
|
|
|
|
|
|
|
return $this;
|
|
|
|
}
|
2009-08-23 20:27:02 +00:00
|
|
|
|
|
|
|
/**
|
2009-11-17 01:29:20 +00:00
|
|
|
* Formats message applying the defined style and writes to the output stream.
|
2009-08-23 20:27:02 +00:00
|
|
|
*
|
|
|
|
* @param string $message Message to be outputted
|
|
|
|
* @param mixed $style Optional style to be applied in message
|
|
|
|
*/
|
2009-09-01 16:48:28 +00:00
|
|
|
public function write($message, $style = 'NONE')
|
2009-08-23 20:27:02 +00:00
|
|
|
{
|
2009-11-17 01:29:20 +00:00
|
|
|
$this->output($this->format($message, $style));
|
2009-09-01 16:48:28 +00:00
|
|
|
|
|
|
|
return $this;
|
2009-08-23 20:27:02 +00:00
|
|
|
}
|
|
|
|
|
2009-08-31 16:21:29 +00:00
|
|
|
/**
|
|
|
|
* Writes a line to the output stream, formatting it by applying the defined style.
|
|
|
|
*
|
|
|
|
* @param string $message Message to be outputted
|
|
|
|
* @param mixed $style Optional style to be applied in message
|
|
|
|
*/
|
2009-09-01 16:48:28 +00:00
|
|
|
public function writeln($message, $style = 'NONE')
|
2009-08-31 16:21:29 +00:00
|
|
|
{
|
2009-09-01 16:48:28 +00:00
|
|
|
return $this->write($message . PHP_EOL, $style);
|
2009-08-31 16:21:29 +00:00
|
|
|
}
|
|
|
|
|
2009-08-23 20:27:02 +00:00
|
|
|
/**
|
|
|
|
* Formats the given message with the defined style.
|
|
|
|
*
|
|
|
|
* @param string $message Message to be formatted
|
|
|
|
* @param mixed $style Style to be applied in message
|
|
|
|
* @return string Formatted message
|
|
|
|
*/
|
2009-10-07 07:45:08 +00:00
|
|
|
abstract public function format($message, $style);
|
2009-08-23 20:27:02 +00:00
|
|
|
}
|