<?php
include_once $_SERVER['DOCUMENT_ROOT'] . '/include/shared-manual.inc';
$TOC = array();
$TOC_DEPRECATED = array();
$PARENTS = array();
include_once dirname(__FILE__) ."/toc/book.yaf.inc";
$setup = array (
  'home' => 
  array (
    0 => 'index.php',
    1 => 'PHP Manual',
  ),
  'head' => 
  array (
    0 => 'UTF-8',
    1 => 'ja',
  ),
  'this' => 
  array (
    0 => 'yaf.appconfig.php',
    1 => 'アプリケーションの設定',
    2 => 'アプリケーションの設定',
  ),
  'up' => 
  array (
    0 => 'book.yaf.php',
    1 => 'Yaf',
  ),
  'prev' => 
  array (
    0 => 'yaf.tutorials.php',
    1 => '例',
  ),
  'next' => 
  array (
    0 => 'class.yaf-application.php',
    1 => 'Yaf_Application',
  ),
  'alternatives' => 
  array (
  ),
  'source' => 
  array (
    'lang' => 'ja',
    'path' => 'reference/yaf/appconfig.xml',
  ),
  'history' => 
  array (
  ),
);
$setup["toc"] = $TOC;
$setup["toc_deprecated"] = $TOC_DEPRECATED;
$setup["parents"] = $PARENTS;
manual_setup($setup);

contributors($setup);

?>
<div id="yaf.appconfig" class="chapter">
 <h1 class="title">アプリケーションの設定</h1>

 <p class="para">
  設定内容を記した配列か、あるいは ini ファイルへのパス
  (<span class="classname"><a href="class.yaf-config-ini.php" class="classname">Yaf_Config_Ini</a></span> を参照ください) を
  <span class="methodname"><a href="yaf-application.construct.php" class="methodname">Yaf_Application::__construct()</a></span> に渡さなければいけません。
 </p>
 <p class="para">
  Yaf は、アプリケーションの設定とユーザーの設定を自動的にマージします。
  アプリケーションの設定には、プレフィックスとして &quot;yaf.&quot; あるいは
  &quot;application.&quot; がつきます。&quot;yaf.&quot; と &quot;application.&quot; の両方が存在する場合は、&quot;application.&quot;
  を使います。
  <div class="example" id="example-1">
   <p><strong>例1 PHP の配列の例</strong></p>
   <div class="example-contents">
<div class="phpcode"><code><span style="color: #000000"><span style="color: #0000BB">&lt;?php<br /><br />$configs </span><span style="color: #007700">= array(<br />    </span><span style="color: #DD0000">"application" </span><span style="color: #007700">=&gt; array(<br />        </span><span style="color: #DD0000">"directory" </span><span style="color: #007700">=&gt; </span><span style="color: #0000BB">dirname</span><span style="color: #007700">(</span><span style="color: #0000BB">__FILE__</span><span style="color: #007700">),<br />        </span><span style="color: #DD0000">"dispatcher" </span><span style="color: #007700">=&gt; array(<br />            </span><span style="color: #DD0000">"catchException" </span><span style="color: #007700">=&gt; </span><span style="color: #0000BB">0</span><span style="color: #007700">,<br />        ),<br />        </span><span style="color: #DD0000">"view" </span><span style="color: #007700">=&gt; array(<br />            </span><span style="color: #DD0000">"ext" </span><span style="color: #007700">=&gt; </span><span style="color: #DD0000">"phtml"</span><span style="color: #007700">,<br />        ),<br />    ),<br />);<br /><br /></span><span style="color: #0000BB">$app </span><span style="color: #007700">= new </span><span style="color: #0000BB">Yaf_Application</span><span style="color: #007700">(</span><span style="color: #0000BB">$configs</span><span style="color: #007700">);<br /><br /></span><span style="color: #0000BB">?&gt;</span></span></code></div>
   </div>

  </div>
  <div class="example" id="example-2">
   <p><strong>例2 ini ファイルの例</strong></p>
   <div class="example-contents">
