Zend_Locale-Migration.xml 5.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- Reviewed: no -->
  3. <!-- EN-Revision: 15156 -->
  4. <sect1 id="zend.locale.migration">
  5. <title>以前のバージョンからの移行</title>
  6. <para>
  7. <classname>Zend_Locale</classname> の API は日々変わっています。
  8. <classname>Zend_Locale</classname> やそのサブコンポーネントを
  9. 初期のバージョンから使っている方は、以下のガイドラインに従ってスクリプトを変更し、
  10. 新しい API にあわせましょう。
  11. </para>
  12. <sect2 id="zend.locale.migration.fromonesixtooneseven">
  13. <title>1.6 から 1.7 以降への移行</title>
  14. <sect3 id="zend.locale.migration.fromonesixtooneseven.islocale">
  15. <title>isLocale() を使う際の変更点</title>
  16. <para>
  17. コーディング規約に従うと、 isLocale() は boolean
  18. 値を返さなければなりませんでした。
  19. 以前のバージョンでは、成功したばあいに文字列を返していました。
  20. リリース 1.7 では、互換性モードが追加されて文字列を返す古い挙動も使えます。
  21. しかし、このばあいは新しい挙動に変更するようにというユーザ警告が発生します。
  22. 古い挙動の isLocale() が行っていた再ルーティングはもはや不要で、
  23. すべての I18N は自分自身で再ルーティングを行います。
  24. </para>
  25. <para>
  26. あなたのスクリプトを新しい API 用に変更するには、次のようにメソッドを使用します。
  27. </para>
  28. <example id="zend.locale.migration.fromonesixtooneseven.example">
  29. <title>isLocale() を 1.6 用から 1.7 用に変更する方法</title>
  30. <programlisting role="php"><![CDATA[
  31. // 1.6 の例
  32. if ($locale = Zend_Locale::isLocale($locale)) {
  33. // ここで何かします
  34. }
  35. // 1.7 の例
  36. // 互換性モードを変更して警告の発生を防ぐ必要があります
  37. // これは起動ファイルで行うことができます
  38. Zend_Locale::$compatibilityMode = false;
  39. if (Zend_Locale::isLocale($locale)) {
  40. }
  41. ]]></programlisting>
  42. <para>
  43. 2 番目のパラメータを使えば、
  44. そのロケールが正しくて再ルーティングが発生しなかったかどうかがわかることに注意しましょう。
  45. </para>
  46. <programlisting role="php"><![CDATA[
  47. // 1.6 の例
  48. if ($locale = Zend_Locale::isLocale($locale, false)) {
  49. // ここで何かします
  50. }
  51. // 1.7 の例
  52. // 互換性モードを変更して警告の発生を防ぐ必要があります
  53. // これは起動ファイルで行うことができます
  54. Zend_Locale::$compatibilityMode = false;
  55. if (Zend_Locale::isLocale($locale, false)) {
  56. if (Zend_Locale::isLocale($locale, true)) {
  57. // ロケールはありません
  58. }
  59. // もとの文字列はロケールを持ちませんが再ルーティングすることができます
  60. }
  61. ]]></programlisting>
  62. </example>
  63. </sect3>
  64. <sect3 id="zend.locale.migration.fromonesixtooneseven.getdefault">
  65. <title>getDefault() を使用する際の変更</title>
  66. <para>
  67. getDefault() メソッドの意味が変わりました。
  68. フレームワークにロケールが統合され、それを setDefault()
  69. で設定できるようになったからです。
  70. このメソッドはもはやロケールチェインを返すことはなく、
  71. フレームワークのロケールに設定されたものだけを返します。
  72. </para>
  73. <para>
  74. あなたのスクリプトを新しい API 用に変更するには、次のようにメソッドを使用します。
  75. </para>
  76. <example id="zend.locale.migration.fromonesixtooneseven.getdefault.example">
  77. <title>getDefault() を 1.6 用から 1.7 用に変更する方法</title>
  78. <programlisting role="php"><![CDATA[
  79. // 1.6 の例
  80. $locales = $locale->getDefault(Zend_Locale::BROWSER);
  81. // 1.7 の例
  82. // 互換性モードを変更して警告の発生を防ぐ必要があります
  83. // これは起動ファイルで行うことができます
  84. Zend_Locale::$compatibilityMode = false;
  85. $locale = Zend_Locale::getOrder(Zend_Locale::BROWSER);
  86. ]]></programlisting>
  87. <para>
  88. 古い実装における getDefault()
  89. の 2 番目のパラメータはもはや使えないことに注意しましょう。
  90. 返り値がそれと同じ値となります。
  91. </para>
  92. </example>
  93. <note>
  94. <para>
  95. デフォルトでは古い挙動も有効ですが、ユーザ警告が発生します。
  96. 新しい挙動にあわせてコードを変更し終えたら、
  97. 互換性モードを false に変更して警告が発生しないようにしなければなりません。
  98. </para>
  99. </note>
  100. </sect3>
  101. </sect2>
  102. </sect1>