mirror of
				https://github.com/SquidDev-CC/CC-Tweaked
				synced 2025-10-24 18:37:38 +00:00 
			
		
		
		
	Merge pull request #1761 from cc-tweaked/feature/no-play-record
Prevent playing music discs with speaker.playSound
This commit is contained in:
		| @@ -18,16 +18,18 @@ import dan200.computercraft.shared.network.client.SpeakerMoveClientMessage; | |||||||
| import dan200.computercraft.shared.network.client.SpeakerPlayClientMessage; | import dan200.computercraft.shared.network.client.SpeakerPlayClientMessage; | ||||||
| import dan200.computercraft.shared.network.client.SpeakerStopClientMessage; | import dan200.computercraft.shared.network.client.SpeakerStopClientMessage; | ||||||
| import dan200.computercraft.shared.network.server.ServerNetworking; | import dan200.computercraft.shared.network.server.ServerNetworking; | ||||||
|  | import dan200.computercraft.shared.platform.PlatformHelper; | ||||||
| import dan200.computercraft.shared.util.PauseAwareTimer; | import dan200.computercraft.shared.util.PauseAwareTimer; | ||||||
| import net.minecraft.ResourceLocationException; |  | ||||||
| import net.minecraft.core.BlockPos; | import net.minecraft.core.BlockPos; | ||||||
| import net.minecraft.core.Holder; | import net.minecraft.core.Holder; | ||||||
|  | import net.minecraft.core.registries.Registries; | ||||||
| import net.minecraft.network.protocol.game.ClientboundSoundPacket; | import net.minecraft.network.protocol.game.ClientboundSoundPacket; | ||||||
| import net.minecraft.resources.ResourceLocation; | import net.minecraft.resources.ResourceLocation; | ||||||
| import net.minecraft.server.level.ServerLevel; | import net.minecraft.server.level.ServerLevel; | ||||||
| import net.minecraft.sounds.SoundEvent; | import net.minecraft.sounds.SoundEvent; | ||||||
| import net.minecraft.sounds.SoundSource; | import net.minecraft.sounds.SoundSource; | ||||||
| import net.minecraft.util.Mth; | import net.minecraft.util.Mth; | ||||||
|  | import net.minecraft.world.item.RecordItem; | ||||||
| import net.minecraft.world.level.block.state.properties.NoteBlockInstrument; | import net.minecraft.world.level.block.state.properties.NoteBlockInstrument; | ||||||
| 
 | 
 | ||||||
