(PHP 4, PHP 5, PHP 7, PHP 8)
assert_options — 様々な assert フラグを設定/取得する
種々の assert() 制御オプションを設定したり、 単に現在の設定を調べたりします。
注意: PHP 7.0.0 以降では、 assert_options() を使うことはお勧めできません。 php.ini のディレクティブ zend.assertions と assert.exception を ini_set() や ini_get() で取得したり設定したりする方が望ましいです。
what
オプション | INI 設定 | デフォルト値 | 説明 |
---|---|---|---|
ASSERT_ACTIVE | assert.active | 1 | assert() による評価を有効にする |
ASSERT_WARNING | assert.warning | 1 | assersion に失敗した場合に PHP 警告を発生する |
ASSERT_BAIL | assert.bail | 0 | assersion に失敗した場合に実行を終了する |
ASSERT_QUIET_EVAL | assert.quiet_eval | 0 | assersion 式については error_reporting を無効にする |
ASSERT_CALLBACK | assert.callback | (null ) |
assertion に失敗した場合にコールされるコールバック |
value
オプションに指定する新しい値。
ASSERT_CALLBACK
定数または assert.callback
に設定するコールバック関数は、次のようなシグネチャを持つべきです:
$file
,$line
,$assertion
,$description
= ?value
に空文字列を渡すと、assertコールバックはリセットされます。
そのオプションの元の値、あるいはエラー時に false
を返します。
例1 assert_options() の例
<?php
// これは、assert に失敗した際の
// 処理を行う関数です
function assert_failure($file, $line, $assertion, $message)
{
echo "The assertion $assertion in $file on line $line has failed: $message";
}
// これがテスト関数です
function test_assert($parameter)
{
assert(is_bool($parameter));
}
// assert オプションを設定します
assert_options(ASSERT_ACTIVE, true);
assert_options(ASSERT_BAIL, true);
assert_options(ASSERT_WARNING, false);
assert_options(ASSERT_CALLBACK, 'assert_failure');
// 失敗する assert です
test_assert(1);
// ASSERT_BAIL が true なので
// 決してここには到達しません
echo 'Never reached';
?>