2025-08-07 08:28:23 +03:00
|
|
|
|
/// Абстракция для DI-адаптера с использованием функций регистрации.
|
2025-08-06 23:15:28 +03:00
|
|
|
|
///
|
2025-08-07 08:28:23 +03:00
|
|
|
|
/// Позволяет использовать любые DI-контейнеры: и модульные, и безмодульные.
|
2025-08-06 16:21:31 +03:00
|
|
|
|
abstract class DIAdapter {
|
2025-08-07 08:28:23 +03:00
|
|
|
|
/// Устанавливает зависимости с помощью одной функции регистрации.
|
|
|
|
|
|
///
|
|
|
|
|
|
/// Функция принимает выбранный DI-контейнер, задаваемый реализацией.
|
|
|
|
|
|
void setupDependencies(void Function(dynamic container) registration);
|
2025-08-06 23:15:28 +03:00
|
|
|
|
|
2025-08-07 08:28:23 +03:00
|
|
|
|
/// Резолвит (возвращает) экземпляр типа [T] (по имени, если требуется).
|
2025-08-07 09:15:26 +03:00
|
|
|
|
T resolve<T extends Object>({String? named});
|
2025-08-06 23:15:28 +03:00
|
|
|
|
|
2025-08-07 08:28:23 +03:00
|
|
|
|
/// Асинхронно резолвит экземпляр типа [T].
|
2025-08-07 09:15:26 +03:00
|
|
|
|
Future<T> resolveAsync<T extends Object>({String? named});
|
2025-08-06 23:15:28 +03:00
|
|
|
|
|
2025-08-07 08:28:23 +03:00
|
|
|
|
/// Уничтожает/отчищает DI-контейнер.
|
2025-08-06 16:21:31 +03:00
|
|
|
|
void teardown();
|
2025-08-06 23:15:28 +03:00
|
|
|
|
|
2025-08-07 08:28:23 +03:00
|
|
|
|
/// Открывает дочерний под-scope (если применимо).
|
2025-08-06 16:21:31 +03:00
|
|
|
|
DIAdapter openSubScope(String name);
|
2025-08-07 09:15:26 +03:00
|
|
|
|
|
|
|
|
|
|
/// Ожидание готовности DI контейнера (нужно для async DI, например get_it)
|
|
|
|
|
|
Future<void> waitForAsyncReady();
|
2025-08-06 16:21:31 +03:00
|
|
|
|
}
|