Created Test Block & DataGen

This commit is contained in:
2025-04-23 01:48:58 +02:00
parent d9bd79a22a
commit 24eaf236e3
23 changed files with 282 additions and 11 deletions

View File

@ -5,6 +5,6 @@ import net.fabricmc.api.ClientModInitializer;
public class SurvivalEnhancedClient implements ClientModInitializer { public class SurvivalEnhancedClient implements ClientModInitializer {
@Override @Override
public void onInitializeClient() { public void onInitializeClient() {
// This entrypoint is suitable for setting up client-specific logic, such as rendering.
} }
} }

View File

@ -2,10 +2,23 @@ package wtf.hak;
import net.fabricmc.fabric.api.datagen.v1.DataGeneratorEntrypoint; import net.fabricmc.fabric.api.datagen.v1.DataGeneratorEntrypoint;
import net.fabricmc.fabric.api.datagen.v1.FabricDataGenerator; import net.fabricmc.fabric.api.datagen.v1.FabricDataGenerator;
import net.minecraft.registry.Registries;
import wtf.hak.blocks.ModBlocks;
import wtf.hak.datagen.*;
public class SurvivalEnhancedDataGenerator implements DataGeneratorEntrypoint { public class SurvivalEnhancedDataGenerator implements DataGeneratorEntrypoint {
@Override
public void onInitializeDataGenerator(FabricDataGenerator fabricDataGenerator) {
@Override
public void onInitializeDataGenerator(FabricDataGenerator generator) {
FabricDataGenerator.Pack pack = generator.createPack();
//System.out.println("MY_BLOCK ID: " + Registries.BLOCK.getId(ModBlocks.TEST_BLOCK));
pack.addProvider(ModBlockTagProvider::new);
pack.addProvider(ModItemTagProvider::new);
pack.addProvider(ModModelProvider::new);
pack.addProvider(ModLootTableProvider::new);
pack.addProvider(ModEngLangProvider::new);
//pack.addProvider(ModRecipeProvider::new);
} }
} }

View File

@ -0,0 +1,22 @@
package wtf.hak.datagen;
import net.fabricmc.fabric.api.datagen.v1.FabricDataOutput;
import net.fabricmc.fabric.api.datagen.v1.provider.FabricTagProvider;
import net.minecraft.registry.RegistryWrapper;
import net.minecraft.registry.tag.BlockTags;
import wtf.hak.blocks.ModBlocks;
import java.util.concurrent.CompletableFuture;
public class ModBlockTagProvider extends FabricTagProvider.BlockTagProvider {
public ModBlockTagProvider(FabricDataOutput output, CompletableFuture<RegistryWrapper.WrapperLookup> registriesFuture) {
super(output, registriesFuture);
}
@Override
protected void configure(RegistryWrapper.WrapperLookup wrapperLookup) {
getOrCreateTagBuilder(BlockTags.PICKAXE_MINEABLE)
.add(ModBlocks.TEST_BLOCK);
}
}

View File

@ -0,0 +1,19 @@
package wtf.hak.datagen;
import net.fabricmc.fabric.api.datagen.v1.FabricDataOutput;
import net.fabricmc.fabric.api.datagen.v1.provider.FabricLanguageProvider;
import net.minecraft.registry.RegistryWrapper;
import wtf.hak.blocks.ModBlocks;
import java.util.concurrent.CompletableFuture;
public class ModEngLangProvider extends FabricLanguageProvider{
public ModEngLangProvider(FabricDataOutput dataOutput, CompletableFuture<RegistryWrapper.WrapperLookup> registryLookup) {
super(dataOutput, "en_us", registryLookup);
}
@Override
public void generateTranslations(RegistryWrapper.WrapperLookup wrapperLookup, TranslationBuilder translationBuilder) {
translationBuilder.add(ModBlocks.TEST_BLOCK.asItem(), "Test Block");
}
}

View File

@ -0,0 +1,19 @@
package wtf.hak.datagen;
import net.fabricmc.fabric.api.datagen.v1.FabricDataOutput;
import net.fabricmc.fabric.api.datagen.v1.provider.FabricTagProvider;
import net.minecraft.registry.RegistryWrapper;
import org.jetbrains.annotations.Nullable;
import java.util.concurrent.CompletableFuture;
public class ModItemTagProvider extends FabricTagProvider.ItemTagProvider {
public ModItemTagProvider(FabricDataOutput output, CompletableFuture<RegistryWrapper.WrapperLookup> completableFuture) {
super(output, completableFuture);
}
@Override
protected void configure(RegistryWrapper.WrapperLookup wrapperLookup) {
}
}