<div class="inicode"><pre class="inicode">[yaf]
yaf.directory = APPLICATION_PATH &quot;/application&quot;
yaf.dispatcher.catchException = 0

[product : yaf]
; user configuration list here</pre>
</div>
   </div>

  </div>
  </p>
  <p class="para">
  <table class="doctable table">
   <caption><strong>Yaf アプリケーション設定</strong></caption>
   
    <thead>
     <tr>
      <th>名前</th>
      <th>デフォルト</th>
      <th>変更履歴</th>
     </tr>

    </thead>

    <tbody class="tbody">
     <tr>
      <td>application.directory</td>
      <td class="empty">&nbsp;</td>
      <td></td>
     </tr>

     <tr>
      <td>application.ext</td>
      <td>&quot;php&quot;</td>
      <td></td>
     </tr>

     <tr>
      <td>application.view.ext</td>
      <td>&quot;phtml&quot;</td>
      <td></td>
     </tr>

     <tr>
      <td>application.modules</td>
      <td>&quot;index&quot;</td>
      <td></td>
     </tr>

     <tr>
      <td>application.library</td>
      <td>application.directory . &quot;/library&quot;</td>
      <td></td>
     </tr>

     <tr>
      <td>application.library.directory</td>
      <td>application.directory . &quot;/library&quot;</td>
      <td></td>
     </tr>

     <tr>
      <td>application.library.namespace</td>
      <td>&quot;&quot;</td>
      <td></td>
     </tr>

     <tr>
      <td>application.bootstrap</td>
      <td>application.directory . &quot;/Bootstrap&quot; . application.ext</td>
      <td></td>
     </tr>

     <tr>
      <td>application.baseUri</td>
      <td>&quot;&quot;</td>
      <td></td>
     </tr>

     <tr>
      <td>application.dispatcher.defaultRoute</td>
      <td class="empty">&nbsp;</td>
      <td></td>
     </tr>

     <tr>
      <td>application.dispatcher.throwException</td>
      <td>1</td>
      <td></td>
     </tr>

     <tr>
      <td>application.dispatcher.catchException</td>
      <td>0</td>
      <td></td>
     </tr>

     <tr>
      <td>application.dispatcher.defaultModule</td>
      <td>&quot;index&quot;</td>
      <td></td>
     </tr>

     <tr>
      <td>application.dispatcher.defaultController</td>
      <td>&quot;index&quot;</td>
      <td></td>
     </tr>

     <tr>
      <td>application.dispatcher.defaultAction</td>
      <td>&quot;index&quot;</td>
      <td></td>
     </tr>

     <tr>
      <td>application.system</td>
      <td class="empty">&nbsp;</td>
      <td></td>
     </tr>

    </tbody>
   
  </table>

 </p>

 <p class="para">以下に設定ディレクティブに関する
