runkit_method_redefine
(PECL runkit:0.7-0.9)
runkit_method_redefine — Dynamically changes the code of the given method
Descrizione
Nota: Questa funzione non può essere usata per manipolare il metodo attualmente in esecuzione (o concatenato).
Questa funzione è SPERIMENTALE. Ovvero, il comportamento di questa funzione, il nome di questa funzione, in definitiva tutto ciò che è documentato qui può cambiare nei futuri rilasci del PHP senza preavviso. Siete avvisati, l'uso di questa funzione è a vostro rischio.
Elenco dei parametri
- 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 methodname is called
- flags
-
The redefined method can be RUNKIT_ACC_PUBLIC, RUNKIT_ACC_PROTECTED or RUNKIT_ACC_PRIVATE
Nota: This parameter is only used as of PHP 5, because, prior to this, all methods were public.
Valori restituiti
Restituisce TRUE in caso di successo, FALSE in caso di fallimento.
Esempi
Example#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();
?>
Il precedente esempio visualizzerà :
Before: foo! After: bar!