Configuração topic
Configuração
Este módulo contém as classes responsáveis por controlar o comportamento do sistema de logging.
ConfigLog
Classe de configuração central do sistema de logging. Define quais logs devem ser processados e quais devem ser ignorados.
class ConfigLog {
final bool enableLog;
final Set<Type> onlyClasses;
}
Parâmetros
| Campo | Tipo | Padrão | Descrição |
|---|---|---|---|
enableLog |
bool |
false |
Habilita ou desabilita o processamento de logs globalmente |
onlyClasses |
Set<Type> |
{DebugLog, WarningLog, InfoLog} |
Conjunto de tipos de log permitidos |
Comportamento
- Quando
enableLogéfalse, todos os logs são ignorados excetoErrorLog, que possuialwaysPrint = truee sempre é processado. onlyClassesfiltra logs por tipo: apenas objetos cujoruntimeTypeesteja no conjunto serão processados.ErrorLognão precisa ser incluído emonlyClassespara ser processado — ele sempre passa.
Exemplos de uso
Configuração padrão (logs desabilitados):
final config = ConfigLog();
// enableLog: false, onlyClasses: {DebugLog, WarningLog, InfoLog}
Habilitar todos os logs em desenvolvimento:
final config = ConfigLog(enableLog: true);
Filtrar apenas erros e warnings:
final config = ConfigLog(
enableLog: true,
onlyClasses: {ErrorLog, WarningLog},
);
Produção — logs desabilitados, apenas erros críticos são sempre registrados:
final config = ConfigLog(enableLog: false);
// ErrorLog ainda é processado por ter alwaysPrint = true
Integração com registro da impressora:
void main() {
registerLogPrinterColor(
config: ConfigLog(
enableLog: true,
onlyClasses: {DebugLog, ErrorLog},
),
);
runApp(MyApp());
}
Classes
- ConfigLog Configuração
- Configuração para controle de logs na biblioteca.