View File

@ -0,0 +1,25 @@
package wtf.hak.datagen;
import net.fabricmc.fabric.api.datagen.v1.FabricDataOutput;
import net.fabricmc.fabric.api.datagen.v1.provider.FabricBlockLootTableProvider;
import net.minecraft.data.DataOutput;
import net.minecraft.loot.LootTable;
import net.minecraft.registry.RegistryKey;
import net.minecraft.registry.RegistryWrapper;
import wtf.hak.blocks.ModBlocks;
import java.util.List;
import java.util.Set;
import java.util.concurrent.CompletableFuture;
public class ModLootTableProvider extends FabricBlockLootTableProvider {
public ModLootTableProvider(FabricDataOutput dataOutput, CompletableFuture<RegistryWrapper.WrapperLookup> registryLookup) {
super(dataOutput, registryLookup);
}
@Override
public void generate() {
addDrop(ModBlocks.TEST_BLOCK);
}
}

View File

@ -0,0 +1,23 @@
package wtf.hak.datagen;
import net.fabricmc.fabric.api.client.datagen.v1.provider.FabricModelProvider;
import net.fabricmc.fabric.api.datagen.v1.FabricDataOutput;
import net.minecraft.client.data.BlockStateModelGenerator;
import net.minecraft.client.data.ItemModelGenerator;
import wtf.hak.blocks.ModBlocks;
public class ModModelProvider extends FabricModelProvider {
public ModModelProvider(FabricDataOutput output) {
super(output);
}
@Override
public void generateBlockStateModels(BlockStateModelGenerator blockStateModelGenerator) {
blockStateModelGenerator.registerSimpleCubeAll(ModBlocks.TEST_BLOCK);
}
@Override
public void generateItemModels(ItemModelGenerator itemModelGenerator) {
}
}

View File

@ -0,0 +1,26 @@
package wtf.hak.datagen;
import net.fabricmc.fabric.api.datagen.v1.FabricDataOutput;
import net.fabricmc.fabric.api.datagen.v1.provider.FabricRecipeProvider;
import net.minecraft.data.recipe.RecipeExporter;
import net.minecraft.data.recipe.RecipeGenerator;
import net.minecraft.registry.RegistryWrapper;
import java.util.concurrent.CompletableFuture;
public class ModRecipeProvider extends FabricRecipeProvider {
public ModRecipeProvider(FabricDataOutput output, CompletableFuture<RegistryWrapper.WrapperLookup> registriesFuture) {
super(output, registriesFuture);
}
@Override
protected RecipeGenerator getRecipeGenerator(RegistryWrapper.WrapperLookup wrapperLookup, RecipeExporter recipeExporter) {
return null;
}
@Override
public String getName() {
return "";
}
}

View File

@ -0,0 +1,2 @@
// 1.21.5 -999999999-01-01T00:00:00 SurvivalEnhanced/Block Loot Tables
6d3d52fa8e565a8270b6ed73f2d41c45eb8f8ae1 data/survivalenhanced/loot_table/blocks/test_block.json

View File

@ -0,0 +1 @@
// 1.21.5 -999999999-01-01T00:00:00 SurvivalEnhanced/Tags for minecraft:item

View File

@ -0,0 +1,2 @@
// 1.21.5 -999999999-01-01T00:00:00 SurvivalEnhanced/Tags for minecraft:block
5bfebfdb385a11ef08214d202811caf3d2ece770 data/minecraft/tags/block/mineable/pickaxe.json

View File

@ -0,0 +1,4 @@
// 1.21.5 -999999999-01-01T00:00:00 SurvivalEnhanced/Model Definitions
8a4568413ceea79afb6cd12a04d134475dc0a5dd assets/survivalenhanced/blockstates/test_block.json
4bf1b27ded399c3be7cd77d2c4687ea7771cd9eb assets/survivalenhanced/items/test_block.json
2c21fa4746f154853402115ecd8a85816b163592 assets/survivalenhanced/models/block/test_block.json

View File

@ -0,0 +1,2 @@
// 1.21.5 -999999999-01-01T00:00:00 SurvivalEnhanced/Language (en_us)
f92cdd9c2f07e8456fcc5d8040adfbcc626bbdcb assets/survivalenhanced/lang/en_us.json

View File

@ -0,0 +1,7 @@
{
"variants": {
"": {
"model": "survivalenhanced:block/test_block"
}
}
}

View File

@ -0,0 +1,6 @@
{
"model": {
"type": "minecraft:model",
"model": "survivalenhanced:block/test_block"
}
}

View File

@ -0,0 +1,3 @@
{
"item.survivalenhanced.test_block": "Test Block"
}

