2022-11-17 00:46:50 +03:00
|
|
|
package magistu.siegemachines;
|
|
|
|
|
|
|
|
import magistu.siegemachines.block.ModBlocks;
|
|
|
|
import magistu.siegemachines.client.ClientProxy;
|
|
|
|
import magistu.siegemachines.client.SoundTypes;
|
|
|
|
import magistu.siegemachines.config.SpecsConfig;
|
|
|
|
import magistu.siegemachines.data.recipes.ModRecipes;
|
|
|
|
import magistu.siegemachines.gui.ContainerTypes;
|
|
|
|
import magistu.siegemachines.entity.EntityTypes;
|
|
|
|
import magistu.siegemachines.item.ModItems;
|
|
|
|
import magistu.siegemachines.network.PacketHandler;
|
|
|
|
import magistu.siegemachines.proxy.IProxy;
|
|
|
|
import magistu.siegemachines.server.ServerProxy;
|
|
|
|
import net.minecraft.block.Block;
|
|
|
|
import net.minecraft.block.Blocks;
|
|
|
|
import net.minecraftforge.common.MinecraftForge;
|
|
|
|
import net.minecraftforge.event.RegistryEvent;
|
|
|
|
import net.minecraftforge.eventbus.api.IEventBus;
|
|
|
|
import net.minecraftforge.eventbus.api.SubscribeEvent;
|
|
|
|
import net.minecraftforge.fml.DistExecutor;
|
|
|
|
import net.minecraftforge.fml.InterModComms;
|
|
|
|
import net.minecraftforge.fml.common.Mod;
|
|
|
|
import net.minecraftforge.fml.event.lifecycle.FMLClientSetupEvent;
|
|
|
|
import net.minecraftforge.fml.event.lifecycle.FMLCommonSetupEvent;
|
|
|
|
import net.minecraftforge.fml.event.lifecycle.InterModEnqueueEvent;
|
|
|
|
import net.minecraftforge.fml.event.lifecycle.InterModProcessEvent;
|
|
|
|
import net.minecraftforge.fml.event.server.FMLServerStartingEvent;
|
|
|
|
import net.minecraftforge.fml.javafmlmod.FMLJavaModLoadingContext;
|
|
|
|
import org.apache.logging.log4j.LogManager;
|
|
|
|
import org.apache.logging.log4j.Logger;
|
|
|
|
|
|
|
|
import java.util.UUID;
|
|
|
|
import java.util.stream.Collectors;
|
|
|
|
|
|
|
|
// The value here should match an entry in the META-INF/mods.toml file
|
2022-11-24 19:51:01 +02:00
|
|
|
@Mod(SiegeMachines.ID)
|
2022-11-17 00:46:50 +03:00
|
|
|
public class SiegeMachines
|
|
|
|
{
|
|
|
|
public static final String ID = "siegemachines";
|
|
|
|
|
|
|
|
public static final IProxy PROXY = DistExecutor.safeRunForDist(() -> ClientProxy::new, () -> ServerProxy::new);
|
|
|
|
public static final int RENDER_UPDATE_RANGE = 128;
|
|
|
|
public static final int RENDER_UPDATE_TIME = 20;
|
|
|
|
public static final int RENDER_UPDATE_RANGE_SQR = RENDER_UPDATE_RANGE * RENDER_UPDATE_RANGE;
|
|
|
|
|
|
|
|
public static final UUID CHAT_UUID = new UUID(100L, 100L);
|
|
|
|
|
|
|
|
// Directly reference a log4j logger.
|
|
|
|
private static final Logger LOGGER = LogManager.getLogger();
|
|
|
|
|
|
|
|
|
|
|
|
public SiegeMachines()
|
|
|
|
{
|
|
|
|
IEventBus eventBus = FMLJavaModLoadingContext.get().getModEventBus();
|
|
|
|
|
|
|
|
FMLJavaModLoadingContext.get().getModEventBus().addListener(this::setup);
|
|
|
|
FMLJavaModLoadingContext.get().getModEventBus().addListener(this::enqueueIMC);
|
|
|
|
FMLJavaModLoadingContext.get().getModEventBus().addListener(this::processIMC);
|
|
|
|
FMLJavaModLoadingContext.get().getModEventBus().addListener(this::doClientStuff);
|
|
|
|
|
|
|
|
EntityTypes.register(eventBus);
|
|
|
|
SoundTypes.register(eventBus);
|
|
|
|
ContainerTypes.register(eventBus);
|
|
|
|
ModBlocks.register(eventBus);
|
|
|
|
ModItems.register(eventBus);
|
|
|
|
ModRecipes.register(eventBus);
|
|
|
|
SpecsConfig.register();
|
|
|
|
|
|
|
|
PacketHandler.init();
|
|
|
|
|
|
|
|
MinecraftForge.EVENT_BUS.register(this);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
private void setup(final FMLCommonSetupEvent event)
|
|
|
|
{
|
|
|
|
// some preinit code
|
|
|
|
LOGGER.info("HELLO FROM PREINIT");
|
|
|
|
LOGGER.info("DIRT BLOCK >> {}", Blocks.DIRT.getRegistryName());
|
|
|
|
}
|
|
|
|
|
|
|
|
private void doClientStuff(final FMLClientSetupEvent event)
|
|
|
|
{
|
|
|
|
// do something that can only be done on the client
|
|
|
|
LOGGER.info("Got game settings {}", event.getMinecraftSupplier().get().options);
|
|
|
|
|
|
|
|
PROXY.clientSetup(event);
|
|
|
|
}
|
|
|
|
|
|
|
|
private void enqueueIMC(final InterModEnqueueEvent event)
|
|
|
|
{
|
|
|
|
// some example code to dispatch IMC to another mod
|
|
|
|
InterModComms.sendTo("examplemod", "helloworld", () -> { LOGGER.info("Hello world from the MDK"); return "Hello world";});
|
|
|
|
}
|
|
|
|
|
|
|
|
private void processIMC(final InterModProcessEvent event)
|
|
|
|
{
|
|
|
|
// some example code to receive and process InterModComms from other mods
|
|
|
|
LOGGER.info("Got IMC {}", event.getIMCStream().
|
|
|
|
map(m->m.getMessageSupplier().get()).
|
|
|
|
collect(Collectors.toList()));
|
|
|
|
}
|
|
|
|
// You can use SubscribeEvent and let the Event Bus discover methods to call
|
|
|
|
@SubscribeEvent
|
|
|
|
public void onServerStarting(FMLServerStartingEvent event)
|
|
|
|
{
|
|
|
|
// do something when the server starts
|
|
|
|
LOGGER.info("HELLO from server starting");
|
|
|
|
}
|
|
|
|
|
|
|
|
// You can use EventBusSubscriber to automatically subscribe events on the contained class (this is subscribing to the MOD
|
|
|
|
// Event bus for receiving Registry Events)
|
|
|
|
@Mod.EventBusSubscriber(bus=Mod.EventBusSubscriber.Bus.MOD)
|
|
|
|
public static class RegistryEvents
|
|
|
|
{
|
|
|
|
@SubscribeEvent
|
|
|
|
public static void onBlocksRegistry(final RegistryEvent.Register<Block> blockRegistryEvent)
|
|
|
|
{
|
|
|
|
// register a new block here
|
|
|
|
LOGGER.info("HELLO from Register Block");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|