Skip to content

Commit

Permalink
Translate specific messages (GeyserMC#1161)
Browse files Browse the repository at this point in the history
  • Loading branch information
Camotoy authored Aug 16, 2020
1 parent 78e8792 commit b074336
Show file tree
Hide file tree
Showing 2 changed files with 8 additions and 11 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -32,8 +32,7 @@
import com.github.steveice10.mc.protocol.data.game.entity.player.Hand;
import com.github.steveice10.mc.protocol.data.game.entity.player.PlayerAction;
import com.github.steveice10.mc.protocol.data.game.world.block.BlockFace;
import com.github.steveice10.mc.protocol.data.message.TextMessage;
import com.github.steveice10.mc.protocol.data.message.TranslationMessage;
import com.github.steveice10.mc.protocol.data.message.Message;
import com.github.steveice10.mc.protocol.packet.ingame.client.player.ClientPlayerActionPacket;
import com.github.steveice10.mc.protocol.packet.ingame.client.player.ClientPlayerUseItemPacket;
import com.nukkitx.math.vector.Vector3f;
Expand Down Expand Up @@ -318,13 +317,10 @@ public void updateBedrockMetadata(EntityMetadata entityMetadata, GeyserSession s
}
break;
case 2: // custom name
if (entityMetadata.getValue() instanceof TextMessage) {
TextMessage name = (TextMessage) entityMetadata.getValue();
if (name != null)
metadata.put(EntityData.NAMETAG, MessageUtils.getBedrockMessage(name));
} else if (entityMetadata.getValue() instanceof TranslationMessage) {
TranslationMessage message = (TranslationMessage) entityMetadata.getValue();
if (entityMetadata.getValue() instanceof Message) {
Message message = (Message) entityMetadata.getValue();
if (message != null)
// Always translate even if it's a TextMessage since there could be translatable parameters
metadata.put(EntityData.NAMETAG, MessageUtils.getTranslatedBedrockMessage(message, session.getClientData().getLanguageCode(), true));
}
break;
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -39,15 +39,16 @@ public class JavaTitleTranslator extends PacketTranslator<ServerTitlePacket> {
@Override
public void translate(ServerTitlePacket packet, GeyserSession session) {
SetTitlePacket titlePacket = new SetTitlePacket();
String locale = session.getClientData().getLanguageCode();

switch (packet.getAction()) {
case TITLE:
titlePacket.setType(SetTitlePacket.Type.TITLE);
titlePacket.setText(MessageUtils.getBedrockMessage(packet.getTitle()));
titlePacket.setText(MessageUtils.getTranslatedBedrockMessage(packet.getTitle(), locale));
break;
case SUBTITLE:
titlePacket.setType(SetTitlePacket.Type.SUBTITLE);
titlePacket.setText(MessageUtils.getBedrockMessage(packet.getTitle()));
titlePacket.setText(MessageUtils.getTranslatedBedrockMessage(packet.getTitle(), locale));
break;
case CLEAR:
case RESET:
Expand All @@ -56,7 +57,7 @@ public void translate(ServerTitlePacket packet, GeyserSession session) {
break;
case ACTION_BAR:
titlePacket.setType(SetTitlePacket.Type.ACTIONBAR);
titlePacket.setText(MessageUtils.getBedrockMessage(packet.getTitle()));
titlePacket.setText(MessageUtils.getTranslatedBedrockMessage(packet.getTitle(), locale));
break;
case TIMES:
titlePacket.setFadeInTime(packet.getFadeIn());
Expand Down

0 comments on commit b074336

Please sign in to comment.