docs/ja-JP/skills/tinystruct-patterns/SKILL.md
tinystructフレームワークでアプリケーションモジュールまたはマイクロサービスを開発する際に使用。ルーティング、コンテキスト管理、BuilderによるJSON処理、CLI/HTTPデュアルモードのパターンをカバー。
npx skillsauth add affaan-m/everything-claude-code tinystruct-patternsInstall this skill globally with one command. Works with Claude Code, Cursor, and Windsurf.
3 of 9 scanners reported clean
Some scanners were skipped, did not run, or reported a non-clean status. Review each row below.
tinystruct Java フレームワークを使用してモジュールをビルドするためのアーキテクチャと実装パターン。CLIとHTTPが等しく扱われる軽量なシステムです。
AbstractApplication を拡張して新しい Application モジュールを作成するとき。@Action を使用してルートとコマンドラインアクションを定義するとき。Context を通じてリクエストごとの状態を処理するとき。Builder コンポーネントを使用してJSONシリアライゼーションを行うとき。application.properties でデータベース接続またはシステム設定を構成するとき。ApplicationManager.init() を通じて標準的な bin/dispatcher エントリポイントを生成または再生成するとき。tinystruct フレームワークは、@Action でアノテーションされたメソッドをターミナルとWeb環境の両方でルーティング可能なエンドポイントとして扱います。アプリケーションは AbstractApplication を拡張することで作成され、init() などのコアライフサイクルフックとリクエスト Context へのアクセスが提供されます。
ルーティングは ActionRegistry によって処理され、パスセグメントをメソッド引数に自動的にマッピングして依存関係を注入します。データのみのサービスでは、ゼロ依存のフットプリントを維持するために、JSONシリアライゼーションにネイティブの Builder コンポーネントを使用すべきです。フレームワークには ApplicationManager のユーティリティも含まれており、bin/dispatcher スクリプトを生成することでプロジェクトの実行環境をブートストラップします。
public class MyService extends AbstractApplication {
@Override
public void init() {
this.setTemplateRequired(false); // データ/APIアプリの .view 参照を無効化
}
@Override public String version() { return "1.0.0"; }
@Action("greet")
public String greet() {
return "Hello from tinystruct!";
}
}
// Web: /api/user/123 または CLI: "bin/dispatcher api/user/123" を処理
@Action("api/user/(\\d+)")
public String getUser(int userId) {
return "User ID: " + userId;
}
@Action(value = "login", mode = Mode.HTTP_POST)
public boolean doLogin() {
// ログイン処理
return true;
}
@Action("api/data")
public Builder getData() throws ApplicationException {
Builder builder = new Builder();
builder.put("status", "success");
Builder nested = new Builder();
nested.put("id", 1);
nested.put("name", "James");
builder.put("data", nested);
return builder;
}
設定は src/main/resources/application.properties で管理されます。
JUnit 5 を使用して、アクションが ActionRegistry に登録されていることを検証することでアクションをテストします。
| 症状 | 正しいパターン |
|---|---|
| com.google.gson または com.fasterxml.jackson のインポート | org.tinystruct.data.component.Builder を使用する。 |
| .view ファイルの FileNotFoundException | APIのみのアプリでは init() 内で setTemplateRequired(false) を呼び出す。 |
| private メソッドへの @Action アノテーション | アクションはフレームワークに登録されるために public である必要がある。 |
| アプリ内での main(String[] args) のハードコーディング | すべてのモジュールのエントリポイントとして bin/dispatcher を使用する。 |
| 手動での ActionRegistry 登録 | 自動検出のために @Action アノテーションを優先する。 |
詳細なガイドは references/ ディレクトリにあります:
Builder の使用data-ai
Design task-local harnesses, eval gates, and reusable skill extraction for Claude dynamic workflow mode and other adaptive agent harnesses.
development
React component testing with React Testing Library, Vitest/Jest, MSW for network mocking, accessibility assertions with axe, and the decision boundary between component tests and Playwright/Cypress end-to-end runs. Use when writing or fixing tests for React components, hooks, or pages.
tools
React and Next.js performance optimization patterns adapted from Vercel Engineering's React Best Practices (https://github.com/vercel-labs/agent-skills). Organizes 70+ rules across 8 priority categories — waterfalls, bundle size, server-side, client fetching, re-render, rendering, JS micro-perf, advanced. Use when writing, reviewing, or refactoring React/Next.js code for performance.
tools
React 18/19 patterns including hooks discipline, server/client component boundaries, Suspense + error boundaries, form actions, data fetching, state management decision trees, and accessibility-first composition. Use when writing or reviewing React components.