<?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 => 'pt_BR',
  ),
  'this' => 
  array (
    0 => 'yaf.appconfig.php',
    1 => 'Configura&ccedil;&atilde;o de Aplica&ccedil;&atilde;o',
    2 => 'Configura&ccedil;&atilde;o de Aplica&ccedil;&atilde;o',
  ),
  'up' => 
  array (
    0 => 'book.yaf.php',
    1 => 'Yaf',
  ),
  'prev' => 
  array (
    0 => 'yaf.tutorials.php',
    1 => 'Exemplos',
  ),
  'next' => 
  array (
    0 => 'class.yaf-application.php',
    1 => 'Yaf_Application',
  ),
  'alternatives' => 
  array (
  ),
  'source' => 
  array (
    'lang' => 'pt_BR',
    '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">Configuração de Aplicação</h1>

 <p class="para">
  Um array ou um arquivo INI com configurações (consulte
  <span class="classname"><a href="class.yaf-config-ini.php" class="classname">Yaf_Config_Ini</a></span>) deve ser passado para o método
  <span class="methodname"><a href="yaf-application.construct.php" class="methodname">Yaf_Application::__construct()</a></span>.
 </p>
 <p class="para">
  Yaf mesclará as configurações de aplicação com as configurações do usuário
  automaticamente. As configurações de aplicação têm o prefixo &quot;yaf.&quot; ou
  &quot;application.&quot;. Se ambos &quot;yaf.&quot; e &quot;application.&quot; existirem, &quot;application.&quot;
  terá preferência na aceitação.
  <div class="example" id="example-1">
   <p><strong>Exemplo #1 Um exemplo de array 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>Exemplo #2 Um exemplo de arquivo 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]
; configuração do usuário listada aqui</pre>
</div>
   </div>

  </div>
 </p>
 <p class="para">
  <table class="doctable table">
   <caption><strong>Configuração de Aplicação Yaf</strong></caption>
   
    <thead>
     <tr>
      <th>Nome</th>
      <th>Padrão</th>
      <th>Registro de Alterações</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">Aqui está uma breve explicação das
diretivas de configuração.</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">
      O diretório da aplicação, que é o diretório que contém os diretórios
      &quot;controllers&quot;, &quot;views&quot;, &quot;models&quot; e &quot;plugins&quot;.
     </p>
     <p class="para">
      <blockquote class="note"><p><strong class="note">Nota</strong>: 
       <p class="para">
        Esta entrada de configuração é a única que não tem um valor padrão.
        Deve sempre ser definida manualmente.
       </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">
      A extensão de arquivo do script PHP, usado no autocarregamento de classname
      (<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">
      A extensão de arquivo dos scripts de modelo de visualização.
     </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">
      Uma lista de módulos registrados, separados por vírgulas, usados no processo
      de roteamento, especialmente enquanto existem mais de três segmentos em PATH_INFO.
     </p>
     <p class="para">
      Yaf precisa de uma maneira de descobrir se o primeiro segmento é ou não um nome de módulo.
     </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">
      O diretório de biblioteca local, consulte <span class="classname"><a href="class.yaf-loader.php" class="classname">Yaf_Loader</a></span> e
      <a href="yaf.configuration.php#ini.yaf.library" class="link">yaf.library</a>.
     </p>
     <blockquote class="note"><p><strong class="note">Nota</strong>: 
      <p class="para">
       Depois do Yaf 2.1.6, esta entrada de configuração pode ser um array. O caminho da biblioteca
       tentará usar os itens definidos em <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">
      Sinônimo de <a href="yaf.appconfig.php#configuration.yaf.library" class="link">application.library</a>. Introduzido
      no 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">
      Uma lista de prefixos de namespace de biblioteca local, separados por vírgula.
     </p>
     <p class="para">
      Introduzido no 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">
      Um caminho absoluto do script da classe Bootstrap.
     </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">
      Usado para remover um prefixo fixo de URI de solicitação no processo de roteamento.
      Por exemplo, é recebida uma solicitação com a URI contendo
      &quot;/prefix/controller/action&quot;. Se application.baseUri for definida como
      &quot;/prefix&quot;, apenas &quot;/controller/action&quot; será considerado PATH_INFO no
      processo de roteamento.
     </p>
     <p class="para">
      Em geral, não há necessidade de definir este valor.
     </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">
       Se definido para On, Yaf lançará uma exceção caso algum erro ocorrer.
       Consulte também <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">
      Se definido para On, Yaf encaminhará para controlador de erro ou ação enquanto
      houver uma exceção não manipulada. Consulte também
      <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">
      A rota padrão, se não especificada, a rota estática será usada
      como padrão. Consulte:
      <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">
      O nome do módulo padrão, consulte também
      <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">
      O nome do controlador padrão, consulte também
      <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">
      O nome da ação padrão, consulte também
      <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">
      Define configuração yaf em tempo de execução no application.ini, como:
      <a href="yaf.configuration.php#ini.yaf.lowcase-path" class="link">application.system.lowcase_path</a>.
      <blockquote class="note"><p><strong class="note">Nota</strong>: 
       <p class="para">
        Somente as configurações <strong><code><a href="info.constants.php#constant.ini-all">INI_ALL</a></code></strong> podem ser definidas desta forma.
       </p>
      </p></blockquote>
     </p>
    </dd>
   

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