Files
everything-claude-code/docs/ja-JP/skills/tinystruct-patterns/references/architecture.md
Claude 174e31b3fc feat(ja-JP): add skill sub-reference translations (angular, remotion, etc.)
Translated 85 skill sub-reference files to achieve full parity with
the English source:

- skills/angular-developer/references/ — 35 files (all references)
- skills/remotion-video-creation/rules/ — 28 files (all rules)
- skills/tinystruct-patterns/references/ — 5 files
- skills/openclaw-persona-forge/references/ — 6 files
- skills/skill-comply/prompts/ — 3 files
- skills/lead-intelligence/agents/ — 4 files
- skills/brand-voice/references/ — 1 file
- skills/frontend-slides/ — 2 files
- hooks/memory-persistence/README.md — 1 file

English source parity: 0 missing files (excluding rules/zh/, internal
docs, and experimental examples absent from zh-CN)
2026-05-18 06:15:26 +09:00

4.3 KiB
Raw Blame History

tinystruct アーキテクチャと設定

使用場面

CLIとHTTPを同等に扱う軽量で高性能なJavaフレームワークが必要な場合にtinystructを選択します。マイクロサービス、コマンドラインユーティリティ、フットプリントが小さく依存関係のないJSONハンドリングが必要なデータ駆動アプリケーションの構築に理想的です。変更なしにターミナルとWebサーバーの両方でロジックを一度だけ書いて公開したい場合に使用します。

動作の仕組み

コアアーキテクチャ

フレームワークはURLパターンまたはコマンド文字列Action オブジェクトにマッピングするシングルトン ActionRegistry で動作します。リクエストが到着すると、システムはパスを解決して対応するメソッドハンドルを呼び出します。

主要な抽象化

クラス/インターフェース 役割
AbstractApplication すべてのtinystruct アプリケーションの基底クラス。これを拡張します。
@Action アノテーション メソッドをURIパスWebまたはコマンド名CLIにマッピングします。単一のルーティングプリミティブ。
ActionRegistry URLパターンを Action オブジェクトにregexでマッピングするシングルトン。直接インスタンス化しない。
Action ディスパッチ用の MethodHandle + regexパターン + 優先度 + Mode をラップします。
Context リクエストごとの状態ストア。getContext() でアクセス。CLIの引数とHTTPのリクエスト/レスポンスを保持。
Dispatcher CLIエントリポイントbin/dispatcher)。アプリケーションを読み込むには --import を読み取ります。
HttpServer 組み込みのNettyベースHTTPサーバー。bin/dispatcher start --import org.tinystruct.system.HttpServer で起動。

パッケージマップ

org.tinystruct/
├── AbstractApplication.java      ← これを拡張する
├── Application.java              ← インターフェース
├── ApplicationException.java     ← チェック済み例外
├── ApplicationRuntimeException.java ← 非チェック例外
├── application/
│   ├── Action.java               ← ランタイムアクションラッパー
│   ├── ActionRegistry.java       ← シングルトンルートレジストリ
│   └── Context.java              ← リクエストコンテキスト
├── system/
│   ├── annotation/Action.java    ← @Actionアテーション + Mode列挙型
│   ├── Dispatcher.java           ← CLIディスパッチャー
│   ├── HttpServer.java           ← 組み込みHTTPサーバー
│   ├── EventDispatcher.java      ← イベントバス
│   └── Settings.java             ← application.propertiesを読み取る
├── data/component/Builder.java   ← JSONシリアライゼーションGson/Jacksonの代わりに使用
└── http/                         ← Request、Response、Constants

テンプレートの動作とディスパッチフロー

デフォルトでは、フレームワークはビューテンプレートが必要だと仮定します。templateRequiredtrue の場合、toString()src/main/resources/themes/<ClassName>.view 内の .view ファイルを探します。getContext() を使って状態を管理し、setVariable("name", value) でテンプレートにデータを渡します。テンプレートは補間に [%name%] を使用します。

最小アプリケーションの初期化

@Override
public void init() {
    this.setTemplateRequired(false); // データのみのアプリでは.viewテンプレートのルックアップをスキップ
}

アクション定義とCLI呼び出し

@Action("hello")
public String hello() {
    return "Hello, tinystruct!";
}

ディスパッチャー経由での実行:

bin/dispatcher hello

設定へのアクセス

src/main/resources/application.properties に配置:

String port = this.getConfiguration("server.port");