CLI リファレンス
Wippy ランタイムのコマンドラインインターフェース。
グローバルフラグ
全てのコマンドで使用可能:
| フラグ | 短縮形 | 説明 |
|---|---|---|
--config |
設定ファイル (デフォルト: .wippy.yaml) | |
--verbose |
-v |
デバッグログを有効化 |
--very-verbose |
スタックトレース付きデバッグ | |
--console |
-c |
カラフルなコンソールログ |
--silent |
-s |
コンソールログを無効化 |
--event-streams |
-e |
イベントバスへログをストリーム |
--profiler |
-p |
localhost:6060 で pprof を有効化 |
--memory-limit |
-m |
メモリ制限 (例: 1G, 512M) |
メモリ制限の優先順位: --memory-limit フラグ > GOMEMLIMIT 環境変数 > デフォルト 1GB。
wippy init
新しいロックファイルを作成する。
wippy init
wippy init --src-dir ./src --modules-dir .wippy
| フラグ | 短縮形 | デフォルト | 説明 |
|---|---|---|---|
--src-dir |
-d |
./src | ソースディレクトリ |
--modules-dir |
.wippy | モジュールディレクトリ | |
--lock-file |
-l |
wippy.lock | ロックファイルのパス |
wippy run
ランタイムを起動するか、コマンドを実行する。
wippy run # ランタイムを起動
wippy run list # 利用可能なコマンドを一覧表示
wippy run test # テストを実行
wippy run snapshot.wapp # パックファイルから実行
wippy run acme/http # モジュールを実行
wippy run --exec app:processes/app:worker # 単一プロセスを実行
| フラグ | 短縮形 | 説明 |
|---|---|---|
--override |
-o |
エントリの値を上書き (namespace:entry:field=value) |
--exec |
-x |
プロセスを実行して終了 (host/namespace:entry) |
--host |
実行用ホスト | |
--registry |
レジストリ URL |
wippy lint
Lua コードの型エラーや警告をチェックする。
wippy lint
wippy lint --level warning
全ての Lua エントリを検証: function.lua.*、library.lua.*、process.lua.*、workflow.lua.*。
| フラグ | 説明 |
|---|---|
--level |
報告する最小重大度レベル |
wippy add
モジュール依存関係を追加する。
wippy add acme/http
wippy add acme/http@1.2.3
wippy add acme/http@latest
| フラグ | 短縮形 | デフォルト | 説明 |
|---|---|---|---|
--lock-file |
-l |
wippy.lock | ロックファイルのパス |
--registry |
レジストリ URL |
wippy install
ロックファイルから依存関係をインストールする。
wippy install
wippy install --force
| フラグ | 短縮形 | 説明 |
|---|---|---|
--lock-file |
-l |
ロックファイルのパス |
--force |
キャッシュをバイパスし、常にダウンロード | |
--registry |
レジストリ URL |
wippy update
依存関係を更新し、ロックファイルを再生成する。
wippy update # 全て更新
wippy update acme/http # 特定のモジュールを更新
wippy update acme/http demo/sql # 複数を更新
| フラグ | 短縮形 | デフォルト | 説明 |
|---|---|---|---|
--lock-file |
-l |
wippy.lock | ロックファイルのパス |
--src-dir |
-d |
. | ソースディレクトリ |
--modules-dir |
.wippy | モジュールディレクトリ | |
--registry |
レジストリ URL |
wippy pack
スナップショットパック (.wapp ファイル) を作成する。
wippy pack snapshot.wapp
wippy pack release.wapp --description "Release 1.0"
wippy pack app.wapp --embed app:assets --bytecode **
| フラグ | 短縮形 | 説明 |
|---|---|---|
--lock-file |
-l |
ロックファイルのパス |
--description |
-d |
パックの説明 |
--tags |
-t |
パックのタグ (カンマ区切り) |
--meta |
カスタムメタデータ (key=value) | |
--embed |
fs.directory エントリを埋め込む (パターン) | |
--list |
fs.directory エントリを一覧表示 (ドライラン) | |
--exclude-ns |
名前空間を除外 (パターン) | |
--exclude |
エントリを除外 (パターン) | |
--bytecode |
Lua をバイトコードにコンパイル (** で全て) |
wippy publish
モジュールをハブに公開する。
wippy publish
wippy publish --version 1.0.0
wippy publish --dry-run
カレントディレクトリの wippy.yaml を読み込む。
| フラグ | 説明 |
|---|---|
--version |
公開するバージョン |
--dry-run |
公開せずに検証のみ実行 |
--label |
バージョンの代わりに可変ラベルとして公開 |
--release-notes |
リリースノート |
--protected |
バージョンを保護済みとしてマーク |
--embed |
fs.directory エントリを ID または名前で埋め込む |
--config |
wippy.yaml を含むディレクトリのパス (デフォルト: .) |
--registry |
レジストリ URL |
wippy search
ハブでモジュールを検索する。
wippy search http
wippy search "sql driver" --limit 20
wippy search auth --json
| フラグ | 説明 |
|---|---|
--json |
JSON として出力 |
--limit |
最大結果数 |
--registry |
レジストリ URL |
wippy auth
レジストリ認証を管理する。
wippy auth login
wippy auth login
wippy auth login --token YOUR_TOKEN
| フラグ | 説明 |
|---|---|
--token |
API トークン |
--registry |
レジストリ URL |
--local |
資格情報をローカルに保存 |
wippy auth logout
wippy auth logout
| フラグ | 説明 |
|---|---|
--registry |
レジストリ URL |
--local |
ローカルの資格情報を削除 |
wippy auth status
wippy auth status
wippy auth status --json
wippy registry
レジストリエントリを照会・検査する。
wippy registry list
wippy registry list
wippy registry list --kind function.lua
wippy registry list --ns app --json
| フラグ | 短縮形 | 説明 |
|---|---|---|
--kind |
-k |
種類でフィルタ |
--ns |
-n |
名前空間でフィルタ |
--name |
名前でフィルタ | |
--meta |
メタデータでフィルタ | |
--json |
JSON として出力 | |
--yaml |
YAML として出力 | |
--lock-file |
-l |
ロックファイルのパス |
wippy registry show
wippy registry show app:http:handler
wippy registry show app:config --yaml
| フラグ | 短縮形 | 説明 |
|---|---|---|
--field |
-f |
特定のフィールドを表示 |
--json |
JSON として出力 | |
--yaml |
YAML として出力 | |
--raw |
生出力 | |
--lock-file |
-l |
ロックファイルのパス |
wippy version
バージョン情報を表示する。
wippy version
wippy version --short
カスタムコマンド
process.lua または process.wasm エントリは、command メタデータを追加することで名前付きコマンドとして登録できる:
entries:
- name: test_runner
kind: process.lua
meta:
command:
name: test
short: Run application tests
source: file://runner.lua
method: main
modules:
- io
- registry
- funcs
以下のコマンドで実行する:
wippy run test
利用可能な全コマンドを一覧表示する:
wippy run list
コマンドメタデータフィールド
| フィールド | 必須 | 説明 |
|---|---|---|
name |
はい | wippy run <name> で使用するコマンド名 |
short |
いいえ | wippy run list に表示される短い説明 |
任意のプロセスエントリ種類 (process.lua、process.wasm) が使用可能。コマンド名はロードされた全エントリ間で一意でなければならない。コマンド名の後の引数はプロセスに渡される。
使用例
開発ワークフロー
# プロジェクトを初期化
wippy init
wippy add wippy/http wippy/sql
wippy install
# エラーをチェック
wippy lint
# デバッグ出力付きで実行
wippy run -c -v
# ローカル開発用に設定を上書き
wippy run -o app:db:host=localhost -o app:db:port=5432
本番デプロイ
# バイトコード付きリリースパックを作成
wippy pack release.wapp --bytecode ** --exclude-ns test.**
# メモリ制限付きでパックから実行
wippy run release.wapp -m 2G
デバッグ
# 単一プロセスを実行
wippy run --exec app:processes/app:worker
# プロファイラを有効にして実行
wippy run -p -v
# 確認: go tool pprof http://localhost:6060/debug/pprof/heap
依存関係管理
# 新しい依存関係を追加
wippy add acme/http@latest
# 強制的に再ダウンロード
wippy install --force
# 特定のモジュールを更新
wippy update acme/http
公開
# ハブにログイン
wippy auth login
# モジュールを検証
wippy publish --dry-run
# 公開
wippy publish --version 1.0.0 --release-notes "Initial release"
設定ファイル
永続的な設定のために .wippy.yaml を作成する:
logger:
mode: development
level: debug
encoding: console
logmanager:
min_level: -1 # debug
profiler:
enabled: true
address: localhost:6060
override:
app:gateway:addr: ":9090"
app:db:host: "localhost"