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>   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框架的交互式命令接口。它將自動(dòng)檢測Mojolicious命名空間中的所有可用命令。

可用命令介紹

默認(rèn)情況下在Mojolicious框架中已經(jīng)實(shí)現(xiàn)的命令會(huì)在接下來一一進(jìn)行簡單的介紹。

cgi

$ ./myapp.pl cgi

使用Mojolicious::Command::cgi對(duì)象中的CGI 支持啟動(dòng)應(yīng)用程序,通過是自動(dòng)檢測。

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可啟動(dòng)獨(dú)立的HTTP和WebSocket服務(wù)器應(yīng)用。

eval

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

使用Mojolicious::Command::eval來運(yùn)行應(yīng)用程序的代碼。

generate

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

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

$ mojo generate help <generator>
$ ./myapp.pl generate help <generator>

列出具有簡短說明的“生成器”命令的可用選項(xiàng)。

generate app

$ mojo generate app <AppName>

使用Mojolicious::Command::generate::app為全功能的Mojolicious應(yīng)用程序生成應(yīng)用程序目錄結(jié)構(gòu)。

generate lite_app

$ mojo generate lite_app

使用Mojolicious::Command::generate::lite_app生成一個(gè)功能完整的Mojolicious::Lite應(yīng)用程序。

generate makefile

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

使用Mojolicious::Command::generate::makefile生成Makefile.PL應(yīng)用程序文件。

generate plugin

$ mojo generate plugin <PluginName>

使用Mojolicious::Command::generate::plugin來生成一個(gè)功能完整的Mojolicious插件的目錄結(jié)構(gòu)。

get

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

使用Mojolicious::Command::get來執(zhí)行遠(yuǎn)程主機(jī)或本地應(yīng)用程序的請(qǐng)求。

help

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

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

$ mojo help <command>
$ ./myapp.pl help <command>

列出具有簡短描述的命令的可用選項(xiàng)。

inflate

$ ./myapp.pl inflate

使用Mojolicious::Command::inflate將嵌入在應(yīng)用程序DATA段中的模板和靜態(tài)文件轉(zhuǎn)換為真實(shí)文件。

prefork

$ ./myapp.pl prefork

使用Mojolicious::Command::prefork啟動(dòng)支持pre-forking 的 HTTP和WebSocket服務(wù)器。

psgi

$ ./myapp.pl psgi

使用Mojolicious::Command::psgi對(duì)象中的PSGI 支持啟動(dòng)應(yīng)用程序,通過是自動(dòng)檢測。

routes

$ ./myapp.pl routes

使用Mojolicious::Command::routes列出應(yīng)用程序路由。

test

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

使用Mojolicious::Command::test從t目錄運(yùn)行應(yīng)用程序的測試。

version

$ mojo version
$ ./myapp.pl version

使用Mojolicious::Command::version顯示可用的核心和可選模塊的版本信息,對(duì)調(diào)試非常有用。

屬性

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']);

從哪個(gè)命令空間來加載命令,默認(rèn)為Mojolicious::Command。

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

方法

Mojolicious::Commands繼承Mojolicious::Command中的所有方法,并實(shí)現(xiàn)以下方法。

detect

my $env = $commands->detect;

嘗試檢測運(yùn)行環(huán)境,如果沒有檢測到的話返回undef。

run

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

加載并運(yùn)行命令??梢允褂肕OJO_NO_DETECT環(huán)境變量禁用自動(dòng)部署環(huán)境檢測。

start_app

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

從指定的類中加載應(yīng)用程序,并從命令行中啟動(dòng)它。

注:選項(xiàng)-h/ --help,--home和-m/ --mode,被所有命令共享,將在編譯時(shí)從解析@ARGV得到。

# Always start daemon for application
Mojolicious::Commands->start_app('MyApp', 'daemon', '-l', 'http://*:8080');
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容