簡単な説明を示します。</p>

 <p class="para">
  <dl>
   
     <dt id="configuration.yaf.directory">
      <code class="parameter">application.directory</code>
      <span class="type"><a href="language.types.string.php" class="type string">string</a></span>
     </dt>
     <dd>
      <p class="para">
       アプリケーションのディレクトリ。このフォルダの中に
       &quot;controllers&quot;、&quot;views&quot;、&quot;models&quot;、&quot;plugins&quot; といったフォルダを配置します。
      </p>
      <p class="para">
       <blockquote class="note"><p><strong class="note">注意</strong>: 
        <p class="para">
         この項目は、デフォルト値を持たない唯一の項目です。
         つまり、必ず手動で指定しなければいけません。
        </p>
       </p></blockquote>
      </p>
     </dd>
    
    
     <dt id="configuration.yaf.ext">
      <code class="parameter">application.ext</code>
      <span class="type"><a href="language.types.string.php" class="type string">string</a></span>
     </dt>
     <dd>
      <p class="para">
       PHP スクリプトファイルの拡張子。クラスのオートロード
       (<span class="classname"><a href="class.yaf-loader.php" class="classname">Yaf_Loader</a></span>) で利用します。
      </p>
     </dd>
    
    
     <dt id="configuration.yaf.view.ext">
      <code class="parameter">application.view.ext</code>
      <span class="type"><a href="language.types.string.php" class="type string">string</a></span>
     </dt>
     <dd>
      <p class="para">
       ビューテンプレートスクリプトのファイル拡張子。
      </p>
     </dd>
    
    
     <dt id="configuration.yaf.modules">
      <code class="parameter">application.modules</code>
      <span class="type"><a href="language.types.string.php" class="type string">string</a></span>
     </dt>
     <dd>
      <p class="para">
       登録済みモジュールのカンマ区切りのリスト。特に、
       ルーティングで PATH_INFO に三つ以上のセグメントがあるときに使います。
      </p>
      <p class="para">
       Yaf は、最初のセグメントがモジュール名なのかそうでないのかを知る手段が必要です。
      </p>
     </dd>
    
    
     <dt id="configuration.yaf.library">
      <code class="parameter">application.library</code>
      <span class="type"><a href="language.types.string.php" class="type string">string</a></span>
     </dt>
     <dd>
      <p class="para">
       ローカルライブラリディレクトリ。<span class="classname"><a href="class.yaf-loader.php" class="classname">Yaf_Loader</a></span> および
       <a href="yaf.configuration.php#ini.yaf.library" class="link">yaf.library</a> を参照ください。
       </p>
       <blockquote class="note"><p><strong class="note">注意</strong>: 
        <p class="para">
         Yaf 2.1.6 以降では、この項目に配列を指定できるようになりました。
         配列を指定した場合、ライブラリパスには <a href="yaf.appconfig.php#configuration.yaf.library.directory" class="link">application.library.directory</a>
         の値を使います。
        </p>
       </p></blockquote>
     </dd>
    
    
     <dt id="configuration.yaf.library.directory">
      <code class="parameter">application.library.directory</code>
      <span class="type"><a href="language.types.string.php" class="type string">string</a></span>
     </dt>
     <dd>
      <p class="para">
       <a href="yaf.appconfig.php#configuration.yaf.library" class="link">application.library</a> のエイリアス。
       Yaf 2.1.6 で導入されました。
      </p>
     </dd>
    
    
     <dt id="configuration.yaf.library.namespace">
      <code class="parameter">application.library.namespace</code>
      <span class="type"><a href="language.types.string.php" class="type string">string</a></span>
     </dt>
     <dd>
      <p class="para">
       カンマ区切りで表した、ローカルライブラリ名前空間のプレフィックス。
      </p>
      <p class="para">
       Yaf 2.1.6 で導入されました。
      </p>
     </dd>
    
    
     <dt id="configuration.yaf.bootstrap">
      <code class="parameter">application.bootstrap</code>
      <span class="type"><a href="language.types.string.php" class="type string">string</a></span>
     </dt>
     <dd>
      <p class="para">
       ブートストラップクラスのスクリプトへの絶対パス。
      </p>
     </dd>
    
    
     <dt id="configuration.yaf.baseuri">
      <code class="parameter">application.baseUri</code>
      <span class="type"><a href="language.types.string.php" class="type string">string</a></span>
     </dt>
     <dd>
      <p class="para">
       ルーティング時に、決まったプレフィックスをリクエスト URI から取り除くために使います。
       例として、リクエスト URI が &quot;/prefix/controller/action&quot; だった場合を考えましょう。
       application.baseUri を &quot;/prefix&quot; にしておくと、
       ルーティング時に &quot;/controller/action&quot; だけが PATH_INFO とみなされるようになります。
      </p>
      <p class="para">
       ふつうは、この値を設定する必要はありません。
      </p>
     </dd>
    
    
     <dt id="configuration.yaf.dispatcher.throwexception">
      <code class="parameter">application.dispatcher.throwException</code>
      <span class="type"><a href="language.types.boolean.php" class="type bool">bool</a></span>
     </dt>
     <dd>
      <p class="para">
       これを On にすると、エラーが発生したときに Yaf が例外をスローするようになります。
       <span class="methodname"><a href="yaf-dispatcher.throwexception.php" class="methodname">Yaf_Dispatcher::throwException()</a></span> も参照ください。
      </p>
     </dd>
    
    
     <dt id="configuration.yaf.dispatcher.catchexception">
      <code class="parameter">application.dispatcher.catchException</code>
      <span class="type"><a href="language.types.boolean.php" class="type bool">bool</a></span>
     </dt>
     <dd>
      <p class="para">
       これを On にすると、Yaf が例外をキャッチできなかったときに
       Error コントローラの Error アクションに転送するようになります。
       <span class="methodname"><a href="yaf-dispatcher.catchexception.php" class="methodname">Yaf_Dispatcher::catchException()</a></span> も参照ください。
      </p>
     </dd>
    
    
     <dt id="configuration.yaf.dispatcher.defaulRoute">
      <code class="parameter">application.dispatcher.defaultRoute</code>
      <span class="type"><a href="language.types.string.php" class="type string">string</a></span>
     </dt>
     <dd>
      <p class="para">
       デフォルトのルート。指定しなかった場合は、デフォルトとして Static
       ルートを使います。
       <span class="methodname"><a href="yaf-router.addroute.php" class="methodname">Yaf_Router::addRoute()</a></span> も参照ください。
      </p>
     </dd>
    
    
     <dt id="configuration.yaf.dispatcher.defaultmodule">
      <code class="parameter">application.dispatcher.defaultModule</code>
      <span class="type"><a href="language.types.string.php" class="type string">string</a></span>
     </dt>
     <dd>
      <p class="para">
       デフォルトのモジュール名。
       <span class="methodname"><a href="yaf-dispatcher.setdefaultmodule.php" class="methodname">Yaf_Dispatcher::setDefaultModule()</a></span>
       も参照ください。
      </p>
     </dd>
    
    
     <dt id="configuration.yaf.dispatcher.defaultcontroller">
      <code class="parameter">application.dispatcher.defaultController</code>
      <span class="type"><a href="language.types.string.php" class="type string">string</a></span>
     </dt>
     <dd>
      <p class="para">
       デフォルトのコントローラ名。
       <span class="methodname"><a href="yaf-dispatcher.setdefaultcontroller.php" class="methodname">Yaf_Dispatcher::setDefaultController()</a></span>
       も参照ください。
      </p>
     </dd>
    
    
     <dt id="configuration.yaf.dispatcher.defaultaction">
      <code class="parameter">application.dispatcher.defaultAction</code>
      <span class="type"><a href="language.types.string.php" class="type string">string</a></span>
     </dt>
     <dd>
      <p class="para">
       デフォルトのアクション名。
       <span class="methodname"><a href="yaf-dispatcher.setdefaultaction.php" class="methodname">Yaf_Dispatcher::setDefaultAction()</a></span>
       も参照ください。
      </p>
     </dd>
    

    
     <dt id="configuration.yaf.system">
      <code class="parameter">application.system</code>
      <span class="type"><a href="language.types.string.php" class="type string">string</a></span>
     </dt>
     <dd>
      <p class="para">
       yaf の実行時の設定を、application.ini で
       <a href="yaf.configuration.php#ini.yaf.lowcase-path" class="link">application.system.lowcase_path</a>
       のように設定します。
       <blockquote class="note"><p><strong class="note">注意</strong>: 
        <p class="para">
        この方法で設定できるのは <strong><code><a href="info.constants.php#constant.ini-all">INI_ALL</a></code></strong> の項目だけです。
       </p>
       </p></blockquote>
      </p>
     </dd>
    

  </dl>
 </p>
</div>
<?php manual_footer($setup); ?>