View File

@ -0,0 +1,6 @@
{
"parent": "minecraft:block/cube_all",
"textures": {
"all": "survivalenhanced:block/test_block"
}
}

View File

@ -0,0 +1,5 @@
{
"values": [
"survivalenhanced:test_block"
]
}

View File

@ -0,0 +1,20 @@
{
"type": "minecraft:block",
"pools": [
{
"bonus_rolls": 0.0,
"conditions": [
{
"condition": "minecraft:survives_explosion"
}
],
"entries": [
{
"type": "minecraft:item",
"name": "survivalenhanced:test_block"
}
],
"rolls": 1.0
}
]
}

View File

@ -4,21 +4,15 @@ import net.fabricmc.api.ModInitializer;
import org.slf4j.Logger; import org.slf4j.Logger;
import org.slf4j.LoggerFactory; import org.slf4j.LoggerFactory;
import wtf.hak.blocks.ModBlocks;
public class SurvivalEnhanced implements ModInitializer { public class SurvivalEnhanced implements ModInitializer {
public static final String MOD_ID = "survivalenhanced"; public static final String MOD_ID = "survivalenhanced";
// This logger is used to write text to the console and the log file.
// It is considered best practice to use your mod id as the logger's name.
// That way, it's clear which mod wrote info, warnings, and errors.
public static final Logger LOGGER = LoggerFactory.getLogger(MOD_ID); public static final Logger LOGGER = LoggerFactory.getLogger(MOD_ID);
@Override @Override
public void onInitialize() { public void onInitialize() {
// This code runs as soon as Minecraft is in a mod-load-ready state. ModBlocks.registerBlocks();
// However, some things (like resources) may still be uninitialized.
// Proceed with mild caution.
LOGGER.info("Hello Fabric world!");
} }
} }

View File

@ -0,0 +1,62 @@
package wtf.hak.blocks;
import net.fabricmc.fabric.api.itemgroup.v1.ItemGroupEvents;
import net.minecraft.block.AbstractBlock;
import net.minecraft.block.Block;
import net.minecraft.block.ChestBlock;
import net.minecraft.block.TestBlock;
import net.minecraft.block.entity.BlockEntityType;
import net.minecraft.item.BlockItem;
import net.minecraft.item.Item;
import net.minecraft.item.ItemGroups;
import net.minecraft.registry.Registries;
import net.minecraft.registry.Registry;
import net.minecraft.registry.RegistryKey;
import net.minecraft.registry.RegistryKeys;
import net.minecraft.util.Identifier;
import wtf.hak.SurvivalEnhanced;
import java.util.function.Function;
public class ModBlocks {
public static Block TEST_BLOCK;
private static Block register(String name, Function<AbstractBlock.Settings, Block> blockFactory, AbstractBlock.Settings settings, boolean shouldRegisterItem) {
// Create a registry key for the block
RegistryKey<Block> blockKey = keyOfBlock(name);
// Create the block instance
Block block = blockFactory.apply(settings.registryKey(blockKey));
// Sometimes, you may not want to register an item for the block.
// Eg: if it's a technical block like `minecraft:moving_piston` or `minecraft:end_gateway`
if (shouldRegisterItem) {
// Items need to be registered with a different type of registry key, but the ID
// can be the same.
RegistryKey<Item> itemKey = keyOfItem(name);
BlockItem blockItem = new BlockItem(block, new Item.Settings().registryKey(itemKey));
Registry.register(Registries.ITEM, itemKey, blockItem);
}
return Registry.register(Registries.BLOCK, blockKey, block);
}
private static RegistryKey<Block> keyOfBlock(String name) {
return RegistryKey.of(RegistryKeys.BLOCK, Identifier.of(SurvivalEnhanced.MOD_ID, name));
}
private static RegistryKey<Item> keyOfItem(String name) {
return RegistryKey.of(RegistryKeys.ITEM, Identifier.of(SurvivalEnhanced.MOD_ID, name));
}
public static void registerBlocks(){
TEST_BLOCK = register("test_block",
TestBlock::new,
AbstractBlock.Settings.create().strength(1f).requiresTool(),
true);
ItemGroupEvents.modifyEntriesEvent(ItemGroups.BUILDING_BLOCKS).register(entries -> entries.add(TEST_BLOCK));
}
}

View File

@ -0,0 +1,10 @@
package wtf.hak.blocks;
import net.minecraft.block.Block;
public class TestBlock extends Block {
public TestBlock(Settings settings) {
super(settings);
}
}

Binary file not shown.

After

Width:  |  Height:  |  Size: 269 B