runkit_method_add
(PECL runkit >= 0.7.0)
runkit_method_add — Динамически добавляет новый метод в класс
Описание
$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 -
Класс, в который будет добавлен метод
-
methodname -
Имя добавляемого метода
-
args -
Список параметров, принимаемых методом, через запятую
-
code -
Код нового метода, который будет выполняться при вызове
methodname -
closure -
Функция определяющая замыкание (closure).
-
flags -
Создаваемый метод может быть
RUNKIT_ACC_PUBLIC,RUNKIT_ACC_PROTECTEDилиRUNKIT_ACC_PRIVATEопционально в комбинации через побитовое ИЛИ сRUNKIT_ACC_STATIC(начиная с версии 1.0.1) -
doc_comment -
Документирующий комментарий к функции.
Возвращаемые значения
Возвращает TRUE в случае успешного завершения или FALSE в случае возникновения ошибки.
Список изменений
| Версия | Описание |
|---|---|
| runkit 1.0.4 |
Добавлен альтернативный синтаксис с использованием замыканий (closure).
|
| runkit 1.0.4 |
Был добавлен необязательный параметр doc_comment.
|
Примеры
Пример #1 Пример runkit_method_add()
<?php
class Example {
function foo() {
echo "foo!\n";
}
}
// создаем экземпляр Example
$e = new Example();
// добавляем новый публичный метод
runkit_method_add(
'Example',
'add',
'$num1, $num2',
'return $num1 + $num2;',
RUNKIT_ACC_PUBLIC
);
// вычисляем 12 + 4
echo $e->add(12, 4);
?>
Результат выполнения данного примера:
16
Смотрите также
- runkit_method_copy() - Копирование метода из одного класса в другой
- runkit_method_redefine() - Изменяет код выбранного метода
- runkit_method_remove() - Динамически удаляет выбранный метод
- runkit_method_rename() - Переименовывает выбранный метод
- runkit_function_add() - Добавляет новую функцию аналогично create_function