mix / cli
PHP CLI Interactive Commander
Installs: 1 557
Dependents: 5
Suggesters: 0
Security: 0
Stars: 3
Watchers: 2
Forks: 0
Open Issues: 0
Requires
- php: >=7.0.0
Requires (Dev)
- phpunit/phpunit: ^7.0.0
This package is auto-updated.
Last update: 2024-10-29 06:25:11 UTC
README
OpenMix 出品:https://openmix.org
Mix CLI
PHP CLI Interactive Commander
PHP 命令行交互指挥官
Overview
一个命令行交互与指挥管理工具,它可以让单个 CLI 可执行多种功能,同时它还包括命令行参数获取、全局异常捕获与处理等命令行开发常用功能。
Installation
composer require mix/cli
Quick start
Mix\Cli\Cli::setName('app')->setVersion('0.0.0-alpha'); $cmd = new Mix\Cli\Command([ 'name' => 'hello', 'short' => 'Echo demo', 'run' => function () { $name = Mix\Cli\Flag::match('n', 'name')->string('default'); // do something } ]); $opt = new Mix\Cli\Option([ 'names' => ['n', 'name'], 'usage' => 'Your name' ]); $cmd->addOption($opt); Mix\Cli\Cli::addCommand($cmd)->run();
上面是采用闭包,也可以使用对象
class FooCommand implements Mix\Cli\RunInterface { public function main(): void { // do something } } $cmd = new Mix\Cli\Command([ 'name' => 'hello', 'short' => 'Echo demo', 'run' => new FooCommand(), ]);
查看整个命令行程序的帮助
$ php app.php
Usage: app.php [OPTIONS] COMMAND [ARG...]
Commands:
hello Echo demo
Global Options:
-h, --help Print usage
-v, --version Print version information
Run 'app.php COMMAND --help' for more information on a command.
Developed with Mix PHP framework. (openmix.org/mix-php)
查看命令行程序的版本信息
$ php app.php -v
app 0.0.0-alpha
查看 hello
命令的帮助
$ php app.php hello --help
Usage: app.php hello [ARG...]
Command Options:
-n, --name Your name
Developed with Mix PHP framework. (openmix.org/mix-php)
执行 hello
命令
$ php app.php hello
Flag 参数获取
参数规则 (部分UNIX风格+GNU风格)
php /examples/app.php home -d -rf --debug -v vvv --page 23 -s=test --name=john arg0
- 命令:
- 第一个参数,可以为空:
home
- 第一个参数,可以为空:
- 选项:
- 短选项:一个中杠,如
-d
、-rf
- 长选项:二个中杠,如:
--debug
- 短选项:一个中杠,如
- 选项值:
- 无值:
-d
、-rf
、--debug
- 有值(空格):
-v vvv
、--page 23
- 有值(等号):
-s=test
、--name=john
- 无值:
- 参数:
- 没有定义
-
的参数:arg0
- 没有定义
获取选项,可以获取 string
、bool
、int
、float
多种类型,也可以指定默认值。
$name = Mix\Cli\Flag::match('n', 'name')->string('Xiao Ming');
获取第一个参数
$arg0 = Mix\Cli\Flag::arguments()->first()->string();
获取全部参数
foreach (Mix\Cli\Flag::arguments()->values() as $k => $v) { // do something }
Daemon 后台执行
我们可以通过配合 flag
获取参数,实现通过某几个参数控制程序后台执行。
- 使用了 Swoole Daemon 方法
if (Mix\Cli\Flag::match('d', 'daemon')->bool()) { \Swoole\Process::daemon(); }
Middleware 与 Handle exception
可以使用全局中间件给所有命令捕获异常,也可以单独对某个命令配置中间件
$h = function ($next) { try { $next(); } catch (\Throwable $ex) { // handle exception echo(sprintf("ERROR: %s\n", $ex->getMessage())); } }; $cmd = new Mix\Cli\Command([ 'name' => 'hello', 'short' => 'Echo demo', 'run' => function () { // do something } ]); Mix\Cli\Cli::use($h)->addCommand($cmd)->run();
Application
我们在编写代码时,可能会要用到 App 中的一些信息。
// 获取基础路径(入口文件所在目录路径)
Mix\Cli\Cli::app()->basePath
// App名称
Mix\Cli\Cli::app()->name
// App版本号
Mix\Cli\Cli::app()->version
// 是否开启debug
Mix\Cli\Cli::app()->debug
Singleton 单命令
当我们的 CLI 只有一个命令时,只需要配置一下 Singleton
:
$cmd = new Mix\Cli\Command([ 'name' => 'hello', 'short' => 'Echo demo', 'run' => function () { // do something }, 'singleton' => true, ]);
命令的 Options 将会在 -h/--help
中打印
$ php app.php
Usage: app.php [OPTIONS] COMMAND [ARG...]
Command Options:
-n, --name Your name
Global Options:
-h, --help Print usage
-v, --version Print version information
Run 'app.php COMMAND --help' for more information on a command.
Developed with Mix PHP framework. (openmix.org/mix-php)
License
Apache License Version 2.0, http://www.apache.org/licenses/