Programmer's Reference Guide

翻訳アダプタの使用法

以前のバージョンからの移行

Zend_Translate の API は日々変わっています。 Zend_Translate やそのサブコンポーネントを 初期のバージョンから使っている方は、以下のガイドラインに従ってスクリプトを変更し、 新しい API にあわせましょう。

1.6 から 1.7 以降への移行

言語の設定

言語の自動検出を使用したり Zend_Translate に手動で言語を設定したりする際に、 「追加に失敗」や「翻訳がない」などの理由で notice が発行されることがありました。 以前のリリースでは、場合によっては例外が発生することもありました。

その原因は、存在しない言語をユーザが指定した際に 何が問題なのかを知る簡単な方法がなかったことにあります。 そこで私たちは notice を発行させるようにしていたのです。 ログに記録が残るので、サポートしていない言語がリクエストされたことがわかるようになります。 そしてたとえ notice が発行されたとしても、コード自体は問題なく動作します。

しかし、xdebug のような独自のエラーハンドラ/例外ハンドラを使った場合など、 意図せぬものも含めてすべての notice を拾ってしまうこともあります。 そういった独自のハンドラは PHP の設定を上書きしてしまうことがあるからです。

これらの notice を発生させないようにするためには、新たなオプション 'disableNotices' を true に設定するだけです。デフォルトは false となっています。

例1 notice を取得せずに言語の設定を行う

ここでは、'en' に対応しているところにユーザから 'fr' がリクエストされたものと家庭します。この翻訳は登録されていません。

$language = new Zend_Translate('gettext',
                               '/path/to/translations',
                               'auto');

                

この場合、存在しない言語 'fr' が指定されたことに関する notice が発行されます。 オプションを追加すると、この notice は発生しなくなります。

$language = new Zend_Translate('gettext',
                               '/path/to/translations',
                               'auto',
                               array('disableNotices' => true));

                

翻訳アダプタの使用法
blog comments powered by Disqus

Select a Version

Languages Available

Components

Search the Manual