array ( 0 => 'index.php', 1 => 'PHP Manual', ), 'head' => array ( 0 => 'UTF-8', 1 => 'fr', ), 'this' => array ( 0 => 'function.runkit7-method-redefine.php', 1 => 'runkit7_method_redefine', ), 'up' => array ( 0 => 'ref.runkit7.php', 1 => 'runkit7 Fonctions', ), 'prev' => array ( 0 => 'function.runkit7-method-copy.php', 1 => 'runkit7_method_copy', ), 'next' => array ( 0 => 'function.runkit7-method-remove.php', 1 => 'runkit7_method_remove', ), 'alternatives' => array ( ), 'source' => array ( 'lang' => 'en', 'path' => 'reference/runkit7/functions/runkit7-method-redefine.xml', ), ); $setup["toc"] = $TOC; $setup["toc_deprecated"] = $TOC_DEPRECATED; $setup["parents"] = $PARENTS; manual_setup($setup); ?>
(PECL runkit7 >= Unknown)
runkit7_method_redefine — Dynamically changes the code of the given method
class_name
The class in which to redefine the method
method_name
The name of the method to redefine
argument_list
Comma-delimited list of arguments for the redefined method
code
The new code to be evaluated when method_name
is called
closure
A closure that defines the method.
flags
The redefined method can be
RUNKIT7_ACC_PUBLIC
,
RUNKIT7_ACC_PROTECTED
or
RUNKIT7_ACC_PRIVATE
optionally combined via bitwise OR with
RUNKIT7_ACC_STATIC
doc_comment
The doc comment of the method.
return_type
The return type of the method.
is_strict
Whether the method behaves as if it was declared in a file with strict_types=1
.
Exemple #1 runkit7_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
runkit7_method_redefine(
'Example',
'foo',
'',
'return "bar!\n";',
RUNKIT7_ACC_PUBLIC
);
// output Example::foo() (after redefine)
echo "After: " . $e->foo();
?>
L'exemple ci-dessus va afficher :
Before: foo! After: bar!