Mojolicious::Commands

简介

Usage: APPLICATION COMMAND [OPTIONS]

  mojo version
  mojo generate lite_app
  ./myapp.pl daemon -m production -l http://*:8080
  ./myapp.pl get /foo
  ./myapp.pl routes -v

Tip: CGI and PSGI environments can be automatically detected very often and
     work without commands.

Options (for all commands):
  -h, --help          Get more information on a specific command
      --home    Path to home directory of your application, defaults to
                      the value of MOJO_HOME or auto-detection
  -m, --mode    Operating mode for your application, defaults to the
                      value of MOJO_MODE/PLACK_ENV or "development"

Mojolicious::Commands是Mojolicious框架的交互式命令接口。它将自动检测Mojolicious命名空间中的所有可用命令。

可用命令介绍

默认情况下在Mojolicious框架中已经实现的命令会在接下来一一进行简单的介绍。

cgi

$ ./myapp.pl cgi

使用Mojolicious::Command::cgi对象中的CGI 支持启动应用程序,通过是自动检测。

cpanify

$ mojo cpanify -u sri -p secr3t Mojolicious-Plugin-Fun-0.1.tar.gz

使用Mojolicious::Command::cpanify将文件上传到CPAN。

daemon

$ ./myapp.pl daemon

使用Mojolicious::Command::deamon可启动独立的HTTP和WebSocket服务器应用。

eval

$ ./myapp.pl eval 'say app->home'

使用Mojolicious::Command::eval来运行应用程序的代码。

generate

$ mojo generate
$ mojo generate help
$ ./myapp.pl generate help

列出可用的“生成器”命令,和简短的描述。

$ mojo generate help 
$ ./myapp.pl generate help 

列出具有简短说明的“生成器”命令的可用选项。

generate app

$ mojo generate app 

使用Mojolicious::Command::generate::app为全功能的Mojolicious应用程序生成应用程序目录结构。

generate lite_app

$ mojo generate lite_app

使用Mojolicious::Command::generate::lite_app生成一个功能完整的Mojolicious::Lite应用程序。

generate makefile

$ mojo generate makefile
$ ./myapp.pl generate makefile

使用Mojolicious::Command::generate::makefile生成Makefile.PL应用程序文件。

generate plugin

$ mojo generate plugin 

使用Mojolicious::Command::generate::plugin来生成一个功能完整的Mojolicious插件的目录结构。

get

$ mojo get http://mojolicious.org
$ ./myapp.pl get /foo

使用Mojolicious::Command::get来执行远程主机或本地应用程序的请求。

help

$ mojo
$ mojo help
$ ./myapp.pl help

列出可用的命令和简短描述。

$ mojo help 
$ ./myapp.pl help 

列出具有简短描述的命令的可用选项。

inflate

$ ./myapp.pl inflate

使用Mojolicious::Command::inflate将嵌入在应用程序DATA段中的模板和静态文件转换为真实文件。

prefork

$ ./myapp.pl prefork

使用Mojolicious::Command::prefork启动支持pre-forking 的 HTTP和WebSocket服务器。

psgi

$ ./myapp.pl psgi

使用Mojolicious::Command::psgi对象中的PSGI 支持启动应用程序,通过是自动检测。

routes

$ ./myapp.pl routes

使用Mojolicious::Command::routes列出应用程序路由。

test

$ ./myapp.pl test
$ ./myapp.pl test t/fun.t

使用Mojolicious::Command::test从t目录运行应用程序的测试。

version

$ mojo version
$ ./myapp.pl version

使用Mojolicious::Command::version显示可用的核心和可选模块的版本信息,对调试非常有用。

属性

hint

my $hint  = $commands->hint;
$commands = $commands->hint('Foo');

列出可用命令后显示的简短提示。

message

my $msg   = $commands->message;
$commands = $commands->message('Hello World!');

列出可用命令之前显示的短使用信息。

namespaces

my $namespaces = $commands->namespaces;
$commands      = $commands->namespaces(['MyApp::Command']);

从哪个命令空间来加载命令,默认为Mojolicious::Command。

# Add another namespace to load commands from
push @{$commands->namespaces}, 'MyApp::Command';

方法

Mojolicious::Commands继承Mojolicious::Command中的所有方法,并实现以下方法。

detect

my $env = $commands->detect;

尝试检测运行环境,如果没有检测到的话返回undef。

run

$commands->run;
$commands->run(@ARGV);

加载并运行命令。可以使用MOJO_NO_DETECT环境变量禁用自动部署环境检测。

start_app

Mojolicious::Commands->start_app('MyApp');
Mojolicious::Commands->start_app(MyApp => @ARGV);

从指定的类中加载应用程序,并从命令行中启动它。

注:选项-h/ --help,--home和-m/ --mode,被所有命令共享,将在编译时从解析@ARGV得到。

# Always start daemon for application
Mojolicious::Commands->start_app('MyApp', 'daemon', '-l', 'http://*:8080');

你可能感兴趣的:(Mojolicious::Commands)