From 16353cc3c8105da9d6d69b844a5a693a5e13a5dd Mon Sep 17 00:00:00 2001 From: haristku Date: Tue, 22 Oct 2024 08:29:29 +0700 Subject: [PATCH 1/4] disable monitor interactive paging on windows --- Commands/Monitor.php | 146 ++++++++++++++++++++++++++++--------------- 1 file changed, 95 insertions(+), 51 deletions(-) diff --git a/Commands/Monitor.php b/Commands/Monitor.php index 1cbaea6..fcfcb15 100644 --- a/Commands/Monitor.php +++ b/Commands/Monitor.php @@ -19,9 +19,14 @@ class Monitor extends ConsoleCommand protected function configure() { $this->setName('queuedtracking:monitor'); - $this->setDescription("Shows and updates the current state of the queue every 2 seconds.\n Key ,=first page, .=last page, 0-9=move to page section, arrow LEFT=prev page, RIGHT=next page, UP=next 10 pages, DOWN=prev 10 pages, q=quit"); + if ($this->interactiveCapability()) { + $this->setDescription("Shows and updates the current state of the queue every 2 seconds.\n Key ,=first page, .=last page, 0-9=move to page section, arrow LEFT=prev page, RIGHT=next page, UP=next 10 pages, DOWN=prev 10 pages, q=quit"); + } else { + $this->setDescription("Shows and updates the current state of the queue every 2 seconds."); + } $this->addRequiredValueOption('iterations', null, 'If set, will limit the number of monitoring iterations done.'); - $this->addRequiredValueOption('perpage', 'p', 'Number of queue worker displayed per page.', 16); + $this->addRequiredValueOption('rowperpage', 'r', 'Number of queue worker displayed per page.', 16); + $this->addRequiredValueOption('jumptopage', 'p', 'Jump to page (p).', 1); } /** @@ -66,14 +71,15 @@ protected function doExecute(): int )); $iterationCount = 0; - $qCurrentPage = 1; + $qCurrentPage = $this->getJumpToPageFromArg(); $qCount = count($queues); $qPerPAge = min(max($this->getPerPageFromArg(), 1), $qCount); $qPageCount = ceil($qCount / $qPerPAge); - - readline_callback_handler_install('', function () { - }); - stream_set_blocking(STDIN, false); + + if ($this->interactiveCapability()) { + readline_callback_handler_install('', function () {}); + stream_set_blocking(STDIN, false); + } $output->writeln(str_repeat("-", 30)); $output->writeln("" . str_pad(" Q INDEX", 10) . str_pad(" | REQUEST SETS", 20) . ""); @@ -88,7 +94,7 @@ protected function doExecute(): int while (1) { if (microtime(true) - $lastStatsTimer >= 2 || $keyPressed != "") { - $output->write("\e[" . ($qPerPAge + 5) . "A"); + $output->write("\e[" . ($qPerPAge + 5) . "A\e[0G"); $qCurrentPage = min(max($qCurrentPage, 1), $qPageCount); $memory = $backend->getMemoryStats(); // I know this will only work with redis currently as it is not defined in backend interface etc. needs to be refactored once we add another backend @@ -120,7 +126,7 @@ protected function doExecute(): int $output->writeln("" . str_pad(" " . ($qCount) . " Q", 10) . " | " . str_pad(number_format($sumInQueue) . " R", 16) . ""); $output->writeln(str_repeat("-", 30)); $output->writeln(sprintf( - "Q [%s-%s] | page %s/%s | press (0-9.,q) or arrow(L,R,U,D) | diff/sec %s \n" . + "Q [%s-%s] | page %s/%s" . ($this->interactiveCapability() ? " | press (0-9.,q) or arrow(L,R,U,D)" : " | use -p arg to jump to specific page"). " | diff/sec %s \n" . "%s used memory (%s peak). %d workers active." . str_repeat(" ", 15), ($idx - $qPerPAge + 1), $idx, @@ -143,44 +149,46 @@ protected function doExecute(): int $lastStatsTimer = microtime(true); } - $keyStroke = stream_get_contents(STDIN, 3); - $keyPressed = strlen($keyStroke) == 3 ? $keyStroke[2] : (strlen($keyStroke) > 0 ? $keyStroke[0] : ""); - if ($keyPressed != "" and in_array($keyPressed, array(".", ",", "0", "1", "2", "3", "4", "5", "6", "7", "8", "9", "A", "B", "C", "D", "q"))) { - switch ($keyPressed) { - case "0": - case "1": - case "2": - case "3": - case "4": - case "5": - case "6": - case "7": - case "8": - case "9": - $keyPressed = $keyPressed != "0" ? $keyPressed : "10"; - $qCurrentPage = floor(($qCurrentPage - 0.1) / 10) * 10 + (int)$keyPressed; - break; - case "C": - $qCurrentPage++; - break; - case "D": - $qCurrentPage--; - break; - case "A": - $qCurrentPage += 10; - break; - case "B": - $qCurrentPage -= 10; - break; - case ",": - $qCurrentPage = 1; - break; - case ".": - $qCurrentPage = $qPageCount; - break; - case "q": - $output->writeln(''); - die; + if ($this->interactiveCapability()) { + $keyStroke = stream_get_contents(STDIN, 3); + $keyPressed = strlen($keyStroke) == 3 ? $keyStroke[2] : (strlen($keyStroke) > 0 ? $keyStroke[0] : ""); + if ($keyPressed != "" and in_array($keyPressed, array(".", ",", "0", "1", "2", "3", "4", "5", "6", "7", "8", "9", "A", "B", "C", "D", "q"))) { + switch ($keyPressed) { + case "0": + case "1": + case "2": + case "3": + case "4": + case "5": + case "6": + case "7": + case "8": + case "9": + $keyPressed = $keyPressed != "0" ? $keyPressed : "10"; + $qCurrentPage = floor(($qCurrentPage - 0.1) / 10) * 10 + (int)$keyPressed; + break; + case "C": + $qCurrentPage++; + break; + case "D": + $qCurrentPage--; + break; + case "A": + $qCurrentPage += 10; + break; + case "B": + $qCurrentPage -= 10; + break; + case ",": + $qCurrentPage = 1; + break; + case ".": + $qCurrentPage = $qPageCount; + break; + case "q": + $output->writeln(''); + die; + } } } @@ -212,21 +220,57 @@ private function getIterationsFromArg() } /** - * Loads the `perpage` argument from the commands arguments. + * Loads the `rowperpage` argument from the commands arguments. * * @return int|null */ private function getPerPageFromArg() { - $perPage = $this->getInput()->getOption('perpage'); + $perPage = $this->getInput()->getOption('rowperpage'); if (!is_numeric($perPage)) { - throw new \Exception('perpage needs to be numeric'); + throw new \Exception('rowperpage needs to be numeric'); } else { $perPage = (int)$perPage; if ($perPage <= 0) { - throw new \Exception('perpage needs to be a non-zero positive number'); + throw new \Exception('rowperpage needs to be a non-zero positive number'); } } return $perPage; } + + /** + * Loads the `jumptopage` argument from the commands arguments. + * + * @return int|null + */ + private function getJumpToPageFromArg() + { + $perPage = $this->getInput()->getOption('jumptopage'); + if (!is_numeric($perPage)) { + throw new \Exception('jumptopage needs to be numeric'); + } else { + $perPage = (int)$perPage; + if ($perPage <= 0) { + throw new \Exception('jumptopage needs to be a non-zero positive number'); + } + } + return $perPage; + } + + /** + * + * @return bool + */ + private function interactiveCapability() + { + if (str_starts_with(strtoupper(PHP_OS), 'WIN')) { + return false; + } + + if (function_exists('readline_callback_handler_install') == false) { + return false; + } + + return true; + } } From 6a7c9fb059ef8dc8d64d494ef7a9097a4640d6e8 Mon Sep 17 00:00:00 2001 From: haristku <48225314+haristku@users.noreply.github.com> Date: Tue, 22 Oct 2024 22:23:02 +0700 Subject: [PATCH 2/4] Update Commands/Monitor.php Co-authored-by: Altamash Shaikh --- Commands/Monitor.php | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Commands/Monitor.php b/Commands/Monitor.php index fcfcb15..7f6d32a 100644 --- a/Commands/Monitor.php +++ b/Commands/Monitor.php @@ -263,7 +263,7 @@ private function getJumpToPageFromArg() */ private function interactiveCapability() { - if (str_starts_with(strtoupper(PHP_OS), 'WIN')) { + return function_exists('readline_callback_handler_install'); return false; } From 10df3c9d298277446d07a4fd44f81b4d55e3e684 Mon Sep 17 00:00:00 2001 From: haristku Date: Tue, 22 Oct 2024 22:35:39 +0700 Subject: [PATCH 3/4] Simplifying the function --- Commands/Monitor.php | 8 -------- 1 file changed, 8 deletions(-) diff --git a/Commands/Monitor.php b/Commands/Monitor.php index 7f6d32a..e991965 100644 --- a/Commands/Monitor.php +++ b/Commands/Monitor.php @@ -264,13 +264,5 @@ private function getJumpToPageFromArg() private function interactiveCapability() { return function_exists('readline_callback_handler_install'); - return false; - } - - if (function_exists('readline_callback_handler_install') == false) { - return false; - } - - return true; } } From 06b1286a7781b29e9bce36bcbd81de967de2dd32 Mon Sep 17 00:00:00 2001 From: haristku Date: Tue, 22 Oct 2024 22:58:26 +0700 Subject: [PATCH 4/4] fix PHPCS check --- Commands/Monitor.php | 7 ++++--- 1 file changed, 4 insertions(+), 3 deletions(-) diff --git a/Commands/Monitor.php b/Commands/Monitor.php index e991965..b9298d7 100644 --- a/Commands/Monitor.php +++ b/Commands/Monitor.php @@ -75,9 +75,10 @@ protected function doExecute(): int $qCount = count($queues); $qPerPAge = min(max($this->getPerPageFromArg(), 1), $qCount); $qPageCount = ceil($qCount / $qPerPAge); - + if ($this->interactiveCapability()) { - readline_callback_handler_install('', function () {}); + readline_callback_handler_install('', function () { + }); stream_set_blocking(STDIN, false); } @@ -126,7 +127,7 @@ protected function doExecute(): int $output->writeln("" . str_pad(" " . ($qCount) . " Q", 10) . " | " . str_pad(number_format($sumInQueue) . " R", 16) . ""); $output->writeln(str_repeat("-", 30)); $output->writeln(sprintf( - "Q [%s-%s] | page %s/%s" . ($this->interactiveCapability() ? " | press (0-9.,q) or arrow(L,R,U,D)" : " | use -p arg to jump to specific page"). " | diff/sec %s \n" . + "Q [%s-%s] | page %s/%s" . ($this->interactiveCapability() ? " | press (0-9.,q) or arrow(L,R,U,D)" : " | use -p arg to jump to specific page") . " | diff/sec %s \n" . "%s used memory (%s peak). %d workers active." . str_repeat(" ", 15), ($idx - $qPerPAge + 1), $idx,