mirror of
https://github.com/SquidDev-CC/CC-Tweaked
synced 2025-05-09 19:04:12 +00:00

- Build fails right now due to module issues, so this won't be pushed to GitHub. - Monitors render transparently when loaded into the world. I don't think this is a 1.17 bug, so not sure what's going on here!
120 lines
5.6 KiB
Java
120 lines
5.6 KiB
Java
/*
|
|
* This file is part of ComputerCraft - http://www.computercraft.info
|
|
* Copyright Daniel Ratcliffe, 2011-2021. Do not distribute without permission.
|
|
* Send enquiries to dratcliffe@gmail.com
|
|
*/
|
|
package dan200.computercraft.data;
|
|
|
|
import dan200.computercraft.ComputerCraft;
|
|
import dan200.computercraft.shared.CommonHooks;
|
|
import dan200.computercraft.shared.Registry;
|
|
import dan200.computercraft.shared.data.BlockNamedEntityLootCondition;
|
|
import dan200.computercraft.shared.data.HasComputerIdLootCondition;
|
|
import dan200.computercraft.shared.data.PlayerCreativeLootCondition;
|
|
import dan200.computercraft.shared.peripheral.modem.wired.BlockCable;
|
|
import dan200.computercraft.shared.peripheral.modem.wired.CableModemVariant;
|
|
import net.minecraft.advancements.critereon.StatePropertiesPredicate;
|
|
import net.minecraft.data.DataGenerator;
|
|
import net.minecraft.resources.ResourceLocation;
|
|
import net.minecraft.world.level.block.Block;
|
|
import net.minecraft.world.level.storage.loot.LootPool;
|
|
import net.minecraft.world.level.storage.loot.LootTable;
|
|
import net.minecraft.world.level.storage.loot.entries.DynamicLoot;
|
|
import net.minecraft.world.level.storage.loot.entries.LootItem;
|
|
import net.minecraft.world.level.storage.loot.parameters.LootContextParamSets;
|
|
import net.minecraft.world.level.storage.loot.predicates.AlternativeLootItemCondition;
|
|
import net.minecraft.world.level.storage.loot.predicates.ExplosionCondition;
|
|
import net.minecraft.world.level.storage.loot.predicates.LootItemBlockStatePropertyCondition;
|
|
import net.minecraft.world.level.storage.loot.providers.number.ConstantValue;
|
|
import net.minecraftforge.registries.RegistryObject;
|
|
|
|
import java.util.function.BiConsumer;
|
|
|
|
class LootTableGenerator extends LootTableProvider
|
|
{
|
|
LootTableGenerator( DataGenerator generator )
|
|
{
|
|
super( generator );
|
|
}
|
|
|
|
@Override
|
|
protected void registerLoot( BiConsumer<ResourceLocation, LootTable> add )
|
|
{
|
|
basicDrop( add, Registry.ModBlocks.DISK_DRIVE );
|
|
basicDrop( add, Registry.ModBlocks.MONITOR_NORMAL );
|
|
basicDrop( add, Registry.ModBlocks.MONITOR_ADVANCED );
|
|
basicDrop( add, Registry.ModBlocks.PRINTER );
|
|
basicDrop( add, Registry.ModBlocks.SPEAKER );
|
|
basicDrop( add, Registry.ModBlocks.WIRED_MODEM_FULL );
|
|
basicDrop( add, Registry.ModBlocks.WIRELESS_MODEM_NORMAL );
|
|
basicDrop( add, Registry.ModBlocks.WIRELESS_MODEM_ADVANCED );
|
|
|
|
computerDrop( add, Registry.ModBlocks.COMPUTER_NORMAL );
|
|
computerDrop( add, Registry.ModBlocks.COMPUTER_ADVANCED );
|
|
computerDrop( add, Registry.ModBlocks.COMPUTER_COMMAND );
|
|
computerDrop( add, Registry.ModBlocks.TURTLE_NORMAL );
|
|
computerDrop( add, Registry.ModBlocks.TURTLE_ADVANCED );
|
|
|
|
add.accept( Registry.ModBlocks.CABLE.get().getLootTable(), LootTable
|
|
.lootTable()
|
|
.setParamSet( LootContextParamSets.BLOCK )
|
|
.withPool( LootPool.lootPool()
|
|
.name( "cable" )
|
|
.setRolls( ConstantValue.exactly( 1 ) )
|
|
.add( LootItem.lootTableItem( Registry.ModItems.CABLE.get() ) )
|
|
.when( ExplosionCondition.survivesExplosion() )
|
|
.when( LootItemBlockStatePropertyCondition.hasBlockStateProperties( Registry.ModBlocks.CABLE.get() )
|
|
.setProperties( StatePropertiesPredicate.Builder.properties().hasProperty( BlockCable.CABLE, true ) )
|
|
)
|
|
)
|
|
.withPool( LootPool.lootPool()
|
|
.name( "wired_modem" )
|
|
.setRolls( ConstantValue.exactly( 1 ) )
|
|
.add( LootItem.lootTableItem( Registry.ModItems.WIRED_MODEM.get() ) )
|
|
.when( ExplosionCondition.survivesExplosion() )
|
|
.when( LootItemBlockStatePropertyCondition.hasBlockStateProperties( Registry.ModBlocks.CABLE.get() )
|
|
.setProperties( StatePropertiesPredicate.Builder.properties().hasProperty( BlockCable.MODEM, CableModemVariant.None ) )
|
|
.invert()
|
|
)
|
|
)
|
|
.build() );
|
|
|
|
add.accept( CommonHooks.LOOT_TREASURE_DISK, LootTable
|
|
.lootTable()
|
|
.setParamSet( LootContextParamSets.ALL_PARAMS )
|
|
.build() );
|
|
}
|
|
|
|
private static <T extends Block> void basicDrop( BiConsumer<ResourceLocation, LootTable> add, RegistryObject<T> wrapper )
|
|
{
|
|
Block block = wrapper.get();
|
|
add.accept( block.getLootTable(), LootTable
|
|
.lootTable()
|
|
.setParamSet( LootContextParamSets.BLOCK )
|
|
.withPool( LootPool.lootPool()
|
|
.name( "main" )
|
|
.setRolls( ConstantValue.exactly( 1 ) )
|
|
.add( LootItem.lootTableItem( block ) )
|
|
.when( ExplosionCondition.survivesExplosion() )
|
|
).build() );
|
|
}
|
|
|
|
private static <T extends Block> void computerDrop( BiConsumer<ResourceLocation, LootTable> add, RegistryObject<T> wrapper )
|
|
{
|
|
Block block = wrapper.get();
|
|
add.accept( block.getLootTable(), LootTable
|
|
.lootTable()
|
|
.setParamSet( LootContextParamSets.BLOCK )
|
|
.withPool( LootPool.lootPool()
|
|
.name( "main" )
|
|
.setRolls( ConstantValue.exactly( 1 ) )
|
|
.add( DynamicLoot.dynamicEntry( new ResourceLocation( ComputerCraft.MOD_ID, "computer" ) ) )
|
|
.when( AlternativeLootItemCondition.alternative(
|
|
BlockNamedEntityLootCondition.BUILDER,
|
|
HasComputerIdLootCondition.BUILDER,
|
|
PlayerCreativeLootCondition.BUILDER.invert()
|
|
) )
|
|
).build() );
|
|
}
|
|
}
|