Библиотека для создания оберток (декораторов) над классами.
Декоратор повторяет публичный интерфейс класса (экспортные методы и поля), делегируя вызов вложенному реальному объекту.
Возможности:
- создание декоратора с идентичным интерфейсом;
- синхронизация значений полей декоратора и реального объекта;
- добавление методов, импортов, полей, шагов инициализации в runtime;
- добавление перехватчиков ("перед", "после") вызова метода;
- поддержка вложенных декораторов.
docs - todo;
#Использовать decorator
КакойТоКласс = Новый КакойТоКласс();
КакойТоКласс.Поле = 123;
ИмяМетода = "ДобавленнаяФункция";
ТекстМетода = "Возврат Поле + 1;";
Декоратор = Новый КонструкторДекоратора(КакойТоКласс)
.ДобавитьИмпортПоИмени("fs")
.ДобавитьПубличноеПоле("НовоеПоле", "ЗначениеПоУмолчанию")
.ДобавитьМетод(ИмяМетода, ТекстМетода)
.ДобавитьПередВызовомМетода("ДобавленнаяФункция", "Сообщить(""Привет, мир!"");")
.Построить();
Ожидаем.Что(Декоратор.Поле).Равно(123);
Ожидаем.Что(Декоратор.РоднаяФункцияВозвращающаяИстина()).ЭтоИстина();
Ожидаем.Что(Декоратор.ДобавленнаяФункция()).Равно(124);
// Конструктор
//
// Параметры:
// Объект - Произвольный - Инстанс объекта, над которым нужно создать декоратор.
//
Процедура ПриСозданииОбъекта(Объект)
// Добавляет в декоратор новое приватное поле.
//
// Параметры:
// ИмяПоля - Строка - Имя добавляемого поля
// ЗначениеПоля - Произвольный - Значение, которым необходимо проинициализировать добавляемое поле.
// Если не задано, поле не инициализируется и содержит Неопределено.
//
// Возвращаемое значение:
// КонструкторДекоратора - Ссылка на текущий инстанс КонструкторДекоратора
//
Функция ДобавитьПриватноеПоле(ИмяПоля, ЗначениеПоля = Неопределено)
// Добавляет в декоратор новое публичное (экспортное) поле.
//
// Параметры:
// ИмяПоля - Строка - Имя добавляемого поля
// ЗначениеПоля - Произвольный - Значение, которым необходимо проинициализировать добавляемое поле.
// Если не задано, поле не инициализируется и содержит Неопределено.
//
// Возвращаемое значение:
// КонструкторДекоратора - Ссылка на текущий инстанс КонструкторДекоратора
//
Функция ДобавитьПубличноеПоле(ИмяПоля, ЗначениеПоля = Неопределено)
// Добавляет в декоратор новый публичный (экспортный) метод.
//
// Параметры:
// ИмяМетода - Строка - Имя добавляемого метода.
// ТекстМетода - Строка - Текст добавляемого метода. Допустимо использование многострочной строки.
//
// Возвращаемое значение:
// КонструкторДекоратора - Ссылка на текущий инстанс КонструкторДекоратора
//
Функция ДобавитьМетод(ИмяМетода, ТекстМетода)
// Добавляет в декоратор перехватчик, срабатывающий перед вызовом указанного метода.
//
// Параметры:
// ИмяМетода - Строка - Имя перехватываемого метода.
// ТекстПерехватчика - Текст - Текст добавляемого перехватчика. Допустимо использование многострочной строки.
//
// Возвращаемое значение:
// КонструкторДекоратора - Ссылка на текущий инстанс КонструкторДекоратора
//
Функция ДобавитьПередВызовомМетода(ИмяМетода, ТекстПерехватчика)
// Добавляет в декоратор перехватчик, срабатывающий после вызова указанного метода.
//
// Параметры:
// ИмяМетода - Строка - Имя перехватываемого метода.
// ТекстПерехватчика - Текст - Текст добавляемого перехватчика. Допустимо использование многострочной строки.
//
// Возвращаемое значение:
// КонструкторДекоратора - Ссылка на текущий инстанс КонструкторДекоратора
//
Функция ДобавитьПослеВызоваМетода(ИмяМетода, ТекстПерехватчика)
// Добавляет в декоратор импорт библиотеки (#Использовать) по имени библиотеки.
//
// Параметры:
// ИмяБиблиотеки - Строка - Имя библиотеки.
//
// Возвращаемое значение:
// КонструкторДекоратора - Ссылка на текущий инстанс КонструкторДекоратора
//
Функция ДобавитьИмпортПоИмени(ИмяБиблиотеки)
// Добавляет в декоратор импорт библиотеки (#Использовать) по пути к библиотеке.
//
// Параметры:
// ПутьКБиблиотеке - Строка - Путь к библиотеке. Можно использовать как абсолютный, так и относительный путь.
//
// Возвращаемое значение:
// КонструкторДекоратора - Ссылка на текущий инстанс КонструкторДекоратора
//
Функция ДобавитьИмпортПоПути(ПутьКБиблиотеке)
// Добавляет в декоратор шаг инициализации в тело модуля.
//
// Параметры:
// ТекстШага - Строка - Выполняемый код.
//
// Возвращаемое значение:
// КонструкторДекоратора - Ссылка на текущий инстанс КонструкторДекоратора
//
Функция ДобавитьШагИнициализации(ТекстШага)
// Получить сконструированный текст сценария будущего декоратора
//
// Возвращаемое значение:
// Строка - Текст сценария декоратора
//
Функция ТекстСценария()
// Сконструировать готовый декоратор по настройкам конструктора декоратора.
//
// Параметры:
// ТекстСценария - Строка - Текст сценария декоратора. Если не задан, формируется автоматически.
//
// Возвращаемое значение:
// Произвольный - Декортатор над объектом, переданным в конструктор декоратора
//
Функция Построить(ТекстСценария = Неопределено)
// Получает тип объекта, вокруг которого построен декоратор (рекурсивно).
//
// Параметры:
// Декоратор - Произвольный - Объект, у которого нужно найти исходный тип объекта
//
// Возвращаемое значение:
// Тип - Исходный тип объекта
//
Функция ИсходныйТип(Декоратор)
// Синхронизировать значения экспортных полей двух объектов.
//
// Параметры:
// ИсходныйОбъект - Произвольный - Источник значений свойств
// Потребитель - Произвольный - Получатель значений свойств
//
Процедура СинхронизироватьПоля(ИсходныйОбъект, Потребитель)
// Имя поля, в котором хранится ссылка на исходный объект.
Перем Поле_ИнстансОбъекта Экспорт;