ethnaコマンドリファレンス
アプリケーション構築手順(1) のページにあるように、Ethna では、プロジェクトの作成から、作成されたプロジェクトに関わる様々な操作を ethna コマンドと呼ばれるコマンドラインから行えるようになっています。
ethna コマンドには様々なサブコマンドが用意されており、プロジェクトに対する様々な操作が行えます。このページでは、ethnaコマンドで出来ることをリファレンスとして紹介します。
いちい | - | 新規作成 |
mumumu | 2008-07-30 | 最新の状態を反映 |
DQNEO | 2010-05-23 | アクション名指定の際の大文字小文字の違いを解説 |
プロジェクトの作成
add-project コマンド
(使い方) $ ethna add-project [-b|--basedir=dir] [-s|--skeldir] [-l|--locale] [-e|--encoding] [Application id]
プロジェクトと、それに付随する必須ファイルを自動生成します。作成しようとした先に、既に同名のプロジェクトが存在する場合は、不足しているファイルのみ作成されます。[Application id](アプリケーションID) の指定が最低限必要です。
オプションは以下の通りです。
- [-b|--basedir]
- プロジェクトを作成するディレクトリを指定します。
- ここで指定されたディレクトリ下に、[Application id] で指定されたディレクトリが作成されます。
- デフォルトはカレントディレクトリです。
- [-s|--skeldir]
- Ethnaは自動生成されるファイルのスケルトンを持っており、それに基づきプロジェクトを生成します。このオプションでディレクトリを指定すると、そこにあるスケルトンファイルが優先されます。
- ファイル名は Ethna本体の skelディレクトリ にあるものと同じでなければなりません。
- このオプションはスケルトンを改造していた場合に有用です。
- [-l|--locale] (2.5.0 preview1以降)
- ロケール(言語や文化の規則)を指定します。
- デフォルトはja_JPです。
- 言語とエンコーディングの設定 も参照して下さい
- [-e|--encoding] (2.5.0 preview1以降)
- プロジェクトで使用するエンコーディングを指定します。
- デフォルトはUTF-8です。
- 言語とエンコーディングの設定 も参照して下さい
- [Application ID]
- アプリケーションIDです。最低限これだけは指定して下さい。
- 大文字小文字は区別されません。
- 自動生成されるファイルの都合上、先頭に数値を指定してはいけません。
アクション, ビューの追加など
add-action コマンド
(使い方) $ ethna add-action [-b|--basedir=dir] [-s|--skelfile=file] [-g|--gateway=www|cli|xmlrpc] [-w|--with-unittest] [-u|--unittestskel=file] [action]
アクションをプロジェクトに追加します。オプションは以下の通りです。
- [-b|--basedir]
- アクションを追加したいプロジェクトのあるディレクトリを指定します。
- 省略時は、現在のディレクトリから親ディレクトリをたどってプロジェクトを自動的に探索します。
- [-s|--skelfile=file]
- アクションファイルを生成する元となるスケルトンファイルを指定します。相対/絶対パスが指定できます。
- 指定されたファイルが見つからないときはアプリケーションのskelディレクトリ、Ethna本体のskelディレクトリを順に探します。
- 省略時は、gatewayの指定に従い、プロジェクトのskel/skel.{action,actio_cli,action_xmlrpc}.phpが使われます。
- このオプションはスケルトンを改造していた場合に有用です。
- [-g|--gateway=www|cli|xmlrpc]
- アクションのゲートウェイを指定します。
- それぞれaction, action_cli,action_xmlrpcディレクトリの下にアクションが追加されます。
- 省略時は www が指定されたものとみなされます。
- [-w|--with-unittest] (2.3.5 以降)
- ユニットテストファイルを同時に生成します。
- add-action-test を同時に実行したことと同じです。
- [-u|--unittestskel=file] (2.3.5 以降)
- ユニットテストファイルを作るときのスケルトンを指定します。
- -w オプションが指定されない場合は、このオプションは無視されます。
- [action]
- アクション名を指定します。最低限これだけは指定して下さい。
- 【補足1】"add-action Foo_Bar"と "add-action foo_bar"の違い
- 生成されるファイル名・クラス名は同じです。
- performのreturn値は異なります。( 'Foo_Bar' と 'foo_bar' )
- どちらの形式でも可能ですが、add-view, add-templateする際は、同じ形式で入力する必要があります。
- 【補足2】"add-action Foo_Bar"と "add-action FooBar"の違い
- 生成されるファイル名は異なります。( 'Foo/Bar.php' と 'FooBar.php' )
- 生成されるクラス名は同じです。
- performのreturn値は異なります。( 'Foo_Bar' と 'FooBar' )
add-view コマンド
(使い方) $ ethna add-view [-b|--basedir=dir] [-s|--skelfile=file] [-w|--with-unittest] [-u|--unittestskel=file] [-t|--template] [-l|--locale] [-e|--encoding] [view]
ビューをプロジェクトに追加します。オプションは以下の通りです。
- [-b|--basedir]
- ビューを追加したいプロジェクトのあるディレクトリを指定します。
- 省略時は、現在のディレクトリから親ディレクトリをたどってプロジェクトを自動的に探索します。
- [-s|--skelfile=file]
- ビューファイルを生成する元となるスケルトンファイルを指定します。相対/絶対パスが指定できます。
- 指定されたファイルが見つからないときはアプリケーションのskelディレクトリ、Ethna本体のskelディレクトリを順に探します。
- このオプションはスケルトンを改造していた場合に有用です。
- [-t|--template]
- ビューと同じ名前のテンプレートを追加します。add-templateを同時に実行したのと同じです。
- [-w|--with-unittest] (2.3.5 以降)
- ユニットテストファイルを同時に生成します。add-view-test を同時に実行したことと同じです。
- -t オプション を指定した場合は、この指定は無視されます。
- [-u|--unittestskel=file] (2.3.5 以降)
- ユニットテストファイルを作るときのスケルトンファイルを指定します。
- -t オプション を指定した場合は、この指定は無視されます。
- [-l|--locale] (2.5.0 preview1以降)
- ロケール(言語や文化の規則)を指定します。
- デフォルトはja_JPです。
- これにより、プロジェクトのテンプレートディレクトリ以下に、指定したロケール名のディ
レクトリが作られます。 - -t オプションを指定したときのみ意味を持ちます。
- 言語とエンコーディングの設定 も参照して下さい
- [-e|--encoding] (2.5.0 preview1以降)
- プロジェクトで使用するエンコーディングを指定します。
- デフォルトはUTF-8です。
- meta タグで指定するエンコーディングを指定する意味しかありません。
- -t オプションを指定したときのみ意味を持ちます。
- [view]
- 追加したいビュー名を指定します。最低これだけは指定して下さい。
- 【補足1】"add-view Foo_Bar"と "add-view foo_bar"の違い
- 挙動は全く同じです。ただし、-tオプションをつけると、tplファイル名が異なります。(後述)
- 【補足2】"add-view Foo_Bar"と "add-view FooBar"の違い
- 生成されるファイル名は異なります。( 'Foo/Bar.php' と 'FooBar.php' )
- 生成されるクラス名は同じです。
add-template コマンド
(使い方) $ ethna add-template [-b|--basedir=dir] [-s|--skelfile=file] [-l|--locale] [-e|--encoding] [template]
テンプレートファイルを追加します。オプションは以下の通りです。
- [-b|--basedir]
- テンプレートファイルを追加したいプロジェクトのあるディレクトリを指定します。
- 省略時は、現在のディレクトリから親ディレクトリをたどってプロジェクトを自動的に探索します。
- [-s|--skelfile=file]
テンプレートファイルを生成する元となるスケルトンファイルを指定します。相対/絶対パスが指定できます。- 指定されたファイルが見つからないときはアプリケーションのskelディレクトリ、Ethna本体のskelディレクトリを順に探します。
- このオプションはスケルトンを改造していた場合に有用です。
- [-l|--locale] (2.5.0 preview1以降)
ロケール(言語や文化の規則)を指定します。- デフォルトはja_JPです。
- これにより、プロジェクトのテンプレートディレクトリ以下に、指定したロケール名のディ
レクトリが作られます。 - 言語とエンコーディングの設定 も参照して下さい
- [-e|--encoding] (2.5.0 preview1以降)
プロジェクトで使用するエンコーディングを指定します。- デフォルトはUTF-8です。
- meta タグで指定するエンコーディングを指定する意味しかありません。
- [template]
- 追加したいテンプレート名を指定します。最低これだけは指定して下さい。
- 【補足】"add-template Foo_Bar"と "add-template foo_bar"の違い
- 生成されるファイル名は異なります。( 'Foo_Bar' と 'foo_bar' )
- アクションクラスのprepare/performが返す文字列と完全一致している必要があります。
add-entry-point コマンド
(使い方) $ ethna add-entry-point [-b|--basedir=dir] [-s|--skelfile=file] [-g|--gateway=www|cli] [action]
エントリポイントと対応するアクションを追加します。エントリポイントは、wwwディレクトリに置かれ、コントローラーを呼び出す役割を果たします。
オプションは以下の通りです。
- [-b|--basedir]
- エントリポイントを追加したいプロジェクトのあるディレクトリを指定します。
- 省略時は、現在のディレクトリから親ディレクトリをたどってプロジェクトを自動的に探索します。
- [-s|--skelfile=file]
- エントリポイントを生成する元となるスケルトンファイルを指定します。相対/絶対パスが指定できます。
- 指定されたファイルが見つからないときはアプリケーションのskelディレクトリ、Ethna本体のskelディレクトリを順に探します。
- このオプションはスケルトンを改造していた場合に有用です。
- [-g|--gateway=www|cli]
アクションのゲートウェイを指定します。- それぞれaction, action_cli ディレクトリの下にアクションが追加されます。
- 省略時は www が指定されたものとみなされます。
- [action]
追加したいエントリポイントで起動するアクション名を指定します。- 例えばgatewayにwww を指定した状態で "admin" を指定すると、エントリポイントとしてadmin.phpが作られ、続けてadminアクションが追加されます。
アプリケーションオブジェクト、マネージャの追加
add-app-manager コマンド
(使い方) $ ethna add-app-manager [-b|--basedir=dir] [app-manager name]
アプリケーションマネージャを追加します。オプションは以下の通りです。
- [-b|--basedir]
- アプリケーションマネージャを追加したいプロジェクトのあるディレクトリを指定します。
- 省略時は、現在のディレクトリから親ディレクトリをたどってプロジェクトを自動的に探索します。
- (現在のところskelfileを指定することはできません。)
- [app-manager name]
- アプリケーションマネージャ−名。最低これだけは指定して下さい。
add-app-object コマンド
(使い方) $ ethna add-app-object [-b|--basedir=dir] [table name]
アプリケーションオブジェクトを追加します。データベースのテーブル名を指定することで、スキーマ定義などを自動的に取得することができます
- [-b|--basedir]
- アプリケーションオブジェクトを追加したいプロジェクトのあるディレクトリを指定します。
- 省略時は、現在のディレクトリから親ディレクトリをたどってプロジェクトを自動的に探索します。
- (現在のところskelfileを指定することはできません。)
- [table name]
- 最低限これだけは指定して下さい
- データベースのテーブル名を指定することで、スキーマ定義などを自動的に取得することができます
- 必ずしもテーブル名である必要はありません。
国際化(i18n)
i18n コマンド
この機能を使うには、Ethna 2.5.0 preview2 以降が必要です
(使い方) $ ethna i18n [-b|--basedir=dir] [-l|--locale=locale] [-g|--gettext] [extdir1] ...
プロジェクト内部のPHPスクリプト(テストスクリプトは除く)、テンプレートファイルを全て調べ、翻訳の対象となるメッセージを全て抜きだし、メッセージカタログの雛形を自動生成します。 実際に調べられ、抜き出されるメッセージは、以下の部分が対象になります*1
1. app ディレクトリ内のPHPスクリプトの、_et 関数の呼び出し箇所全て 2. app ディレクトリ内の ActionForm のフォーム定義のうち、以下の部分 a) name b) required_error c) type_error d) min_error e) max_error f) regexp_error 3. template ディレクトリ内の、i18n修正子の呼び出し箇所全て
既に[ini|po]ファイルが存在していた場合、iniファイル(デフォルト) の場合は 自動的に既にある翻訳をマージしてファイルを上書きします。gettext([-g|--gettext] を指定)の場合は、別に新しいファイルを作成し、古いファイルはそのままにします。
コマンドのオプションは以下の通りです。
- [-b|--basedir=dir]
- プロジェクトのあるディレクトリを指定します。
- 省略時は、現在のディレクトリから親ディレクトリをたどってプロジェクトを自動的に探索します。
- [-l|--locale=locale]
- 生成したいカタログのロケールを指定します。
- デフォルトは ja_JP です。
- 実際のカタログは [appid]/locale/[指定したロケール名]/LC_MESSAGES/[指定したロケール名].[ini|po] に作られます。デフォルトでは ini ファイルが生成されます。
- [-g|--gettext]
- gettext を使う場合、このオプションを指定します。
- このオプションを指定すると、デフォルトの iniファイルではなく、po ファイルが自動生成されます。
- 生成された po ファイルに対して、xgettext や msgmerge コマンドを使用して mo ファイルを生成するのはユーザの責任です。
- [extdir1] [extdir2] ...
- デフォルトでは プロジェクト内の app ディレクトリ内と、templateディレクトリしか調べられませんが、任意のディレクトリをコマンドの最後に追加できます。
- ここで指定したディレクトリ内のファイルは、PHPスクリプトの _et 関数の呼び出ししか解釈されません
テストケースの追加
テストケース追加に当たっての注意
Ethna 2.3.5 以降では、作成したテストはデフォルトで失敗するようになっています。要するに「作った以上、テストを書いて下さいネ」ということです。
add-action-test コマンド
(使い方) $ ethna add-action-test [-b|--basedir=dir] [-s|--skelfile=file] [action]
指定されたアクションのテストスクリプトを追加します。
対応するアクションがまだ作成されていない場合には警告が生成されるので注意して下さい。
オプションは以下の通りです。
- [-b|--basedir]
- アクションのテストを追加したいプロジェクトのあるディレクトリを指定します。
- 省略時は、現在のディレクトリから親ディレクトリをたどってプロジェクトを自動的に探索します。
- [-s|--skelfile=file]
- アクションのテストを生成する元となるスケルトンファイルを指定します。相対/絶対パスが指定できます。
- 指定されたファイルが見つからないときはアプリケーションのskelディレクトリ、Ethna本体のskelディレクトリを順に探します。
- このオプションはスケルトンを改造していた場合に有用です。
- [action]
- 作成するテストのアクション名を指定します。最低これだけは指定して下さい。
add-view-test コマンド
(使い方) $ ethna add-view-test [-b|--basedir=dir] [-s|--skelfile=file] [view]
指定されたビューのテストスクリプトを追加します。
対応するビューがまだ作成されていない場合には警告が生成されるので注意して下さい。
オプションは以下の通りです。
- [-b|--basedir]
- ビューのテストを追加したいプロジェクトのあるディレクトリを指定します。
- 省略時は、現在のディレクトリから親ディレクトリをたどってプロジェクトを自動的に探索します。
- [-s|--skelfile=file]
- ビューのテストを生成する元となるスケルトンファイルを指定します。相対/絶対パスが指定できます。
- 指定されたファイルが見つからないときはアプリケーションのskelディレクトリ、Ethna本体のskelディレクトリを順に探します。
- このオプションはスケルトンを改造していた場合に有用です。
- [view]
- 作成するテストのビュー名を指定します。最低これだけは指定して下さい。
add-test コマンド
(使い方) $ ethna add-test [-b|--basedir=dir] [-s|--skelfile=file] [name]
一般的なテストスクリプトを追加します。アプリケーションマネージャー等、アクションやビュー以外のテストケース作成に使います。
オプションは以下の通りです。
- [-b|--basedir]
- テストを追加したいプロジェクトのあるディレクトリを指定します。
- 省略時は、現在のディレクトリから親ディレクトリをたどってプロジェクトを自動的に探索します。
- [-s|--skelfile=file]
- テストを生成する元となるスケルトンファイルを指定します。相対/絶対パスが指定できます。
- 指定されたファイルが見つからないときはアプリケーションのskelディレクトリ、Ethna本体のskelディレクトリを順に探します。
- このオプションはスケルトンを改造していた場合に有用です。
- [name]
- 作成するテスト名を指定します。最低これだけは指定して下さい。
PEAR パッケージ管理
pear-local コマンド
(使い方) $ ethna pear-local [-c|--channel=channel] [-b|--basedir=dir] [pear command ...]
pearコマンド と全く同じ操作で、プロジェクト内でPEARパッケージを楽に管理できます。
詳細は、Ethnaプロジェクト内で PEAR パッケージを管理する を参照して下さい。
オプションは以下の通りです。
- [-c|--channel=channel]
- PEARチャンネル名を指定します。ここで指定したチャンネルのパッケージが操作対象になります。
- デフォルトは pear.php.net です。
- [-b|--basedir]
- PEARパッケージを追加、管理したいプロジェクトのあるディレクトリを指定します。
- 省略時は、現在のディレクトリから親ディレクトリをたどってプロジェクトを自動的に探索します。
- [pear command ...]
- pearコマンド と同様のオプションやパッケージ名を指定します
- Ethnaプロジェクト内で PEAR パッケージを管理する も参照して下さい。
プラグイン関連
おもにプラグインのパッケージを扱うハンドラです。
警告!:--channel=channelの指定はまだ不完全です!!
list-plugin コマンド
(使用例) $ ethna list-plugin [-c|--channel=channel] [-b|--basedir=dir] [-l|--local] [-m|--master] [-t|--type=type] [-v|--verbose]
プラグインの一覧を表示します。パッケージでインストールされたものはpackageの列にパッケージ名が表示されます。
- [-l|--local], [-m|--master]
- local, masterどちらのプラグインを表示するかを切替えます。
local/master の違いはプラグインの説明を参照してください。 - 省略時はlocalが指定されたとみなされます。
- local, masterどちらのプラグインを表示するかを切替えます。
- [-b|--basedir]
- プロジェクトのあるディレクトリを指定します。
- 省略時は、現在のディレクトリから親ディレクトリをたどってプロジェクトを自動的に探索します。
- [-t|--type]
- 表示するプラグインの$typeを指定できます。
- [-v|--verbose]
- バージョン情報などが表示されます。かなり横に長いです。
install-plugin, upgrade-plugin コマンド
(使い方) $ ethna install-plugin [-c|--channel=channel] [-b|--basedir=dir] [-l|--local] [-m|--master] [type name|packagefile|packageurl] $ ethna upgrade-plugin [-c|--channel=channel] [-b|--basedir=dir] [-l|--local] [-m|--master] [type name|packagefile|packageurl]
(使用例その1) pear.ethna.jpからHoge_Fugaプラグインのパッケージをインストールする $ ethna install-plugin -l Hoge Fuga (使用例その2) 指定されたtgzファイルからEthna本体のプラグインをアップグレードする $ ethna upgrade-plugin -m http://pear.ethna.jp/get/Ethna_Plugin_Hoge_Fuga-0.0.1.tgz
プラグインをパッケージからインストール、アップグレードします。pearコマンドのinstall、upgradeと似たような動作をします。
- [-l|--local], [-m|--master]
- list-pluginと同様です。
- [-b|--basedir]
- プロジェクトのあるディレクトリを指定します。
- 省略時は、現在のディレクトリから親ディレクトリをたどってプロジェクトを自動的に探索します。
- [-s|--state]
- パッケージの状態(stable, alpha, beta)を指定できます。
uninstall-plugin コマンド
(使い方) $ ethna uninstall-plugin [-c|--channel=channel] [-b|--basedir=dir] [-l|--local] [-m|--master] [type name]
パッケージでインストールされたプラグインをアンインストールします。
インストールしたファイルをローカルで編集していても問答無用で消しますので注意してください。
info-plugin コマンド
$ ethna info-plugin [-c|--channel=channel] [-b|--basedir=dir] [-l|--local] [-m|--master] [type name]
パッケージでインストールされたプラグインのパッケージ情報を表示します。 pear info [パッケージ名] と同様です。
channel-update コマンド
$ ethna channel-update [-c|--channel=channel] [-b|--basedir=dir] [-l|--local] [-m|--master]
Ethnaのパッケージをダウンロードするpear channelの情報をアップデートします。 pear channel-update pear.ethna.jp とほぼ同様です。
make-plugin-package コマンド
(使い方) $ ethna make-plugin-package [-i|--inifile=file] [-s|--skelfile=file] [-w|--workdir=dir]
プラグインのパッケージを作ります。詳しくはプラグインのパッケージを作るを参照してください。 このコマンドを使うには、PEAR_PackageFileManager がインストールされている必要があります。
- [-i|--inifile]
- パッケージの情報ファイル(ini形式)を指定します。
- [-s|--skelfile]
- プラグインのスケルトンファイルを指定します。
- [-w|--workdir]
- 作業ディレクトリを指定します。省略時はカレントディレクトリです。
その他
clear-cache コマンド
(使い方) $ ethna clear-cache [-b|--basedir=dir] [-a|--any-tmp-files] [-s|--smarty] [-p|--pear] [-c|--cachemanager]
アプリケーションのキャッシュファイルを削除します。
- [-s|--smarty]
- smartyのキャッシュ、コンパイル済みファイルを削除
- [-c|--cachemanager]
- Cachemanager_Localfileが作るキャッシュファイルを削除します。デフォルトではアプリケーションの tmp/.cache/ 以下のファイルです。
- [-p|--pear]
- ethnaコマンドで使っているpearチャンネル関連のキャッシュを削除します。
- [-a|--any-tmp-files]
- アプリケーションの tmp/ 以下のファイルをすべて削除します。
ethna コマンドを拡張する
ethna で指定できる各コマンドは Ethna_Plugin_Handle_* プラグインで作られています。プラグインはアプリケーション固有のものもありますが、現在のところ ethna コマンド用 のプラグインはEthna本体のものしか使えません。
Ethna_Handle について
Ethna_Handleはコントローラから独立したクラスです。ethnaコマンドが実行されてまずインスタンスが作られます。Ethna_Handleのコンストラクタ内でようやくEthna_Controllerのインスタンスが作られます。
Ethna本体のディレクトリやアプリケーションのディレクトリに何か指示をするときは、いったん以下のメソッドで各コントローラを取得し、$ctl->getDirectory('tmp')とかするといいと思います。
- getEthnaController()
- Ethna_Controllerのインスタンスを取得します。これはEthna本体のEthna_Controller.phpで定義されたEthna_Controllerそのものです。
- getAppController($app_dir)
- 指定されたディレクトリからアプリケーションのコントローラをさがし、そのインスタンスを返します。