/* * Minecraft Forge * Copyright (c) 2016. * * This library is free software; you can redistribute it and/or * modify it under the terms of the GNU Lesser General Public * License as published by the Free Software Foundation version 2.1 * of the License. * * This library 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 * Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with this library; if not, write to the Free Software * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA */ package net.minecraftforge.fml.common; import java.lang.annotation.ElementType; import java.lang.annotation.Retention; import java.lang.annotation.RetentionPolicy; import java.lang.annotation.Target; /** * Sided proxies are loaded based on the specific environment they find themselves loaded into. * They are used to ensure that client-specific code (such as GUIs) is only loaded into the game * on the client side. * It is applied to static fields of a class, anywhere in your mod code. FML will scan * and load any classes with this annotation at mod construction time. * *

* This example will load a CommonProxy on the server side, and a ClientProxy on the client side. * *

{@code
 *  public class MySidedProxyHolder {
 *      {@literal @}SidedProxy(modId="MyModId",clientSide="mymod.ClientProxy", serverSide="mymod.CommonProxy")
 *      public static CommonProxy proxy;
 *  }
 *
 *  public class CommonProxy {
 *      // Common or server stuff here that needs to be overridden on the client
 *  }
 *
 *  public class ClientProxy extends CommonProxy {
 *      // Override common stuff with client specific stuff here
 *  }
 * }
 * 
* @author cpw * */ @Retention(RetentionPolicy.RUNTIME) @Target(ElementType.FIELD) public @interface SidedProxy { /** * The full name of the client side class to load and populate. * Defaults to the nested class named "ClientProxy" in the current class. */ String clientSide() default ""; /** * The full name of the server side class to load and populate. * Defaults to the nested class named "ServerProxy" in the current class. */ String serverSide() default ""; /** * The (optional) name of a mod to load this proxy for. This will help ensure correct behaviour when loading a combined * scala/java mod package. It is almost never going to be required, unless you ship both Scala and Java {@link Mod} content * in a single jar. */ String modId() default ""; }