mirror of
				https://github.com/SquidDev-CC/CC-Tweaked
				synced 2025-10-25 02:47:39 +00:00 
			
		
		
		
	Remove MixinLevel
This mixin isn't needed since 1.17 changes to BlockEntities, and doesn't do anything in its current state.
This commit is contained in:
		| @@ -1,59 +0,0 @@ | ||||
| /* | ||||
|  * 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.fabric.mixin; | ||||
|  | ||||
| import dan200.computercraft.shared.common.TileGeneric; | ||||
| import net.minecraft.world.level.Level; | ||||
| import net.minecraft.world.level.block.entity.BlockEntity; | ||||
| import org.spongepowered.asm.mixin.Mixin; | ||||
| import org.spongepowered.asm.mixin.Shadow; | ||||
| import org.spongepowered.asm.mixin.injection.At; | ||||
| import org.spongepowered.asm.mixin.injection.Inject; | ||||
| import org.spongepowered.asm.mixin.injection.callback.CallbackInfo; | ||||
|  | ||||
| import javax.annotation.Nullable; | ||||
| import java.util.Collection; | ||||
|  | ||||
| /** | ||||
|  * Horrible bodge to ensure a {@link BlockEntity}'s world is always present when setting a TE during another TE's tick. | ||||
|  * | ||||
|  * Forge does this, this is just a bodge to get Fabric in line with that behaviour. | ||||
|  */ | ||||
| @Mixin( Level.class ) | ||||
| public class MixinLevel | ||||
| { | ||||
|     @Shadow | ||||
|     protected boolean tickingBlockEntities; | ||||
|  | ||||
|     @Inject( method = "setBlockEntity", at = @At( "HEAD" ) ) | ||||
|     public void setBlockEntity( @Nullable BlockEntity entity, CallbackInfo info ) | ||||
|     { | ||||
|         if( entity != null && !entity.isRemoved() && entity.getLevel() != null && entity.getLevel().isInWorldBounds( entity.getBlockPos() ) && tickingBlockEntities ) | ||||
|         { | ||||
|             setWorld( entity, this ); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     private static void setWorld( BlockEntity entity, Object world ) | ||||
|     { | ||||
|         if( entity.getLevel() != world && entity instanceof TileGeneric ) | ||||
|         { | ||||
|             entity.setLevel( (Level) world ); //TODO why? | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     //    @Inject( method = "addBlockEntities", at = @At( "HEAD" ) ) | ||||
|     public void addBlockEntities( Collection<BlockEntity> entities, CallbackInfo info ) | ||||
|     { | ||||
|         if( tickingBlockEntities ) | ||||
|         { | ||||
|             for( BlockEntity entity : entities ) | ||||
|             { | ||||
|                 setWorld( entity, this ); | ||||
|             } | ||||
|         } | ||||
|     } | ||||
| } | ||||
| @@ -9,7 +9,6 @@ | ||||
|         "MixinBlock", | ||||
|         "MixinChunkMap", | ||||
|         "MixinEntity", | ||||
|         "MixinLevel", | ||||
|         "MixinMatrix4f", | ||||
|         "MixinServerLevel", | ||||
|         "MixinServerPlayerGameMode" | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 Toad-Dev
					Toad-Dev