Zend_Translate-Migration.xml 3.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- Reviewed: no -->
  3. <!-- EN-Revision: 15617 -->
  4. <sect1 id="zend.translate.migration">
  5. <title>以前のバージョンからの移行</title>
  6. <para>
  7. <classname>Zend_Translate</classname> の API は日々変わっています。
  8. <classname>Zend_Translate</classname> やそのサブコンポーネントを
  9. 初期のバージョンから使っている方は、以下のガイドラインに従ってスクリプトを変更し、
  10. 新しい API にあわせましょう。
  11. </para>
  12. <sect2 id="zend.translate.migration.fromonesixtooneseven">
  13. <title>1.6 から 1.7 以降への移行</title>
  14. <sect3 id="zend.translate.migration.fromonesixtooneseven.languages">
  15. <title>言語の設定</title>
  16. <para>
  17. 言語の自動検出を使用したり <classname>Zend_Translate</classname> に手動で言語を設定したりする際に、
  18. 「追加に失敗」や「翻訳がない」などの理由で notice が発行されることがありました。
  19. 以前のリリースでは、場合によっては例外が発生することもありました。
  20. </para>
  21. <para>
  22. その原因は、存在しない言語をユーザが指定した際に
  23. 何が問題なのかを知る簡単な方法がなかったことにあります。
  24. そこで私たちは notice を発行させるようにしていたのです。
  25. ログに記録が残るので、サポートしていない言語がリクエストされたことがわかるようになります。
  26. そしてたとえ notice が発行されたとしても、コード自体は問題なく動作します。
  27. </para>
  28. <para>
  29. しかし、xdebug のような独自のエラーハンドラ/例外ハンドラを使った場合など、
  30. 意図せぬものも含めてすべての notice を拾ってしまうこともあります。
  31. そういった独自のハンドラは PHP の設定を上書きしてしまうことがあるからです。
  32. </para>
  33. <para>
  34. これらの notice を発生させないようにするためには、新たなオプション
  35. 'disableNotices' を true に設定するだけです。デフォルトは false となっています。
  36. </para>
  37. <example id="zend.translate.migration.fromonesixtooneseven.example">
  38. <title>notice を取得せずに言語の設定を行う</title>
  39. <para>
  40. ここでは、'en' に対応しているところにユーザから
  41. 'fr' がリクエストされたものと家庭します。この翻訳は登録されていません。
  42. </para>
  43. <programlisting language="php"><![CDATA[
  44. $language = new Zend_Translate('gettext',
  45. '/path/to/translations',
  46. 'auto');
  47. ]]></programlisting>
  48. <para>
  49. この場合、存在しない言語 'fr' が指定されたことに関する notice が発行されます。
  50. オプションを追加すると、この notice は発生しなくなります。
  51. </para>
  52. <programlisting language="php"><![CDATA[
  53. $language = new Zend_Translate('gettext',
  54. '/path/to/translations',
  55. 'auto',
  56. array('disableNotices' => true));
  57. ]]></programlisting>
  58. </example>
  59. </sect3>
  60. </sect2>
  61. </sect1>