| import javax.annotation.Nullable; | import javax.annotation.Nullable; | ||||||
| @@ -252,15 +254,15 @@ public abstract class SpeakerPeripheral implements IPeripheral { | |||||||
|         var volume = (float) clampVolume(checkFinite(1, volumeA.orElse(1.0))); |         var volume = (float) clampVolume(checkFinite(1, volumeA.orElse(1.0))); | ||||||
|         var pitch = (float) checkFinite(2, pitchA.orElse(1.0)); |         var pitch = (float) checkFinite(2, pitchA.orElse(1.0)); | ||||||
| 
 | 
 | ||||||
|         ResourceLocation identifier; |         var identifier = ResourceLocation.tryParse(name); | ||||||
|         try { |         if (identifier == null) throw new LuaException("Malformed sound name '" + name + "' "); | ||||||
|             identifier = new ResourceLocation(name); | 
 | ||||||
|         } catch (ResourceLocationException e) { |         // Prevent playing music discs. | ||||||
|             throw new LuaException("Malformed sound name '" + name + "' "); |         var soundEvent = PlatformHelper.get().tryGetRegistryObject(Registries.SOUND_EVENT, identifier); | ||||||
|         } |         if (soundEvent != null && RecordItem.getBySound(soundEvent) != null) return false; | ||||||
| 
 | 
 | ||||||
|         synchronized (lock) { |         synchronized (lock) { | ||||||
|             if (pendingSound != null | (dfpwmState != null && dfpwmState.isPlaying())) return false; |             if (pendingSound != null || (dfpwmState != null && dfpwmState.isPlaying())) return false; | ||||||
|             dfpwmState = null; |             dfpwmState = null; | ||||||
|             pendingSound = new PendingSound<>(identifier, volume, pitch); |             pendingSound = new PendingSound<>(identifier, volume, pitch); | ||||||
|             return true; |             return true; | ||||||
|   | |||||||
| @@ -29,4 +29,15 @@ class Speaker_Test { | |||||||
|             } |             } | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  | 
 | ||||||
|  |     /** | ||||||
|  |      * [SpeakerPeripheral.playSound] will not play records. | ||||||
|  |      */ | ||||||
|  |     @GameTest | ||||||
|  |     fun Will_not_play_record(helper: GameTestHelper) = helper.sequence { | ||||||
|  |         thenOnComputer { | ||||||
|  |             callPeripheral("right", "playSound", SoundEvents.MUSIC_DISC_PIGSTEP.location.toString()) | ||||||
|  |                 .assertArrayEquals(false) | ||||||
|  |         } | ||||||
|  |     } | ||||||
| } | } | ||||||
|   | |||||||
							
								
								
									
										138
									
								
								projects/common/src/testMod/resources/data/cctest/structures/speaker_test.will_not_play_record.snbt
									
									
									
										generated
									
									
									
										Normal file
									
								
							
							
						
						
									
										138
									
								
								projects/common/src/testMod/resources/data/cctest/structures/speaker_test.will_not_play_record.snbt
									
									
									
										generated
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,138 @@ | |||||||
|  | { | ||||||
|  |     DataVersion: 3465, | ||||||
|  |     size: [5, 5, 5], | ||||||
|  |     data: [ | ||||||
|  |         {pos: [0, 0, 0], state: "minecraft:polished_andesite"}, | ||||||
|  |         {pos: [0, 0, 1], state: "minecraft:polished_andesite"}, | ||||||
|  |         {pos: [0, 0, 2], state: "minecraft:polished_andesite"}, | ||||||
|  |         {pos: [0, 0, 3], state: "minecraft:polished_andesite"}, | ||||||
|  |         {pos: [0, 0, 4], state: "minecraft:polished_andesite"}, | ||||||
|  |         {pos: [1, 0, 0], state: "minecraft:polished_andesite"}, | ||||||
|  |         {pos: [1, 0, 1], state: "minecraft:polished_andesite"}, | ||||||
|  |         {pos: [1, 0, 2], state: "minecraft:polished_andesite"}, | ||||||
|  |         {pos: [1, 0, 3], state: "minecraft:polished_andesite"}, | ||||||
|  |         {pos: [1, 0, 4], state: "minecraft:polished_andesite"}, | ||||||
|  |         {pos: [2, 0, 0], state: "minecraft:polished_andesite"}, | ||||||
|  |         {pos: [2, 0, 1], state: "minecraft:polished_andesite"}, | ||||||
|  |         {pos: [2, 0, 2], state: "minecraft:polished_andesite"}, | ||||||
|  |         {pos: [2, 0, 3], state: "minecraft:polished_andesite"}, | ||||||
|  |         {pos: [2, 0, 4], state: "minecraft:polished_andesite"}, | ||||||
|  |         {pos: [3, 0, 0], state: "minecraft:polished_andesite"}, | ||||||
|  |         {pos: [3, 0, 1], state: "minecraft:polished_andesite"}, | ||||||
|  |         {pos: [3, 0, 2], state: "minecraft:polished_andesite"}, | ||||||
|  |         {pos: [3, 0, 3], state: "minecraft:polished_andesite"}, | ||||||
|  |         {pos: [3, 0, 4], state: "minecraft:polished_andesite"}, | ||||||
|  |         {pos: [4, 0, 0], state: "minecraft:polished_andesite"}, | ||||||
|  |         {pos: [4, 0, 1], state: "minecraft:polished_andesite"}, | ||||||
|  |         {pos: [4, 0, 2], state: "minecraft:polished_andesite"}, | ||||||
|  |         {pos: [4, 0, 3], state: "minecraft:polished_andesite"}, | ||||||
|  |         {pos: [4, 0, 4], state: "minecraft:polished_andesite"}, | ||||||
|  |         {pos: [0, 1, 0], state: "minecraft:air"}, | ||||||
|  |         {pos: [0, 1, 1], state: "minecraft:air"}, | ||||||
|  |         {pos: [0, 1, 2], state: "minecraft:air"}, | ||||||
|  |         {pos: [0, 1, 3], state: "minecraft:air"}, | ||||||
|  |         {pos: [0, 1, 4], state: "minecraft:air"}, | ||||||
|  |         {pos: [1, 1, 0], state: "minecraft:air"}, | ||||||
|  |         {pos: [1, 1, 1], state: "minecraft:air"}, | ||||||
|  |         {pos: [1, 1, 2], state: "computercraft:speaker{facing:north}", nbt: {id: "computercraft:speaker"}}, | ||||||
|  |         {pos: [1, 1, 3], state: "minecraft:air"}, | ||||||
|  |         {pos: [1, 1, 4], state: "minecraft:air"}, | ||||||
|  |         {pos: [2, 1, 0], state: "minecraft:air"}, | ||||||
|  |         {pos: [2, 1, 1], state: "minecraft:air"}, | ||||||
|  |         {pos: [2, 1, 2], state: "computercraft:computer_normal{facing:north,state:on}", nbt: {ComputerId: 1, Label: "speaker_test.will_not_play_record", On: 1b, id: "computercraft:computer_normal"}}, | ||||||
|  |         {pos: [2, 1, 3], state: "minecraft:air"}, | ||||||
|  |         {pos: [2, 1, 4], state: "minecraft:air"}, | ||||||
|  |         {pos: [3, 1, 0], state: "minecraft:air"}, | ||||||
|  |         {pos: [3, 1, 1], state: "minecraft:air"}, | ||||||
|  |         {pos: [3, 1, 2], state: "minecraft:air"}, | ||||||
|  |         {pos: [3, 1, 3], state: "minecraft:air"}, | ||||||
|  |         {pos: [3, 1, 4], state: "minecraft:air"}, | ||||||
|  |         {pos: [4, 1, 0], state: "minecraft:air"}, | ||||||
|  |         {pos: [4, 1, 1], state: "minecraft:air"}, | ||||||
|  |         {pos: [4, 1, 2], state: "minecraft:air"}, | ||||||
|  |         {pos: [4, 1, 3], state: "minecraft:air"}, | ||||||
|  |         {pos: [4, 1, 4], state: "minecraft:air"}, | ||||||
|  |         {pos: [0, 2, 0], state: "minecraft:air"}, | ||||||
|  |         {pos: [0, 2, 1], state: "minecraft:air"}, | ||||||
|  |         {pos: [0, 2, 2], state: "minecraft:air"}, | ||||||
|  |         {pos: [0, 2, 3], state: "minecraft:air"}, | ||||||
|  |         {pos: [0, 2, 4], state: "minecraft:air"}, | ||||||
|  |         {pos: [1, 2, 0], state: "minecraft:air"}, | ||||||
|  |         {pos: [1, 2, 1], state: "minecraft:air"}, | ||||||
|  |         {pos: [1, 2, 2], state: "minecraft:air"}, | ||||||
|  |         {pos: [1, 2, 3], state: "minecraft:air"}, | ||||||
|  |         {pos: [1, 2, 4], state: "minecraft:air"}, | ||||||
|  |         {pos: [2, 2, 0], state: "minecraft:air"}, | ||||||
|  |         {pos: [2, 2, 1], state: "minecraft:air"}, | ||||||
|  |         {pos: [2, 2, 2], state: "minecraft:air"}, | ||||||
|  |         {pos: [2, 2, 3], state: "minecraft:air"}, | ||||||
|  |         {pos: [2, 2, 4], state: "minecraft:air"}, | ||||||
|  |         {pos: [3, 2, 0], state: "minecraft:air"}, | ||||||
|  |         {pos: [3, 2, 1], state: "minecraft:air"}, | ||||||
|  |         {pos: [3, 2, 2], state: "minecraft:air"}, | ||||||
|  |         {pos: [3, 2, 3], state: "minecraft:air"}, | ||||||
|  |         {pos: [3, 2, 4], state: "minecraft:air"}, | ||||||
|  |         {pos: [4, 2, 0], state: "minecraft:air"}, | ||||||
|  |         {pos: [4, 2, 1], state: "minecraft:air"}, | ||||||
|  |         {pos: [4, 2, 2], state: "minecraft:air"}, | ||||||
|  |         {pos: [4, 2, 3], state: "minecraft:air"}, | ||||||
|  |         {pos: [4, 2, 4], state: "minecraft:air"}, | ||||||
|  |         {pos: [0, 3, 0], state: "minecraft:air"}, | ||||||
|  |         {pos: [0, 3, 1], state: "minecraft:air"}, | ||||||
|  |         {pos: [0, 3, 2], state: "minecraft:air"}, | ||||||
|  |         {pos: [0, 3, 3], state: "minecraft:air"}, | ||||||
|  |         {pos: [0, 3, 4], state: "minecraft:air"}, | ||||||
|  |         {pos: [1, 3, 0], state: "minecraft:air"}, | ||||||
|  |         {pos: [1, 3, 1], state: "minecraft:air"}, | ||||||
|  |         {pos: [1, 3, 2], state: "minecraft:air"}, | ||||||
|  |         {pos: [1, 3, 3], state: "minecraft:air"}, | ||||||
|  |         {pos: [1, 3, 4], state: "minecraft:air"}, | ||||||
|  |         {pos: [2, 3, 0], state: "minecraft:air"}, | ||||||
|  |         {pos: [2, 3, 1], state: "minecraft:air"}, | ||||||
|  |         {pos: [2, 3, 2], state: "minecraft:air"}, | ||||||
|  |         {pos: [2, 3, 3], state: "minecraft:air"}, | ||||||
|  |         {pos: [2, 3, 4], state: "minecraft:air"}, | ||||||
|  |         {pos: [3, 3, 0], state: "minecraft:air"}, | ||||||
|  |         {pos: [3, 3, 1], state: "minecraft:air"}, | ||||||
|  |         {pos: [3, 3, 2], state: "minecraft:air"}, | ||||||
|  |         {pos: [3, 3, 3], state: "minecraft:air"}, | ||||||
|  |         {pos: [3, 3, 4], state: "minecraft:air"}, | ||||||
|  |         {pos: [4, 3, 0], state: "minecraft:air"}, | ||||||
|  |         {pos: [4, 3, 1], state: "minecraft:air"}, | ||||||
|  |         {pos: [4, 3, 2], state: "minecraft:air"}, | ||||||
|  |         {pos: [4, 3, 3], state: "minecraft:air"}, | ||||||
|  |         {pos: [4, 3, 4], state: "minecraft:air"}, | ||||||
|  |         {pos: [0, 4, 0], state: "minecraft:air"}, | ||||||
|  |         {pos: [0, 4, 1], state: "minecraft:air"}, | ||||||
|  |         {pos: [0, 4, 2], state: "minecraft:air"}, | ||||||
|  |         {pos: [0, 4, 3], state: "minecraft:air"}, | ||||||
|  |         {pos: [0, 4, 4], state: "minecraft:air"}, | ||||||
|  |         {pos: [1, 4, 0], state: "minecraft:air"}, | ||||||
|  |         {pos: [1, 4, 1], state: "minecraft:air"}, | ||||||
|  |         {pos: [1, 4, 2], state: "minecraft:air"}, | ||||||
|  |         {pos: [1, 4, 3], state: "minecraft:air"}, | ||||||
|  |         {pos: [1, 4, 4], state: "minecraft:air"}, | ||||||
|  |         {pos: [2, 4, 0], state: "minecraft:air"}, | ||||||
|  |         {pos: [2, 4, 1], state: "minecraft:air"}, | ||||||
|  |         {pos: [2, 4, 2], state: "minecraft:air"}, | ||||||
|  |         {pos: [2, 4, 3], state: "minecraft:air"}, | ||||||
|  |         {pos: [2, 4, 4], state: "minecraft:air"}, | ||||||
|  |         {pos: [3, 4, 0], state: "minecraft:air"}, | ||||||
|  |         {pos: [3, 4, 1], state: "minecraft:air"}, | ||||||
|  |         {pos: [3, 4, 2], state: "minecraft:air"}, | ||||||
|  |         {pos: [3, 4, 3], state: "minecraft:air"}, | ||||||
|  |         {pos: [3, 4, 4], state: "minecraft:air"}, | ||||||
|  |         {pos: [4, 4, 0], state: "minecraft:air"}, | ||||||
|  |         {pos: [4, 4, 1], state: "minecraft:air"}, | ||||||
|  |         {pos: [4, 4, 2], state: "minecraft:air"}, | ||||||
|  |         {pos: [4, 4, 3], state: "minecraft:air"}, | ||||||
|  |         {pos: [4, 4, 4], state: "minecraft:air"} | ||||||
|  |     ], | ||||||
|  |     entities: [], | ||||||
|  |     palette: [ | ||||||
|  |         "minecraft:polished_andesite", | ||||||
|  |         "minecraft:air", | ||||||
|  |         "computercraft:speaker{facing:north}", | ||||||
|  |         "computercraft:computer_normal{facing:north,state:on}" | ||||||
|  |     ] | ||||||
|  | } | ||||||
		Reference in New Issue
	
	Block a user
	 Jonathan Coates
					Jonathan Coates