2021-05-20 01:35:37 +02:00
|
|
|
package com.jozufozu.flywheel;
|
|
|
|
|
2021-12-06 10:47:52 +01:00
|
|
|
import org.apache.logging.log4j.LogManager;
|
|
|
|
import org.apache.logging.log4j.Logger;
|
|
|
|
|
2022-02-01 21:46:47 +01:00
|
|
|
import com.jozufozu.flywheel.backend.Backend;
|
2022-02-02 06:32:31 +01:00
|
|
|
import com.jozufozu.flywheel.backend.Loader;
|
|
|
|
import com.jozufozu.flywheel.backend.RenderWork;
|
|
|
|
import com.jozufozu.flywheel.backend.instancing.InstancedRenderDispatcher;
|
2021-06-30 21:43:54 +02:00
|
|
|
import com.jozufozu.flywheel.config.FlwConfig;
|
2022-02-01 21:46:47 +01:00
|
|
|
import com.jozufozu.flywheel.core.Contexts;
|
|
|
|
import com.jozufozu.flywheel.core.PartialModel;
|
2022-02-02 06:32:31 +01:00
|
|
|
import com.jozufozu.flywheel.core.QuadConverter;
|
2022-02-01 21:46:47 +01:00
|
|
|
import com.jozufozu.flywheel.core.compile.ProgramCompiler;
|
2022-02-02 06:32:31 +01:00
|
|
|
import com.jozufozu.flywheel.core.crumbling.CrumblingRenderer;
|
|
|
|
import com.jozufozu.flywheel.event.EntityWorldHandler;
|
|
|
|
import com.jozufozu.flywheel.event.ForgeEvents;
|
|
|
|
import com.jozufozu.flywheel.fabric.event.FlywheelEvents;
|
2022-02-01 21:46:47 +01:00
|
|
|
import com.jozufozu.flywheel.mixin.PausedPartialTickAccessor;
|
|
|
|
import com.jozufozu.flywheel.vanilla.VanillaInstances;
|
2021-06-19 07:52:33 +02:00
|
|
|
|
2022-02-02 06:32:31 +01:00
|
|
|
import net.fabricmc.api.ClientModInitializer;
|
|
|
|
import net.fabricmc.fabric.api.client.event.lifecycle.v1.ClientEntityEvents;
|
|
|
|
import net.fabricmc.fabric.api.client.event.lifecycle.v1.ClientTickEvents;
|
|
|
|
import net.fabricmc.fabric.api.client.model.ModelLoadingRegistry;
|
|
|
|
import net.fabricmc.fabric.api.client.rendering.v1.WorldRenderEvents;
|
|
|
|
import net.fabricmc.fabric.api.resource.ResourceManagerHelper;
|
2022-02-01 03:18:24 +01:00
|
|
|
import net.fabricmc.loader.api.FabricLoader;
|
|
|
|
import net.fabricmc.loader.api.SemanticVersion;
|
|
|
|
import net.fabricmc.loader.api.Version;
|
2021-09-15 08:45:29 +02:00
|
|
|
import net.minecraft.resources.ResourceLocation;
|
2022-02-02 06:32:31 +01:00
|
|
|
import net.minecraft.server.packs.PackType;
|
2021-06-16 20:19:33 +02:00
|
|
|
|
2022-02-02 06:32:31 +01:00
|
|
|
public class Flywheel implements ClientModInitializer {
|
2021-05-20 01:35:37 +02:00
|
|
|
|
2021-06-30 21:43:54 +02:00
|
|
|
public static final String ID = "flywheel";
|
2021-12-25 08:26:18 +01:00
|
|
|
public static final Logger LOGGER = LogManager.getLogger(Flywheel.class);
|
2022-02-02 06:32:31 +01:00
|
|
|
private static SemanticVersion version;
|
2022-01-31 22:13:27 +01:00
|
|
|
|
2022-02-02 06:32:31 +01:00
|
|
|
@Override
|
|
|
|
public void onInitializeClient() {
|
2022-02-01 03:18:24 +01:00
|
|
|
Version version = FabricLoader.getInstance()
|
|
|
|
.getModContainer(ID)
|
|
|
|
.orElseThrow(() -> new IllegalStateException("Could not get the mod container for Flywheel!"))
|
|
|
|
.getMetadata()
|
2022-01-31 22:13:27 +01:00
|
|
|
.getVersion();
|
2022-02-01 03:18:24 +01:00
|
|
|
if (!(version instanceof SemanticVersion semver)) {
|
|
|
|
throw new IllegalStateException("Got non-semantic version for Flywheel!");
|
|
|
|
}
|
2022-02-02 06:32:31 +01:00
|
|
|
Flywheel.version = semver;
|
2021-06-16 20:19:33 +02:00
|
|
|
|
2021-06-19 07:52:33 +02:00
|
|
|
FlwConfig.init();
|
2021-06-16 20:19:33 +02:00
|
|
|
|
2022-02-02 06:32:31 +01:00
|
|
|
Backend.init();
|
2021-06-16 20:19:33 +02:00
|
|
|
|
2022-02-02 06:32:31 +01:00
|
|
|
FlywheelEvents.GATHER_CONTEXT.register(Contexts::flwInit);
|
|
|
|
ModelLoadingRegistry.INSTANCE.registerModelProvider(PartialModel::onModelRegistry);
|
|
|
|
ResourceManagerHelper.get(PackType.CLIENT_RESOURCES).registerReloadListener(PartialModel.ResourceReloadListener.INSTANCE);
|
2022-02-01 21:46:47 +01:00
|
|
|
|
2022-02-02 06:32:31 +01:00
|
|
|
FlywheelEvents.RELOAD_RENDERERS.register(ProgramCompiler::invalidateAll);
|
2022-02-01 21:46:47 +01:00
|
|
|
|
2022-02-02 06:32:31 +01:00
|
|
|
ResourceManagerHelper.get(PackType.CLIENT_RESOURCES).registerReloadListener(Loader.ResourceReloadListener.INSTANCE);
|
2022-02-01 21:46:47 +01:00
|
|
|
|
2022-02-02 06:32:31 +01:00
|
|
|
WorldRenderEvents.END.register(RenderWork::onRenderWorldLast);
|
|
|
|
ClientTickEvents.END_CLIENT_TICK.register(InstancedRenderDispatcher::tick);
|
|
|
|
FlywheelEvents.BEGIN_FRAME.register(InstancedRenderDispatcher::onBeginFrame);
|
|
|
|
FlywheelEvents.RENDER_LAYER.register(InstancedRenderDispatcher::renderLayer);
|
|
|
|
FlywheelEvents.RELOAD_RENDERERS.register(InstancedRenderDispatcher::onReloadRenderers);
|
|
|
|
FlywheelEvents.RELOAD_RENDERERS.register(QuadConverter::onRendererReload);
|
|
|
|
FlywheelEvents.RELOAD_RENDERERS.register(CrumblingRenderer::onReloadRenderers);
|
|
|
|
ClientEntityEvents.ENTITY_LOAD.register(EntityWorldHandler::onEntityJoinWorld);
|
|
|
|
ClientEntityEvents.ENTITY_UNLOAD.register(EntityWorldHandler::onEntityLeaveWorld);
|
|
|
|
ClientTickEvents.END_CLIENT_TICK.register(ForgeEvents::tickLight);
|
2022-02-01 21:46:47 +01:00
|
|
|
|
|
|
|
VanillaInstances.init();
|
|
|
|
|
|
|
|
// https://github.com/Jozufozu/Flywheel/issues/69
|
|
|
|
// Weird issue with accessor loading.
|
|
|
|
// Only thing I've seen that's close to a fix is to force the class to load before trying to use it.
|
|
|
|
// From the SpongePowered discord:
|
|
|
|
// https://discord.com/channels/142425412096491520/626802111455297538/675007581168599041
|
2022-02-02 05:44:53 +01:00
|
|
|
LOGGER.debug("Successfully loaded {}", PausedPartialTickAccessor.class.getName());
|
2022-02-01 21:46:47 +01:00
|
|
|
}
|
|
|
|
|
2022-02-02 06:32:31 +01:00
|
|
|
public static SemanticVersion getVersion() {
|
2022-02-02 05:44:53 +01:00
|
|
|
return version;
|
2021-06-19 07:52:33 +02:00
|
|
|
}
|
2021-06-16 20:19:33 +02:00
|
|
|
|
2021-09-05 01:40:40 +02:00
|
|
|
public static ResourceLocation rl(String path) {
|
|
|
|
return new ResourceLocation(ID, path);
|
|
|
|
}
|
2021-05-20 01:35:37 +02:00
|
|
|
}
|