<?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 => 'fr',
  ),
  'this' => 
  array (
    0 => 'yaf.appconfig.php',
    1 => 'Application Configuration',
    2 => 'Application Configuration',
  ),
  'up' => 
  array (
    0 => 'book.yaf.php',
    1 => 'Yaf',
  ),
  'prev' => 
  array (
    0 => 'yaf.tutorials.php',
    1 => 'Exemples',
  ),
  'next' => 
  array (
    0 => 'class.yaf-application.php',
    1 => 'Yaf_Application',
  ),
  'alternatives' => 
  array (
  ),
  'source' => 
  array (
    'lang' => 'fr',
    '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">Application Configuration</h1>

 <p class="para">
  Il faut fournir un tableau de configuration, ou un fichier
  au format ini de configuration (voir le chemin
  <span class="classname"><a href="class.yaf-config-ini.php" class="classname">Yaf_Config_Ini</a></span>) de la méthode
  <span class="methodname"><a href="yaf-application.construct.php" class="methodname">Yaf_Application::__construct()</a></span>. 
 </p>
 <p class="para">
  Yaf va fusionner automatiquement les configurations de l&#039;application et
  celles de l&#039;utilisateur. Les configurations d&#039;application sont préfixées
  par &quot;yaf.&quot; ou par &quot;application.&quot;. Si à la fois &quot;yaf.&quot; et &quot;application.&quot; existent,
  &quot;application.&quot; prendra l&#039;avantage.
  <div class="example" id="example-1">
   <p><strong>Exemple #1 Exemple avec un tableau 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>Exemple #2 Exemple avec un fichier 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]
; la configuration utilisateur va ici</pre>
</div>
   </div>

  </div>
  </p>
  <p class="para">
  <table class="doctable table">
   <caption><strong>Configuration d&#039;application Yaf</strong></caption>
   
    <thead>
     <tr>
      <th>Nom</th>
      <th>Défaut</th>
      <th>Historique</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">Voici un éclaircissement sur
l&#039;utilisation des directives de configuration.</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">
       Le dossier de l&#039;application ; il contient les dossiers
       &quot;controllers&quot;, &quot;views&quot;, &quot;models&quot; et &quot;plugins&quot;.
      </p>
      <p class="para">
       <blockquote class="note"><p><strong class="note">Note</strong>: 
        <p class="para">
         Cette entrée de configuration est la seule qui n&#039;a pas de valeur
         par défaut. Il faut toujours la définir manuellement.
        </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">
       L&#039;extension de fichier du script PHP, utilisé dans la classe
       autoloading(<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">
       L&#039;extension du fichier de script du template de visualisation.
      </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">
       Une liste séparée par une virgule de modules enregistrés, utilisés
       dans le processus de routage, et spécialement lorsqu&#039;il y a plus de
       trois segments dans le PATH_INFO
      </p>
      <p class="para">
       Yaf doit avoir un moyen de savoir si le premier segment est un
       nom de module ou pas.
      </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">
       Le dossier local de la bibliothèque, voir
       <span class="classname"><a href="class.yaf-loader.php" class="classname">Yaf_Loader</a></span> et
       <a href="yaf.configuration.php#ini.yaf.library" class="link">yaf.library</a>.
       </p>
       <blockquote class="note"><p><strong class="note">Note</strong>: 
        <p class="para">
         Depuis Yaf 2.1.6, cette entrée de configuration peut être un tableau.
         Le chemin de la bibliothèque tente d&#039;utiliser la valeur de <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">
       Alias de <a href="yaf.appconfig.php#configuration.yaf.library" class="link">application.library</a>.
       Introduit en 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">
       Préfixes séparés par une virgule d&#039;espace de noms locaux de
       la bibliothèque.
      </p>
      <p class="para">
       Introduit en 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">
       Un chemin absolu du script de la 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">
       Utilisé pour supprimer un préfixe fixé d&#039;une URI de requête
       dans le processus de routage. Par exemple, une requête
       dont l&#039;URI est &quot;/prefix/controller/action&quot;. Si on définit
       application.baseUri à &quot;/prefix&quot;, alors seul &quot;/controller/action&quot;
       sera pris comme PATH_INFO dans le processus de routage.
      </p>
      <p class="para">
       En général, il n&#039;est pas nécessaire de définir cette valeur.
      </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">
       Si vaut On, Yaf lance une exception lorsqu&#039;une erreur surviendra.
       Voir aussi la méthode <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">
       Si vaut On, Yaf transmettra les erreurs aux contrôleurs/actions,
       lorsqu&#039;il rencontrera une exception non attrapable.
       Voir aussi la méthode <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">
       La route par défaut, si elle n&#039;est pas spécifiée, la route statique
       sera utilisée. Voir la méthode <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">
       Le nom de module par défaut. Voir aussi la méthode
       <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">
       Le nom par défaut du contrôleur. Voir aussi la méthode
       <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">
       Le nom par défaut de l&#039;action. Voir aussi la méthode
       <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">
       Définit une configuration Yaf au moment de l&#039;exécution dans
       application.ini, comme ceci :
       <a href="yaf.configuration.php#ini.yaf.lowcase-path" class="link">application.system.lowcase_path</a>
       <blockquote class="note"><p><strong class="note">Note</strong>: 
        <p class="para">
         seules les options de configuration <strong><code>INI_ALL</code></strong> peuvent
         être définies de cette façon.
       </p>
       </p></blockquote>
      </p>
     </dd>
    

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