<?php
/**
* Zend Framework (http://framework.zend.com/)
*
* @link http://github.com/zendframework/zf2 for the canonical source repository
* @copyright Copyright (c) 2005-2014 Zend Technologies USA Inc. (http://www.zend.com)
* @license http://framework.zend.com/license/new-bsd New BSD License
*/
namespace Zend\Console\Prompt;
class Line extends AbstractPrompt
{
/**
* @var string
*/
protected $promptText = 'Please enter value: ';
/**
* @var bool
*/
protected $allowEmpty = false;
/**
* @var int
*/
protected $maxLength = 2048;
/**
* Ask the user for an answer (a line of text)
*
* @param string $promptText The prompt text to display in console
* @param bool $allowEmpty Is empty response allowed?
* @param int $maxLength Maximum response length
*/
public function __construct($promptText = 'Please enter value: ', $allowEmpty = false, $maxLength = 2048)
{
if ($promptText !== null) {
$this->setPromptText($promptText);
}
if ($allowEmpty !== null) {
$this->setAllowEmpty($allowEmpty);
}
if ($maxLength !== null) {
$this->setMaxLength($maxLength);
}
}
/**
* Show the prompt to user and return the answer.
*
* @return mixed
*/
public function show()
{
do {
$this->getConsole()->write($this->promptText);
$line = $this->getConsole()->readLine($this->maxLength);
} while (!$this->allowEmpty && !$line);
return $this->lastResponse = $line;
}
/**
* @param bool $allowEmpty
*/
public function setAllowEmpty($allowEmpty)
{
$this->allowEmpty = $allowEmpty;
}
/**
* @return bool
*/
public function getAllowEmpty()
{
return $this->allowEmpty;
}
/**
* @param int $maxLength
*/
public function setMaxLength($maxLength)
{
$this->maxLength = $maxLength;
}
/**
* @return int
*/
public function getMaxLength()
{
return $this->maxLength;
}
/**
* @param string $promptText
*/
public function setPromptText($promptText)
{
$this->promptText = $promptText;
}
/**
* @return string
*/
public function getPromptText()
{
return $this->promptText;
}
}