runkit_method_redefine
(PECL runkit >= 0.7.0)
runkit_method_redefine — Dynamically changes the code of the given method
説明
$classname
, string $methodname
, string $args
, string $code
[, int $flags = RUNKIT_ACC_PUBLIC
[, string $doc_comment = NULL
]] ) : bool$classname
, string $methodname
, Closure $closure
[, int $flags = RUNKIT_ACC_PUBLIC
[, string $doc_comment = NULL
]] ) : bool注意: この関数は、 現在実行中(もしくはチェーンド)のメソッドを操作することはできません。
パラメータ
-
classname -
The class in which to redefine the method
-
methodname -
The name of the method to redefine
-
args -
Comma-delimited list of arguments for the redefined method
-
code -
The new code to be evaluated when
methodnameis called -
closure -
A closure that defines the method.
-
flags -
The redefined method can be
RUNKIT_ACC_PUBLIC,RUNKIT_ACC_PROTECTEDorRUNKIT_ACC_PRIVATEoptionally combined via bitwise OR withRUNKIT_ACC_STATIC(since 1.0.1) -
doc_comment -
The doc comment of the function.
返り値
成功した場合に TRUE を、失敗した場合に FALSE を返します。
変更履歴
| バージョン | 説明 |
|---|---|
| runkit 1.0.4 |
An alternative syntax expecting a closure has been added.
|
| runkit 1.0.4 |
The optional parameter doc_comment has been added.
|
例
例1 runkit_method_redefine() example
<?php
class Example {
function foo() {
return "foo!\n";
}
}
// create an Example object
$e = new Example();
// output Example::foo() (before redefine)
echo "Before: " . $e->foo();
// Redefine the 'foo' method
runkit_method_redefine(
'Example',
'foo',
'',
'return "bar!\n";',
RUNKIT_ACC_PUBLIC
);
// output Example::foo() (after redefine)
echo "After: " . $e->foo();
?>
上の例の出力は以下となります。
Before: foo! After: bar!
参考
- runkit_method_add() - Dynamically adds a new method to a given class
- runkit_method_copy() - あるクラスのメソッドを別のクラスにコピーする
- runkit_method_remove() - 指定したメソッドを動的に削除する
- runkit_method_rename() - 指定したメソッドの名前を動的に変更する
- runkit_function_redefine() - Replace a function definition with a new implementation