Skip to content

Commit dca8ecf

Browse files
Fix notes color from note block being wrong in 1.13->1.12 (#680)
Closes #679
1 parent 170e5f2 commit dca8ecf

File tree

4 files changed

+77
-1
lines changed

4 files changed

+77
-1
lines changed

common/src/main/java/com/viaversion/viabackwards/protocol/protocol1_12_2to1_13/Protocol1_12_2To1_13.java

Lines changed: 3 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -29,6 +29,7 @@
2929
import com.viaversion.viabackwards.protocol.protocol1_12_2to1_13.packets.SoundPackets1_13;
3030
import com.viaversion.viabackwards.protocol.protocol1_12_2to1_13.providers.BackwardsBlockEntityProvider;
3131
import com.viaversion.viabackwards.protocol.protocol1_12_2to1_13.storage.BackwardsBlockStorage;
32+
import com.viaversion.viabackwards.protocol.protocol1_12_2to1_13.storage.NoteBlockStorage;
3233
import com.viaversion.viabackwards.protocol.protocol1_12_2to1_13.storage.PlayerPositionStorage1_13;
3334
import com.viaversion.viabackwards.protocol.protocol1_12_2to1_13.storage.TabCompleteStorage;
3435
import com.viaversion.viaversion.api.Via;
@@ -124,6 +125,8 @@ public void init(UserConnection user) {
124125
if (ViaBackwards.getConfig().isFix1_13FacePlayer() && !user.has(PlayerPositionStorage1_13.class)) {
125126
user.put(new PlayerPositionStorage1_13());
126127
}
128+
129+
user.put(new NoteBlockStorage());
127130
}
128131

129132
@Override

common/src/main/java/com/viaversion/viabackwards/protocol/protocol1_12_2to1_13/packets/BlockItemPackets1_13.java

Lines changed: 19 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -25,6 +25,7 @@
2525
import com.viaversion.viabackwards.protocol.protocol1_12_2to1_13.block_entity_handlers.FlowerPotHandler;
2626
import com.viaversion.viabackwards.protocol.protocol1_12_2to1_13.providers.BackwardsBlockEntityProvider;
2727
import com.viaversion.viabackwards.protocol.protocol1_12_2to1_13.storage.BackwardsBlockStorage;
28+
import com.viaversion.viabackwards.protocol.protocol1_12_2to1_13.storage.NoteBlockStorage;
2829
import com.viaversion.viaversion.api.Via;
2930
import com.viaversion.viaversion.api.connection.UserConnection;
3031
import com.viaversion.viaversion.api.minecraft.BlockChangeRecord;
@@ -56,6 +57,8 @@
5657
import com.viaversion.viaversion.protocols.protocol1_13to1_12_2.data.SpawnEggRewriter;
5758
import com.viaversion.viaversion.util.ComponentUtil;
5859
import com.viaversion.viaversion.util.Key;
60+
import com.viaversion.viaversion.util.Pair;
61+
5962
import java.util.ArrayList;
6063
import java.util.HashMap;
6164
import java.util.List;
@@ -136,6 +139,17 @@ else if (blockId == 472)
136139
else if (blockId >= 483 && blockId <= 498)
137140
blockId = blockId - 483 + 219;
138141

142+
if (blockId == 25) { // Note block
143+
final NoteBlockStorage noteBlockStorage = wrapper.user().get(NoteBlockStorage.class);
144+
145+
final Position position = wrapper.get(Type.POSITION1_8, 0);
146+
final Pair<Integer, Integer> update = noteBlockStorage.getNoteBlockUpdate(position);
147+
if (update != null) { // Use values from block state update
148+
wrapper.set(Type.UNSIGNED_BYTE, 0, update.key().shortValue());
149+
wrapper.set(Type.UNSIGNED_BYTE, 1, update.value().shortValue());
150+
}
151+
}
152+
139153
wrapper.set(Type.VAR_INT, 0, blockId);
140154
});
141155
}
@@ -189,6 +203,11 @@ public void register() {
189203
int blockState = wrapper.read(Type.VAR_INT);
190204
Position position = wrapper.get(Type.POSITION1_8, 0);
191205

206+
// Note block special treatment
207+
if (blockState >= 249 && blockState <= 748) { // Note block states id range
208+
wrapper.user().get(NoteBlockStorage.class).storeNoteBlockUpdate(position, blockState);
209+
}
210+
192211
// Store blocks
193212
BackwardsBlockStorage storage = wrapper.user().get(BackwardsBlockStorage.class);
194213
storage.checkAndStore(position, blockState);

common/src/main/java/com/viaversion/viabackwards/protocol/protocol1_12_2to1_13/packets/EntityPackets1_13.java

Lines changed: 5 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -25,6 +25,7 @@
2525
import com.viaversion.viabackwards.protocol.protocol1_12_2to1_13.data.PaintingMapping;
2626
import com.viaversion.viabackwards.protocol.protocol1_12_2to1_13.data.ParticleMapping;
2727
import com.viaversion.viabackwards.protocol.protocol1_12_2to1_13.storage.BackwardsBlockStorage;
28+
import com.viaversion.viabackwards.protocol.protocol1_12_2to1_13.storage.NoteBlockStorage;
2829
import com.viaversion.viabackwards.protocol.protocol1_12_2to1_13.storage.PlayerPositionStorage1_13;
2930
import com.viaversion.viaversion.api.minecraft.Particle;
3031
import com.viaversion.viaversion.api.minecraft.entities.EntityType;
@@ -197,7 +198,10 @@ public void register() {
197198
map(Type.INT); // 0 - Dimension ID
198199

199200
handler(getDimensionHandler(0));
200-
handler(wrapper -> wrapper.user().get(BackwardsBlockStorage.class).clear());
201+
handler(wrapper -> {
202+
wrapper.user().get(BackwardsBlockStorage.class).clear();
203+
wrapper.user().get(NoteBlockStorage.class).clear();
204+
});
201205
}
202206
});
203207

