<html>
<body>
S2コンテナとその構成要素を定義するインターフェースおよび、S2コンテナの振舞いに関連した例外クラスを提供します。
<p>
このパッケージを構成する主な要素は、以下のとおりです。
<dl>
<dt>コンテナ本体(<a href="S2Container.html">S2Container</a>)</dt>
<dd>
S2コンテナ本体は、各コンポーネントの定義情報を保持し、必要に応じてコンポーネントの生成・提供を行います。
S2コンテナは階層構造を持つことができます。階層関係はdiconファイルの<include>要素で指定します。
</dd>
<dt>定義情報(~Def)</dt>
<dd>
diconファイルやアノテーションで指定されたコンポーネントの定義情報は、S2コンテナ上では
<a href="ComponentDef.html">ComponentDef</a>、<a href="PropertyDef.html">PropertyDef</a>
などの定義情報として保持されます。
</dd>
<dt>定義情報の集約(~DefAware)</dt>
<dd>
diconファイル上で<initMethod>要素の子要素として<arg>要素を書くように、定義情報は親子関係(集約関係)を持ちます。
要素間に親子関係がある場合、親要素はこのタイプのインターフェースを継承し、
子要素である定義情報の追加や取得などの機能<sup><a href="#remark1">※1</a></sup>を提供します。
</dd>
<dt>式(<a href="Expression.html">Expression</a>)</dt>
<dd>
S2コンテナでは、コンポーネントの定義や値の定義に、式を利用することが出来ます。標準ではOGNL式をサポートしています。
</dd>
<dt>外部コンテキストへのアクセス(<a href="ExternalContext.html">ExternalContext</a>)</dt>
<dd>
Webコンテナやポートレットコンテナで管理されるコンポーネントへのアクセス手段を提供します。
例えば、Webコンテナのrequestスコープコンポーネント(HttpServletRequest)の取得や設定を行うことが出来ます。
</dd>
<dt>コンポーネントの構築(~Assembler)</dt>
<dd>
S2コンテナでは、コンストラクタ、プロパティ設定、初期化メソッドを順に実行してコンポーネントを組み立てます。
それぞれの処理を<a href="ConstructorAssembler.html">ConstructorAssembler</a>、
<a href="PropertyAssembler.html">PropertyAssembler</a>、
<a href="MethodAssembler.html">MethodAssembler</a><sup><a href="#remark2">※2</a></sup>が担当します。
</dd>
<dt>コンポーネント自動登録機構(HOT / WARM / COOL deploy)</dt>
<dd>
規約に従って作成されたクラスを、S2コンテナが管理するコンポーネントとして自動的に登録する機能を提供します。
この機能に関連するインターフェースとして<a href="ComponentCreator.html">ComponentCreator</a>、
<a href="ComponentCustomizer.html">ComponentCustomizer</a>があります。
</dd>
</dl>
<p style="text-indent:-1em; padding-left:1em">
<a name="remark1">※1</a> ~DefAware系インターフェースは、子要素である定義情報の追加(add~Def)、要素数の取得(get~DefSize)、
定義情報の取得(get~Def)の3種類のメソッドを提供します。
</p>
<p style="text-indent:-1em; padding-left:1em">
<a name="remark2">※2</a> このインターフェースは、S2コンテナによって管理されているコンポーネントが破棄される際の
<a href="DestroyMethodDef.html">終了メソッド</a>としても用いられます。
</p>
</p>
<p>
diconファイルのタグとS2コンテナの構成要素を表すインターフェースは、直接関連しています。下表にその関係を示します。
<table border="1">
<tr class="TableHeadingColor">
        <th colspan="4">タグ(Tigerアノテーション)とS2コンテナの構成要素を表すインターフェースの関係</th>
</tr>
<tr>
        <th>diconファイルタグ</th>
        <th>Tigerアノテーション</th>
        <th>要素定義インターフェース</th>
        <th>要素集約インターフェース</th>
</tr>
</tr>
        <td><components></td>
        <td style="text-align:center;">-</td>
        <td><a href="S2Container.html">S2Container</a></td>
        <td style="text-align:center;">-</td>
</tr>
<tr>
        <td><component></td>
        <td>@Component</td>
        <td><a href="ComponentDef.html">ComponentDef</a></td>
        <td style="text-align:center;">-</td>
</tr>
<tr>
        <td><arg></td>
        <td style="text-align:center;">-</td>
        <td><a href="ArgDef.html">ArgDef</a></td>
        <td><a href="ArgDefAware.html">ArgDefAware</a></td>
</tr>
<tr>
        <td><property></td>
        <td>@Binding<sup><a href="remark3">※3</a></sup></td>
        <td><a href="PropertyDef.html">PropertyDef</a></td>
        <td><a href="PropertyDefAware.html">PropertyDefAware</a></td>
</tr>
<tr>
        <td><initMethod></td>
        <td>@InitMethod</td>
        <td><a href="InitMethodDef.html">InitMethodDef</a></td>
        <td><a href="InitMethodDefAware.html">InitMethodDefAware</a></td>
</tr>
<tr>
        <td><destroyMethod></td>
        <td>@DestroyMethod</td>
        <td><a href="DestroyMethodDef.html">DestroyMethodDef</a></td>
        <td><a href="DestroyMethodDefAware.html">DestroyMethodDefAware</a></td>
</tr>
<tr>
        <td><aspect></td>
        <td>@Aspect</td>
        <td><a href="AspectDef.html">AspectDef</a></td>
        <td><a href="AspectDefAware.html">AspectDefAware</a></td>
</tr>
<tr>
        <td><interType></td>
        <td>@InterType</td>
        <td><a href="InterTypeDef.html">InterTypeDef</a></td>
        <td><a href="InterTypeDefAware.html">InterTypeDefAware</a></td>
</tr>
<tr>
        <td><meta></td>
        <td style="text-align:center;">-</td>
        <td><a href="MetaDef.html">MetaDef</a></td>
        <td><a href="MetaDefAware.html">MetaDefAware</a></td>
</tr>
</table>
<p style="text-indent:-1em; padding-left:1em">
※3 @Propertyアノテーションは、フィールドに対応するアクセッサをコンポーネントに追加することを表します。
</p>
</p>
</body>
</html>