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 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.luaprocess.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"

関連項目