register terra chunk generators alongside vanilla

This commit is contained in:
dfsek
2022-03-23 22:30:21 -07:00
parent 2267759378
commit a71da4f4c2
3 changed files with 75 additions and 51 deletions
@@ -29,6 +29,7 @@ import com.dfsek.terra.fabric.data.Codecs;
import net.fabricmc.api.ModInitializer; import net.fabricmc.api.ModInitializer;
import net.minecraft.server.command.ServerCommandSource; import net.minecraft.server.command.ServerCommandSource;
import net.minecraft.util.Identifier; import net.minecraft.util.Identifier;
import net.minecraft.util.registry.BuiltinRegistries;
import net.minecraft.util.registry.Registry; import net.minecraft.util.registry.Registry;
import org.slf4j.Logger; import org.slf4j.Logger;
import org.slf4j.LoggerFactory; import org.slf4j.LoggerFactory;
@@ -47,9 +48,6 @@ public class FabricEntryPoint implements ModInitializer {
@Override @Override
public void onInitialize() { public void onInitialize() {
logger.info("Initializing Terra Fabric mod..."); logger.info("Initializing Terra Fabric mod...");
// register the things
Registry.register(Registry.CHUNK_GENERATOR, new Identifier("terra:terra"), Codecs.FABRIC_CHUNK_GENERATOR_WRAPPER);
Registry.register(Registry.BIOME_SOURCE, new Identifier("terra:terra"), Codecs.TERRA_BIOME_SOURCE);
FabricServerCommandManager<CommandSender> manager = new FabricServerCommandManager<>( FabricServerCommandManager<CommandSender> manager = new FabricServerCommandManager<>(
CommandExecutionCoordinator.simpleCoordinator(), CommandExecutionCoordinator.simpleCoordinator(),
@@ -57,8 +55,14 @@ public class FabricEntryPoint implements ModInitializer {
commandSender -> (ServerCommandSource) commandSender commandSender -> (ServerCommandSource) commandSender
); );
manager.brigadierManager().setNativeNumberSuggestions(false); manager.brigadierManager().setNativeNumberSuggestions(false);
TERRA_PLUGIN.getEventManager().callEvent(new CommandRegistrationEvent(manager)); TERRA_PLUGIN.getEventManager().callEvent(new CommandRegistrationEvent(manager));
} }
public static void register() { // register the things
Registry.register(Registry.CHUNK_GENERATOR, new Identifier("terra:terra"), Codecs.FABRIC_CHUNK_GENERATOR_WRAPPER);
Registry.register(Registry.BIOME_SOURCE, new Identifier("terra:terra"), Codecs.TERRA_BIOME_SOURCE);
}
} }
@@ -0,0 +1,19 @@
package com.dfsek.terra.fabric.mixin.lifecycle;
import com.dfsek.terra.fabric.FabricEntryPoint;
import net.minecraft.world.gen.chunk.ChunkGenerator;
import org.spongepowered.asm.mixin.Mixin;
import org.spongepowered.asm.mixin.injection.At;
import org.spongepowered.asm.mixin.injection.Inject;
import org.spongepowered.asm.mixin.injection.callback.CallbackInfo;
@Mixin(ChunkGenerator.class)
public class ChunkGenerator_ChunkGeneratorRegistrationMixin {
@Inject(method = "<clinit>", at = @At("RETURN"))
private static void registerTerraGenerators(CallbackInfo ci) {
FabricEntryPoint.register();
}
}
@@ -1,50 +1,51 @@
{ {
"required": true, "required": true,
"minVersion": "0.8", "minVersion": "0.8",
"package": "com.dfsek.terra.fabric.mixin", "package": "com.dfsek.terra.fabric.mixin",
"compatibilityLevel": "JAVA_16", "compatibilityLevel": "JAVA_16",
"mixins": [ "mixins": [
"access.BiomeEffectsAccessor", "access.BiomeEffectsAccessor",
"access.MobSpawnerLogicAccessor", "access.MobSpawnerLogicAccessor",
"access.StateAccessor", "access.StateAccessor",
"access.StructureAccessorAccessor", "access.StructureAccessorAccessor",
"implementations.BiomeMixin", "implementations.BiomeMixin",
"implementations.HandleImplementationMixin", "implementations.HandleImplementationMixin",
"implementations.block.BlockMixin", "implementations.block.BlockMixin",
"implementations.block.entity.BlockEntityMixin", "implementations.block.entity.BlockEntityMixin",
"implementations.block.entity.LootableContainerBlockEntityMixin", "implementations.block.entity.LootableContainerBlockEntityMixin",
"implementations.block.entity.MobSpawnerBlockEntityMixin", "implementations.block.entity.MobSpawnerBlockEntityMixin",
"implementations.block.entity.SignBlockEntityMixin", "implementations.block.entity.SignBlockEntityMixin",
"implementations.block.state.BlockStateMixin", "implementations.block.state.BlockStateMixin",
"implementations.block.state.PropertyMixin", "implementations.block.state.PropertyMixin",
"implementations.chunk.ChunkRegionMixin", "implementations.chunk.ChunkRegionMixin",
"implementations.chunk.WorldChunkMixin", "implementations.chunk.WorldChunkMixin",
"implementations.chunk.data.ProtoChunkMixin", "implementations.chunk.data.ProtoChunkMixin",
"implementations.entity.EntityMixin", "implementations.entity.EntityMixin",
"implementations.entity.EntityTypeMixin", "implementations.entity.EntityTypeMixin",
"implementations.entity.PlayerEntityMixin", "implementations.entity.PlayerEntityMixin",
"implementations.entity.ServerCommandSourceMixin", "implementations.entity.ServerCommandSourceMixin",
"implementations.inventory.LockableContainerBlockEntityMixin", "implementations.inventory.LockableContainerBlockEntityMixin",
"implementations.inventory.item.ItemMixin", "implementations.inventory.item.ItemMixin",
"implementations.inventory.item.ItemStackMixin", "implementations.inventory.item.ItemStackMixin",
"implementations.inventory.meta.EnchantmentMixin", "implementations.inventory.meta.EnchantmentMixin",
"implementations.inventory.meta.ItemStackDamageableMixin", "implementations.inventory.meta.ItemStackDamageableMixin",
"implementations.inventory.meta.ItemStackMetaMixin", "implementations.inventory.meta.ItemStackMetaMixin",
"implementations.world.ChunkRegionMixin", "implementations.world.ChunkRegionMixin",
"implementations.world.ServerWorldMixin", "implementations.world.ServerWorldMixin",
"lifecycle.MinecraftServerMixin", "lifecycle.ChunkGenerator_ChunkGeneratorRegistrationMixin",
"lifecycle.MinecraftServer_BiomeRegistrationMixin" "lifecycle.MinecraftServer_BiomeRegistrationMixin",
], "lifecycle.MinecraftServerMixin"
"client": [ ],
"access.GeneratorTypeAccessor", "client": [
"lifecycle.client.MinecraftClientMixin" "access.GeneratorTypeAccessor",
], "lifecycle.client.MinecraftClientMixin"
"server": [ ],
"lifecycle.server.GeneratorOptionsMixin", "server": [
"lifecycle.server.ServerMainMixin" "lifecycle.server.GeneratorOptionsMixin",
], "lifecycle.server.ServerMainMixin"
"injectors": { ],
"defaultRequire": 1 "injectors": {
}, "defaultRequire": 1
"refmap": "terra-refmap.json" },
"refmap": "terra-refmap.json"
} }