2 Commits

4 changed files with 28 additions and 8 deletions

12
examples/basic.php Normal file
View File

@ -0,0 +1,12 @@
<?php
require_once __DIR__."/../vendor/autoload.php";
use NoccyLabs\Shell\Shell;
use NoccyLabs\Shell\Context;
$myShell = new Shell();
$myShell->setPrompt("test>");
$myShell->pushContext(new Context());
$myShell->run();

View File

@ -23,6 +23,11 @@ class Context
$this->configure(); $this->configure();
} }
public function getContextInfo()
{
return null;
}
public function setShell(Shell $shell) public function setShell(Shell $shell)
{ {
$this->shell = $shell; $this->shell = $shell;

View File

@ -68,11 +68,11 @@ class LineRead
$this->posCursor = strlen($this->buffer); $this->posCursor = strlen($this->buffer);
} }
$cursor = strlen($this->prompt) + 1 + $this->posCursor - $this->posScroll; $cursor = strlen($this->prompt) + 2 + $this->posCursor - $this->posScroll;
$endStyle = "\e[0m"; $endStyle = "\e[0m";
fprintf(STDOUT, "\r\e[2K%s%s\e[%dG{$endStyle}", ($this->promptStyle)($prompt), ($this->commandStyle)($buffer), $cursor); fprintf(STDOUT, "\r\e[2K%s %s\e[%dG{$endStyle}", ($this->promptStyle)($prompt), ($this->commandStyle)($buffer), $cursor);
} }
protected function styleToAnsi($style) protected function styleToAnsi($style)

View File

@ -19,6 +19,8 @@ class Shell
protected $timers = []; protected $timers = [];
protected $prompt = ">";
public function __construct() public function __construct()
{ {
$this->configure(); $this->configure();
@ -162,10 +164,11 @@ class Shell
public function setPrompt($text) public function setPrompt($text)
{ {
if (!$this->lineReader) { $this->prompt = $text;
return;
if ($this->lineReader) {
$this->lineReader->setPromptText($text);
} }
$this->lineReader->setPromptText($text);
} }
/** /**
@ -229,11 +232,11 @@ class Shell
switch ($command) { switch ($command) {
case '.': case '.':
$type = basename(strtr(get_class($this->context), "\\", "/")); $type = basename(strtr(get_class($this->context), "\\", "/"));
printf("%s<%s>: %s\n", $type, $this->context->getName(), json_encode($this->context->getData())); printf("%s<%s>: %s\n", $type, $this->context->getName(), $this->context->getContextInfo());
$level = 0; $level = 0;
foreach ($this->contextStack as $context) { foreach ($this->contextStack as $context) {
$type = basename(strtr(get_class($context), "\\", "/")); $type = basename(strtr(get_class($context), "\\", "/"));
printf(" %s- %s<%s>\n", str_repeat(" ",$level++), $type, $context->getName()); printf(" %s└─%s<%s>: %s\n", str_repeat(" ",$level++), $type, $context->getName(), $context->getContextInfo());
} }
break; break;
case '..': case '..':
@ -314,7 +317,7 @@ class Shell
{ {
$this->lineReader = new LineRead(); $this->lineReader = new LineRead();
$this->lineReader->setPromptText("shell>"); $this->lineReader->setPromptText($this->prompt);
$this->lineReader->setPromptStyle(new Style(Style::BR_GREEN)); $this->lineReader->setPromptStyle(new Style(Style::BR_GREEN));
$this->lineReader->setCommandStyle(new Style(Style::GREEN)); $this->lineReader->setCommandStyle(new Style(Style::GREEN));