Lines changed: 50 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,50 @@
1+
/*
2+
* This file is part of ViaBackwards - https://github.com/ViaVersion/ViaBackwards
3+
* Copyright (C) 2016-2024 ViaVersion and contributors
4+
*
5+
* This program is free software: you can redistribute it and/or modify
6+
* it under the terms of the GNU General Public License as published by
7+
* the Free Software Foundation, either version 3 of the License, or
8+
* (at your option) any later version.
9+
*
10+
* This program is distributed in the hope that it will be useful,
11+
* but WITHOUT ANY WARRANTY; without even the implied warranty of
12+
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13+
* GNU General Public License for more details.
14+
*
15+
* You should have received a copy of the GNU General Public License
16+
* along with this program. If not, see <http://www.gnu.org/licenses/>.
17+
*/
18+
package com.viaversion.viabackwards.protocol.protocol1_12_2to1_13.storage;
19+
20+
import com.viaversion.viaversion.api.connection.StorableObject;
21+
import com.viaversion.viaversion.api.minecraft.Position;
22+
import com.viaversion.viaversion.libs.fastutil.objects.Object2IntMap;
23+
import com.viaversion.viaversion.libs.fastutil.objects.Object2IntOpenHashMap;
24+
import com.viaversion.viaversion.util.Pair;
25+
26+
public class NoteBlockStorage implements StorableObject {
27+
28+
private static final int MAX_NOTE_ID = 24;
29+
30+
private final Object2IntMap<Position> noteBlockUpdates = new Object2IntOpenHashMap<>();
31+
32+
public void storeNoteBlockUpdate(final Position position, final int blockStateId) {
33+
noteBlockUpdates.put(position, blockStateId);
34+
}
35+
36+
public Pair<Integer, Integer> getNoteBlockUpdate(final Position position) {
37+
if (!noteBlockUpdates.containsKey(position)) {
38+
return null;
39+
}
40+
int relativeBlockState = noteBlockUpdates.removeInt(position) - 249;
41+
relativeBlockState = relativeBlockState / 2; // Get rid of powered state
42+
43+
return new Pair<>(relativeBlockState / MAX_NOTE_ID + 1, relativeBlockState % MAX_NOTE_ID + 1);
44+
}
45+
46+
public void clear() {
47+
noteBlockUpdates.clear();
48+
}
49+
50+
}

0 commit comments

Comments
 (0)