/** * Copyright (c) 2013-2016, The SeedStack authors <http://seedstack.org> * * This Source Code Form is subject to the terms of the Mozilla Public * License, v. 2.0. If a copy of the MPL was not distributed with this * file, You can obtain one at http://mozilla.org/MPL/2.0/. */ package org.seedstack.seed.core.internal.logging; import com.google.inject.TypeLiteral; import com.google.inject.spi.TypeEncounter; import com.google.inject.spi.TypeListener; import org.seedstack.seed.Logging; import org.slf4j.Logger; import java.lang.reflect.Field; import java.util.HashSet; import java.util.Set; /** * Guice type listener that will register any type having a field annotated with {@link Logging}. */ class LoggingTypeListener implements TypeListener { @Override public <T> void hear(TypeLiteral<T> typeLiteral, TypeEncounter<T> typeEncounter) { Set<Field> fields = new HashSet<>(); for (Class<?> c = typeLiteral.getRawType(); c != Object.class; c = c.getSuperclass()) { for (Field field : c.getDeclaredFields()) { if (field.getType() == Logger.class && field.isAnnotationPresent(Logging.class)) { fields.add(field); } } } if (!fields.isEmpty()) { typeEncounter.register(new LoggingMembersInjector<>(fields)); } } }