(PECL runkit >= 0.7.0)
runkit_method_redefine — Change dynamiquement le code de la méthode donnée
$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
]] ) : boolNote: Cette fonction ne peut être utilisée pour manipuler la méthode en cours d'utilisation (ou chaînée).
classnameLa classe dans laquelle la méthode sera redéfinie
methodnameLe nom de la méthode à redéfinir
argsListe d'arguments séparés par des virgules pour la méthode redéfinie
code
Le nouveau code qui sera évalué lorsque
methodname sera appelée
closureUne closure qui définit la fonction.
flags
La méthode redéfinie peut etre
RUNKIT_ACC_PUBLIC,
RUNKIT_ACC_PROTECTED ou
RUNKIT_ACC_PRIVATE optionnellement combiné
via un OR avec RUNKIT_ACC_STATIC (depuis la version 1.0.1)
doc_commentLe commentaire de documentation de la fonction.
Cette fonction retourne TRUE en cas de succès ou FALSE si une erreur survient.
| Version | Description |
|---|---|
| runkit 1.0.4 |
Une syntaxe alternative s'attendant a une closure a été ajouté.
|
| runkit 1.0.4 |
Le paramètre optionel doc_comment a été ajouté.
|
Exemple #1 Exemple avec runkit_method_redefine()
<?php
class Example {
function foo() {
return "foo!\n";
}
}
// Crée un objet Example
$e = new Example();
// Sortie Example::foo() (avant la redéfinition)
echo "Avant : " . $e->foo();
// Redéfinition de la méthode 'foo'
runkit_method_redefine(
'Example',
'foo',
'',
'return "bar!\n";',
RUNKIT_ACC_PUBLIC
);
// Sortie Example::foo() (après la redéfinition)
echo "Après : " . $e->foo();
?>
L'exemple ci-dessus va afficher :
Avant : foo! Après : bar!