簡介
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> Path to home directory of your application, defaults to
the value of MOJO_HOME or auto-detection
-m, --mode <name> 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 <generator>
$ ./myapp.pl generate help <generator>
列出具有簡短說明的“生成器”命令的可用選項。
generate app
$ mojo generate app <AppName>
使用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 <PluginName>
使用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 <command>
$ ./myapp.pl help <command>
列出具有簡短描述的命令的可用選項。
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);
加載并運行命令??梢允褂肕OJO_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');