From 384cbf7b2c0a14a4e68d62be069a1a97d6476784 Mon Sep 17 00:00:00 2001 From: Timm Friebe Date: Thu, 28 Mar 2024 20:19:20 +0100 Subject: [PATCH 1/2] Support `use` prefix for argument methods --- src/main/php/xp/command/CmdRunner.class.php | 4 ++-- .../php/util/cmd/unittest/CmdRunnerTest.class.php | 14 ++++++++++++++ 2 files changed, 16 insertions(+), 2 deletions(-) diff --git a/src/main/php/xp/command/CmdRunner.class.php b/src/main/php/xp/command/CmdRunner.class.php index 4abba52..29776b4 100755 --- a/src/main/php/xp/command/CmdRunner.class.php +++ b/src/main/php/xp/command/CmdRunner.class.php @@ -105,7 +105,7 @@ protected function commandUsage(Type $type) { $extra= $details= $positional= []; foreach ($type->methods()->annotated(Arg::class) as $method) { $arg= $method->annotation(Arg::class)->arguments(); - $name= strtolower(preg_replace('/^set/', '', $method->name())); + $name= strtolower(preg_replace('/^(use|set)/', '', $method->name())); $first= $method->parameter(0); $optional= $first ? $first->optional() : true; $comment= $method->comment(); @@ -253,7 +253,7 @@ protected function runCommand($command, $params, $config) { $name= '#'.($position + 1); $short= null; } else { - $select= $name= $arg->argument('name') ?? strtolower(preg_replace('/^set/', '', $method->name())); + $select= $name= $arg->argument('name') ?? strtolower(preg_replace('/^(use|set)/', '', $method->name())); $short= $arg->argument('short'); } diff --git a/src/test/php/util/cmd/unittest/CmdRunnerTest.class.php b/src/test/php/util/cmd/unittest/CmdRunnerTest.class.php index 37d1bf0..78e4e10 100755 --- a/src/test/php/util/cmd/unittest/CmdRunnerTest.class.php +++ b/src/test/php/util/cmd/unittest/CmdRunnerTest.class.php @@ -569,4 +569,18 @@ public function can_be_invoked_via_main() { Assert::equals(12, $command::main(['-a', 12])); } + + #[Test] + public function argument_name_with_use() { + $command= newinstance(Command::class, [], '{ + private $arg= null; + + #[Arg] + public function useArg($arg) { $this->arg= $arg; } + public function run() { $this->out->write($this->arg); } + }'); + + $this->runWith([nameof($command), '-a', 'UNITTEST']); + Assert::equals('UNITTEST', $this->out->bytes()); + } } \ No newline at end of file From f6a8c8155d0f4a91849ecbfed4f50095889a3420 Mon Sep 17 00:00:00 2001 From: Timm Friebe Date: Thu, 28 Mar 2024 20:20:27 +0100 Subject: [PATCH 2/2] Advertise `use` prefix --- README.md | 22 ++++++---------------- 1 file changed, 6 insertions(+), 16 deletions(-) diff --git a/README.md b/README.md index 2a05cb2..49acb7e 100755 --- a/README.md +++ b/README.md @@ -25,24 +25,16 @@ class Query extends Command { private $connection, $query; private $verbose= false; - /** - * Connection DSN, e.g. `mysql://user:pass@host[:port][/database]` - * - * @param string $dsn - */ + /** Connection DSN, e.g. `mysql://user:pass@host[:port][/database]` */ #[Arg(position: 0)] - public function setConnection($dsn) { + public function useConnection(string $dsn) { $this->connection= DriverManager::getConnection($dsn); $this->connection->connect(); } - /** - * SQL query. Use `-` to read from standard input. - * - * @param string $query - */ + /** SQL query. Use `-` to read from standard input */ #[Arg(position: 1)] - public function setQuery($query) { + public function useQuery(string $query) { if ('-' === $query) { $this->query= Streams::readAll($this->in->stream()); } else { @@ -50,11 +42,9 @@ class Query extends Command { } } - /** - * Verbose output - */ + /** Verbose output */ #[Arg] - public function setVerbose() { + public function useVerbose() { $this->verbose= true; }