Zend_Config_Writer.xml 6.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- Reviewed: no -->
  3. <!-- EN-Revision: 19691 -->
  4. <sect1 id="zend.config.writer.introduction">
  5. <title>Zend_Config_Writer</title>
  6. <para>
  7. <classname>Zend_Config_Writer</classname> は、設定ファイルに
  8. <classname>Zend_Config</classname> オブジェクトを書き出します。
  9. アダプタなしでも動作するので、使用するのも簡単です。
  10. デフォルトでは <classname>Zend_Config_Writer</classname>
  11. には 3 種類のアダプタが同梱されており、全てファイル・ベースです。
  12. まず、<emphasis>filename</emphasis> や <emphasis>config</emphasis>
  13. のオプションを指定してライターのインスタンスを作成します。
  14. それからライターの <methodname>write()</methodname> メソッドをコールすると、
  15. 設定ファイルが作成されます。<varname>$filename</varname> や
  16. <varname>$config</varname> を、直接 <methodname>write()</methodname>
  17. メソッドで設定することもできます。現在は、次のライターが
  18. <classname>Zend_Config_Writer</classname> に同梱されています。
  19. </para>
  20. <itemizedlist>
  21. <listitem>
  22. <para>
  23. <classname>Zend_Config_Writer_Array</classname>
  24. </para>
  25. </listitem>
  26. <listitem>
  27. <para>
  28. <classname>Zend_Config_Writer_Ini</classname>
  29. </para>
  30. </listitem>
  31. <listitem>
  32. <para>
  33. <classname>Zend_Config_Writer_Xml</classname>
  34. </para>
  35. </listitem>
  36. </itemizedlist>
  37. <para>
  38. <acronym>INI</acronym> ライターでは、セクションについてのレンダリング用のモードが2つあります。
  39. 既定では、トップレベルの構成節は、常にセクション名に含まれます。
  40. <command>$writer->setRenderWithoutSections()</command> を呼ぶことにより、
  41. オプションの全てが <acronym>INI</acronym> ファイルのグローバル名前空間に含まれます。
  42. そして、セクションは使用されません。
  43. </para>
  44. <para>
  45. 加えて、<classname>Zend_Config_Writer_Ini</classname> にはオプションのパラメータ
  46. <emphasis>nestSeparator</emphasis> が用意されています。
  47. これは、ノードを区切る文字を定義します。デフォルトはドットひとつで、
  48. これは <classname>Zend_Config_Ini</classname> のデフォルトと同じです。
  49. </para>
  50. <para>
  51. <classname>Zend_Config</classname> オブジェクトを変更したり作成したりする際には、
  52. 知っておくべきことがあります。値を作成したり変更したりするには、
  53. パラメータのアクセサ (<emphasis>-&gt;</emphasis>) で <classname>Zend_Config</classname>
  54. オブジェクトのパラメータを設定します。
  55. ルート内のセクションやブランチを作成するには、新規配列を作成します
  56. ("<command>$config-&gt;branch = array();</command>")。
  57. セクションの継承関係を定義するには、ルート
  58. <classname>Zend_Config</classname> オブジェクトの
  59. <methodname>setExtend()</methodname> メソッドをコールします。
  60. </para>
  61. <example id="zend.config.writer.example.using">
  62. <title>Zend_Config_Writer の使用法</title>
  63. <para>
  64. この例では、<classname>Zend_Config_Writer_Xml</classname>
  65. で新しい設定ファイルを作成する方法を説明します。
  66. </para>
  67. <programlisting language="php"><![CDATA[
  68. // config オブジェクトを作成します
  69. $config = new Zend_Config(array(), true);
  70. $config->production = array();
  71. $config->staging = array();
  72. $config->setExtend('staging', 'production');
  73. $config->production->db = array();
  74. $config->production->db->hostname = 'localhost';
  75. $config->production->db->username = 'production';
  76. $config->staging->db = array();
  77. $config->staging->db->username = 'staging';
  78. // 次のいずれかの方法で設定ファイルを書き出します
  79. // a)
  80. $writer = new Zend_Config_Writer_Xml(array('config' => $config,
  81. 'filename' => 'config.xml'));
  82. $writer->write();
  83. // b)
  84. $writer = new Zend_Config_Writer_Xml();
  85. $writer->setConfig($config)
  86. ->setFilename('config.xml')
  87. ->write();
  88. // c)
  89. $writer = new Zend_Config_Writer_Xml();
  90. $writer->write('config.xml', $config);
  91. ]]></programlisting>
  92. <para>
  93. これは、production と staging というセクションを持つ <acronym>XML</acronym>
  94. 設定ファイルを作成します。staging は production を継承しています。
  95. </para>
  96. </example>
  97. <example id="zend.config.writer.modifying">
  98. <title>既存の設定の変更</title>
  99. <para>
  100. この例では、既存の設定ファイルを編集する方法を説明します。
  101. </para>
  102. <programlisting language="php"><![CDATA[
  103. // すべてのセクションを既存の設定ファイルから読み込みますが継承は読み飛ばします
  104. $config = new Zend_Config_Ini('config.ini',
  105. null,
  106. array('skipExtends' => true,
  107. 'allowModifications' => true));
  108. // 値を変更します
  109. $config->production->hostname = 'foobar';
  110. // 設定ファイルを書き出します
  111. $writer = new Zend_Config_Writer_Ini(array('config' => $config,
  112. 'filename' => 'config.ini'));
  113. $writer->write();
  114. ]]></programlisting>
  115. </example>
  116. <note>
  117. <title>設定ファイルの読み込み</title>
  118. <para>
  119. 既存の設定ファイルを読み込んで変更をする場合は、
  120. すべてのセクションを読み込んで継承を読み飛ばすことが大切です。
  121. そうすることで、値がマージされてしまうことがなくなります。
  122. そのために、コンストラクタで
  123. <emphasis>skipExtends</emphasis> オプションを指定します。
  124. </para>
  125. </note>
  126. <para>
  127. 構成節の文字列を作成するために、ファイル・ベースのライタ
  128. ( <acronym>INI</acronym> 、 <acronym>XML</acronym> 及び <acronym>PHP</acronym> 配列)
  129. 全てで内部的に <methodname>render()</methodname> が使用されます。
  130. コンフィギュレーション・データの文字列表現にアクセスする必要があれば、
  131. このメソッドを外部からも使用できます。
  132. </para>
  133. </sect1>
  134. <!--
  135. vim:se ts=4 sw=4 et:
  136. -->