geforkt von Mirrors/Paper
57 Zeilen
3.1 KiB
Diff
57 Zeilen
3.1 KiB
Diff
|
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
||
|
From: Isaac Moore <rmsy@me.com>
|
||
|
Date: Tue, 19 Apr 2016 14:09:31 -0500
|
||
|
Subject: [PATCH] Implement PlayerLocaleChangeEvent
|
||
|
|
||
|
|
||
|
diff --git a/src/main/java/net/minecraft/server/level/ServerPlayer.java b/src/main/java/net/minecraft/server/level/ServerPlayer.java
|
||
|
index e978a91636192cd00ef8bab9b8411fda39aebbb7..32ecdb19c377952b553297548c7f3ff32054ee2a 100644
|
||
|
--- a/src/main/java/net/minecraft/server/level/ServerPlayer.java
|
||
|
+++ b/src/main/java/net/minecraft/server/level/ServerPlayer.java
|
||
|
@@ -214,7 +214,7 @@ public class ServerPlayer extends Player {
|
||
|
private int levitationStartTime;
|
||
|
private boolean disconnected;
|
||
|
private int requestedViewDistance;
|
||
|
- public String language = "en_us"; // CraftBukkit - default
|
||
|
+ public String language = null; // CraftBukkit - default // Paper - default to null
|
||
|
public java.util.Locale adventure$locale = java.util.Locale.US; // Paper
|
||
|
@Nullable
|
||
|
private Vec3 startingToFallPosition;
|
||
|
@@ -264,7 +264,7 @@ public class ServerPlayer extends Player {
|
||
|
this.lastActionTime = Util.getMillis();
|
||
|
this.recipeBook = new ServerRecipeBook();
|
||
|
this.requestedViewDistance = 2;
|
||
|
- this.language = "en_us";
|
||
|
+ this.language = null; // Paper - default to null
|
||
|
this.lastSectionPos = SectionPos.of(0, 0, 0);
|
||
|
this.chunkTrackingView = ChunkTrackingView.EMPTY;
|
||
|
this.respawnDimension = Level.OVERWORLD;
|
||
|
@@ -1818,9 +1818,10 @@ public class ServerPlayer extends Player {
|
||
|
PlayerChangedMainHandEvent event = new PlayerChangedMainHandEvent(this.getBukkitEntity(), getMainArm() == HumanoidArm.LEFT ? MainHand.LEFT : MainHand.RIGHT);
|
||
|
this.server.server.getPluginManager().callEvent(event);
|
||
|
}
|
||
|
- if (!this.language.equals(clientOptions.language())) {
|
||
|
+ if (this.language == null || !this.language.equals(clientOptions.language())) { // Paper
|
||
|
PlayerLocaleChangeEvent event = new PlayerLocaleChangeEvent(this.getBukkitEntity(), clientOptions.language());
|
||
|
this.server.server.getPluginManager().callEvent(event);
|
||
|
+ this.server.server.getPluginManager().callEvent(new com.destroystokyo.paper.event.player.PlayerLocaleChangeEvent(this.getBukkitEntity(), this.language, clientOptions.language())); // Paper
|
||
|
}
|
||
|
// CraftBukkit end
|
||
|
this.language = clientOptions.language();
|
||
|
diff --git a/src/main/java/org/bukkit/craftbukkit/entity/CraftPlayer.java b/src/main/java/org/bukkit/craftbukkit/entity/CraftPlayer.java
|
||
|
index a6eca427d04cfbdfb8af277a72e5866e7c14d30f..a67a3f13c2b142205b76a6ff478a606fe7546925 100644
|
||
|
--- a/src/main/java/org/bukkit/craftbukkit/entity/CraftPlayer.java
|
||
|
+++ b/src/main/java/org/bukkit/craftbukkit/entity/CraftPlayer.java
|
||
|
@@ -2203,7 +2203,10 @@ public class CraftPlayer extends CraftHumanEntity implements Player {
|
||
|
|
||
|
@Override
|
||
|
public String getLocale() {
|
||
|
- return this.getHandle().language;
|
||
|
+ // Paper start - Locale change event
|
||
|
+ final String locale = this.getHandle().language;
|
||
|
+ return locale != null ? locale : "en_us";
|
||
|
+ // Paper end
|
||
|
}
|
||
|
|
||
|
// Paper start
|