/*
* Copyright (c) 2015 NOVA, All rights reserved.
* This library is free software, licensed under GNU Lesser General Public License version 3
*
* This file is part of NOVA.
*
* NOVA is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* NOVA is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with NOVA. If not, see <http://www.gnu.org/licenses/>.
*/
package nova.core.component;
import java.lang.annotation.ElementType;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
import java.lang.annotation.Target;
/**
* <p>
* This annotation can be used together with {@link Component} to specify an
* interface to be passed through to the wrapper implementation. This can be
* used to achieve basic native compatibility, for example for energy systems.
* </p>
*
* <p>
* A component with a passthrough will cause the wrapper to implement an
* interface on the native representation and respectively creates a new
* instance of said passthrough component for every native representation that
* implements the interface and isn't added by NOVA.
* </p>
*
* <p>
* A passthrough component has to be registered with
* {@link ComponentManager#registerNativePassthrough(Class)}
* </p>
*
* @author Vic Nightfall
*
*/
@Retention(RetentionPolicy.RUNTIME)
@Target(ElementType.TYPE)
public @interface Passthrough {
String value();
}