WIP 1.18.3: Impl editing of server config in-game

Fixed Battle not checking Player haste/speed status for using
"player_haste_speed" and "player_slow_speed".
This commit is contained in:
Stephen Seo 2022-06-08 19:22:45 +09:00
parent bc598c41b7
commit 28291e5134
4 changed files with 507 additions and 259 deletions

View file

@ -19,8 +19,7 @@ import net.minecraftforge.network.NetworkEvent;
import java.util.UUID;
import java.util.function.Supplier;
public class ClientProxy extends CommonProxy
{
public class ClientProxy extends CommonProxy {
private BattleGui battleGui = null;
private BattleMusic battleMusic = null;
private int battleMusicCount = 0;
@ -28,8 +27,7 @@ public class ClientProxy extends CommonProxy
private Battle localBattle = null;
@Override
protected void initializeClient()
{
protected void initializeClient() {
battleGui = new BattleGui();
battleMusic = null; // will be initialized in postInit()
battleMusicCount = 0;
@ -39,48 +37,40 @@ public class ClientProxy extends CommonProxy
}
@Override
public void setBattleGuiTime(int timeRemaining)
{
public void setBattleGuiTime(int timeRemaining) {
battleGui.setTimeRemaining(timeRemaining);
}
@Override
public void setBattleGuiBattleChanged()
{
public void setBattleGuiBattleChanged() {
battleGui.battleChanged();
}
@Override
public void setBattleGuiAsGui()
{
if(Minecraft.getInstance().screen != battleGui)
{
public void setBattleGuiAsGui() {
if (Minecraft.getInstance().screen != battleGui) {
battleGui.turnEnd();
Minecraft.getInstance().setScreen(battleGui);
}
}
@Override
public void battleGuiTurnBegin()
{
public void battleGuiTurnBegin() {
battleGui.turnBegin();
}
@Override
public void battleGuiTurnEnd()
{
public void battleGuiTurnEnd() {
battleGui.turnEnd();
}
@Override
public void battleStarted()
{
public void battleStarted() {
setBattleGuiAsGui();
}
@Override
public void battleEnded()
{
public void battleEnded() {
localBattle = null;
Minecraft.getInstance().setScreen(null);
stopMusic(true);
@ -89,28 +79,24 @@ public class ClientProxy extends CommonProxy
}
@Override
protected void postInitClient()
{
protected void postInitClient() {
battleMusic = new BattleMusic(getLogger());
}
@Override
public void playBattleMusic()
{
public void playBattleMusic() {
Options gs = Minecraft.getInstance().options;
battleMusic.playBattle(gs.getSoundSourceVolume(SoundSource.MUSIC) * gs.getSoundSourceVolume(SoundSource.MASTER));
}
@Override
public void playSillyMusic()
{
public void playSillyMusic() {
Options gs = Minecraft.getInstance().options;
battleMusic.playSilly(gs.getSoundSourceVolume(SoundSource.MUSIC) * gs.getSoundSourceVolume(SoundSource.MASTER));
}
@Override
public void stopMusic(boolean resumeMCSounds)
{
public void stopMusic(boolean resumeMCSounds) {
battleMusic.stopMusic(resumeMCSounds);
}
@ -118,11 +104,11 @@ public class ClientProxy extends CommonProxy
* Sets what music to play based on type and loaded Config
*/
@Override
public void typeEnteredBattle(String type)
{
public void typeEnteredBattle(String type) {
if (localBattle == null) {
return;
} if(type == null || type.isEmpty() || getConfig().isBattleMusicType(type)) {
}
if (type == null || type.isEmpty() || getConfig().isBattleMusicType(type)) {
++battleMusicCount;
} else if (getConfig().isSillyMusicType(type)) {
++sillyMusicCount;
@ -133,10 +119,8 @@ public class ClientProxy extends CommonProxy
}
@Override
public void typeLeftBattle(String type)
{
if(localBattle == null || localBattle.getSideA().isEmpty() || localBattle.getSideB().isEmpty())
{
public void typeLeftBattle(String type) {
if (localBattle == null || localBattle.getSideA().isEmpty() || localBattle.getSideB().isEmpty()) {
battleMusicCount = 0;
sillyMusicCount = 0;
return;
@ -151,8 +135,7 @@ public class ClientProxy extends CommonProxy
}
@Override
public void displayString(String message)
{
public void displayString(String message) {
Component parentComponent = new TextComponent("");
TextComponent prefix = new TextComponent("TBM: ");
@ -167,8 +150,7 @@ public class ClientProxy extends CommonProxy
}
@Override
public void displayComponent(Component text)
{
public void displayComponent(Component text) {
Component parentComponent = new TextComponent("");
TextComponent prefix = new TextComponent("TBM: ");
@ -180,68 +162,49 @@ public class ClientProxy extends CommonProxy
Minecraft.getInstance().player.sendMessage(parentComponent, new UUID(0, 0));
}
private void checkBattleTypes(boolean entityLeft)
{
private void checkBattleTypes(boolean entityLeft) {
// check that battle is still valid
if (localBattle == null && entityLeft && (localBattle.getSideA().isEmpty() || localBattle.getSideB().isEmpty())) {
return;
}
float percentage = 0.0f;
if(sillyMusicCount == 0 && battleMusicCount == 0)
{
if (sillyMusicCount == 0 && battleMusicCount == 0) {
percentage = 0.0f;
}
else if(battleMusicCount == 0)
{
} else if (battleMusicCount == 0) {
percentage = 100.0f;
}
else
{
} else {
percentage = 100.0f * (float) sillyMusicCount / (float) (sillyMusicCount + battleMusicCount);
}
if(percentage >= (float)getConfig().getSillyMusicThreshold())
{
if(battleMusic.isPlaying())
{
if(!battleMusic.isPlayingSilly() && battleMusic.hasSillyMusic())
{
if (percentage >= (float) getConfig().getSillyMusicThreshold()) {
if (battleMusic.isPlaying()) {
if (!battleMusic.isPlayingSilly() && battleMusic.hasSillyMusic()) {
stopMusic(false);
playSillyMusic();
}
}
else if(battleMusic.hasSillyMusic())
{
} else if (battleMusic.hasSillyMusic()) {
playSillyMusic();
}
}
else
{
if(battleMusic.isPlaying())
{
if(battleMusic.isPlayingSilly() && battleMusic.hasBattleMusic())
{
} else {
if (battleMusic.isPlaying()) {
if (battleMusic.isPlayingSilly() && battleMusic.hasBattleMusic()) {
stopMusic(false);
playBattleMusic();
}
}
else if(battleMusic.hasBattleMusic())
{
} else if (battleMusic.hasBattleMusic()) {
playBattleMusic();
}
}
}
@Override
public Battle getLocalBattle()
{
public Battle getLocalBattle() {
return localBattle;
}
@Override
public void createLocalBattle(int id)
{
public void createLocalBattle(int id) {
localBattle = new Battle(null, id, null, null, false, Minecraft.getInstance().level.dimension());
}
@ -256,57 +219,44 @@ public class ClientProxy extends CommonProxy
PacketBattleMessage pkt = (PacketBattleMessage) msg;
Entity fromEntity = getEntity(pkt.getEntityIDFrom(), pkt.getDimension());
Component from = new TextComponent("Unknown");
if(fromEntity != null)
{
if (fromEntity != null) {
from = fromEntity.getDisplayName();
}
else if(TurnBasedMinecraftMod.proxy.getLocalBattle() != null)
{
} else if (TurnBasedMinecraftMod.proxy.getLocalBattle() != null) {
fromEntity = TurnBasedMinecraftMod.proxy.getLocalBattle().getCombatantEntity(pkt.getEntityIDFrom());
if(fromEntity != null)
{
if (fromEntity != null) {
from = fromEntity.getDisplayName();
}
}
Entity toEntity = TurnBasedMinecraftMod.proxy.getEntity(pkt.getEntityIDTo(), pkt.getDimension());
Component to = new TextComponent("Unknown");
if(toEntity != null)
{
if (toEntity != null) {
to = toEntity.getDisplayName();
}
else if(TurnBasedMinecraftMod.proxy.getLocalBattle() != null)
{
} else if (TurnBasedMinecraftMod.proxy.getLocalBattle() != null) {
toEntity = TurnBasedMinecraftMod.proxy.getLocalBattle().getCombatantEntity(pkt.getEntityIDTo());
if(toEntity != null)
{
if (toEntity != null) {
to = toEntity.getDisplayName();
}
}
Component parentComponent = new TextComponent("");
switch(pkt.getMessageType())
{
switch (pkt.getMessageType()) {
case ENTERED:
parentComponent.getSiblings().add(from);
parentComponent.getSiblings().add(new TextComponent(" entered battle!"));
TurnBasedMinecraftMod.proxy.displayComponent(parentComponent);
if(TurnBasedMinecraftMod.proxy.getLocalBattle() == null || TurnBasedMinecraftMod.proxy.getLocalBattle().getId() != pkt.getAmount())
{
if (TurnBasedMinecraftMod.proxy.getLocalBattle() == null || TurnBasedMinecraftMod.proxy.getLocalBattle().getId() != pkt.getAmount()) {
TurnBasedMinecraftMod.proxy.createLocalBattle(pkt.getAmount());
}
TurnBasedMinecraftMod.proxy.battleStarted();
TurnBasedMinecraftMod.proxy.typeEnteredBattle(pkt.getCustom());
break;
case FLEE:
if(pkt.getAmount() != 0)
{
if (pkt.getAmount() != 0) {
parentComponent.getSiblings().add(from);
parentComponent.getSiblings().add(new TextComponent(" fled battle!"));
TurnBasedMinecraftMod.proxy.displayComponent(parentComponent);
TurnBasedMinecraftMod.proxy.typeLeftBattle(pkt.getCustom());
}
else
{
} else {
parentComponent.getSiblings().add(from);
parentComponent.getSiblings().add(new TextComponent(" tried to flee battle but failed!"));
TurnBasedMinecraftMod.proxy.displayComponent(parentComponent);
@ -366,22 +316,18 @@ public class ClientProxy extends CommonProxy
break;
case USED_ITEM:
parentComponent.getSiblings().add(from);
switch(PacketBattleMessage.UsedItemAction.valueOf(pkt.getAmount()))
{
switch (PacketBattleMessage.UsedItemAction.valueOf(pkt.getAmount())) {
case USED_NOTHING:
parentComponent.getSiblings().add(new TextComponent(" tried to use nothing!"));
TurnBasedMinecraftMod.proxy.displayComponent(parentComponent);
break;
case USED_INVALID:
if(pkt.getCustom().length() > 0)
{
if (pkt.getCustom().length() > 0) {
parentComponent.getSiblings().add(new TextComponent(" tried to consume "));
parentComponent.getSiblings().add(new TextComponent(pkt.getCustom()));
parentComponent.getSiblings().add(new TextComponent(" and failed!"));
TurnBasedMinecraftMod.proxy.displayComponent(parentComponent);
}
else
{
} else {
parentComponent.getSiblings().add(new TextComponent(" tried to consume an invalid item and failed!"));
TurnBasedMinecraftMod.proxy.displayComponent(parentComponent);
}
@ -405,28 +351,21 @@ public class ClientProxy extends CommonProxy
TurnBasedMinecraftMod.proxy.battleGuiTurnBegin();
break;
case TURN_END:
if(TurnBasedMinecraftMod.proxy.getLocalBattle() != null)
{
if(pkt.getAmount() == 0)
{
if (TurnBasedMinecraftMod.proxy.getLocalBattle() != null) {
if (pkt.getAmount() == 0) {
TurnBasedMinecraftMod.proxy.displayString("The turn ended!");
}
else
{
} else {
TurnBasedMinecraftMod.proxy.displayString("The turn ended (abnormally due to internal error)!");
}
}
TurnBasedMinecraftMod.proxy.battleGuiTurnEnd();
break;
case SWITCHED_ITEM:
if(pkt.getAmount() != 0)
{
if (pkt.getAmount() != 0) {
parentComponent.getSiblings().add(from);
parentComponent.getSiblings().add(new TextComponent(" switched to a different item!"));
TurnBasedMinecraftMod.proxy.displayComponent(parentComponent);
}
else
{
} else {
parentComponent.getSiblings().add(from);
parentComponent.getSiblings().add(new TextComponent(" switched to a different item but failed because it was invalid!"));
TurnBasedMinecraftMod.proxy.displayComponent(parentComponent);
@ -494,10 +433,8 @@ public class ClientProxy extends CommonProxy
} else if (msg.getClass() == PacketEditingMessage.class) {
PacketEditingMessage pkt = (PacketEditingMessage) msg;
Component parentComponent = new TextComponent("");
switch(pkt.getType())
{
case ATTACK_ENTITY:
{
switch (pkt.getType()) {
case ATTACK_ENTITY: {
TextComponent text = new TextComponent("Attack the entity you want to edit for TurnBasedMinecraftMod. ");
text.setStyle(text.getStyle().withColor(TextColor.fromRgb(0xFFFFFFFF)).withBold(false));
@ -509,8 +446,7 @@ public class ClientProxy extends CommonProxy
TurnBasedMinecraftMod.proxy.displayComponent(parentComponent);
break;
}
case PICK_EDIT:
{
case PICK_EDIT: {
TextComponent text = new TextComponent("Edit what value? ");
text.setStyle(text.getStyle().withColor(TextColor.fromRgb(0xFFFFFFFF)).withBold(false));
@ -640,13 +576,12 @@ public class ClientProxy extends CommonProxy
TurnBasedMinecraftMod.proxy.displayComponent(parentComponent);
break;
}
case SERVER_EDIT:
{
case SERVER_EDIT: {
TextComponent parent = new TextComponent("Edit what server value? ");
parent.setStyle(parent.getStyle().withColor(TextColor.fromRgb(0xFFFFFFFF)).withBold(false));
TextComponent sub = new TextComponent("leave_battle_cooldown ");
sub.setStyle(sub.getStyle().withColor(0xFFFFFF00));
sub.setStyle(sub.getStyle().withColor(0xFFFFFF00).withBold(true));
for (int i = 1; i <= 10; ++i) {
TextComponent value = new TextComponent(String.valueOf(i) + ' ');
@ -662,7 +597,7 @@ public class ClientProxy extends CommonProxy
parent.append(sub);
sub = new TextComponent("aggro_start_battle_max_distance ");
sub.setStyle(sub.getStyle().withColor(0xFFFFFF00));
sub.setStyle(sub.getStyle().withColor(0xFFFFFF00).withBold(true));
parent.append(sub);
sub = new TextComponent("5 ");
@ -699,7 +634,8 @@ public class ClientProxy extends CommonProxy
.withColor(0xFFFFFF00)
.withHoverEvent(new HoverEvent(
HoverEvent.Action.SHOW_TEXT,
new TextComponent("If enabled, battles only start on a hit, not including mobs targeting players"))));
new TextComponent("If enabled, battles only start on a hit, not including mobs targeting players")))
.withBold(true));
parent.append(sub);
sub = new TextComponent("true ");
@ -725,7 +661,8 @@ public class ClientProxy extends CommonProxy
.withColor(0xFFFFFF00)
.withHoverEvent(new HoverEvent(
HoverEvent.Action.SHOW_TEXT,
new TextComponent("Allows use for /tbm-disable and /tbm-enable for all"))));
new TextComponent("Allows use for /tbm-disable and /tbm-enable for all")))
.withBold(true));
parent.append(sub);
sub = new TextComponent("true ");
@ -747,7 +684,7 @@ public class ClientProxy extends CommonProxy
parent.append(sub);
sub = new TextComponent("max_in_battle ");
sub.setStyle(sub.getStyle().withColor(0xFFFFFF00));
sub.setStyle(sub.getStyle().withColor(0xFFFFFF00).withBold(true));
parent.append(sub);
sub = new TextComponent("2 ");
@ -769,7 +706,7 @@ public class ClientProxy extends CommonProxy
}
sub = new TextComponent("freeze_battle_combatants ");
sub.setStyle(sub.getStyle().withColor(0xFFFFFF00));
sub.setStyle(sub.getStyle().withColor(0xFFFFFF00).withBold(true));
parent.append(sub);
sub = new TextComponent("true ");
@ -790,11 +727,79 @@ public class ClientProxy extends CommonProxy
)));
parent.append(sub);
sub = new TextComponent("ignore_battle_types ");
sub.setStyle(sub.getStyle()
.withColor(0xFF00FF00)
.withClickEvent(new ClickEvent(
ClickEvent.Action.RUN_COMMAND,
"/tbm-server-edit ignore_battle_types"))
.withHoverEvent(new HoverEvent(
HoverEvent.Action.SHOW_TEXT,
new TextComponent("Click to show current ignored categories, or use /tbm-server-edit ignore_battle_types add/remove <category_name>")
))
.withBold(true));
parent.append(sub);
sub = new TextComponent("player_speed ");
sub.setStyle(sub.getStyle()
.withColor(0xFFFFFF00)
.withBold(true)
.withHoverEvent(new HoverEvent(
HoverEvent.Action.SHOW_TEXT,
new TextComponent("Player default speed"))));
parent.append(sub);
for (int i = 0; i <= 100; i += 5) {
sub = new TextComponent(String.valueOf(i) + ' ');
sub.setStyle(sub.getStyle()
.withColor(0xFF00FF00)
.withClickEvent(new ClickEvent(ClickEvent.Action.RUN_COMMAND,
"/tbm-server-edit player_speed " + i)));
parent.append(sub);
}
sub = new TextComponent("player_haste_speed ");
sub.setStyle(sub.getStyle()
.withColor(0xFFFFFF00)
.withBold(true)
.withHoverEvent(new HoverEvent(
HoverEvent.Action.SHOW_TEXT,
new TextComponent("Player speed when under the effects of \"Speed\"")
)));
parent.append(sub);
for (int i = 0; i <= 100; i += 5) {
sub = new TextComponent(String.valueOf(i) + ' ');
sub.setStyle(sub.getStyle()
.withColor(0xFF00FF00)
.withClickEvent(new ClickEvent(ClickEvent.Action.RUN_COMMAND,
"/tbm-server-edit player_haste_speed " + i)));
parent.append(sub);
}
sub = new TextComponent("player_slow_speed ");
sub.setStyle(sub.getStyle()
.withColor(0xFFFFFF00)
.withBold(true)
.withHoverEvent(new HoverEvent(
HoverEvent.Action.SHOW_TEXT,
new TextComponent("Player speed when under the effects of \"Slow\"")
)));
parent.append(sub);
for (int i = 0; i <= 100; i += 5) {
sub = new TextComponent(String.valueOf(i) + ' ');
sub.setStyle(sub.getStyle()
.withColor(0xFF00FF00)
.withClickEvent(new ClickEvent(ClickEvent.Action.RUN_COMMAND,
"/tbm-server-edit player_slow_speed " + i)));
parent.append(sub);
}
TurnBasedMinecraftMod.proxy.displayComponent(parent);
break;
}
case EDIT_IGNORE_BATTLE:
{
case EDIT_IGNORE_BATTLE: {
TextComponent text = new TextComponent("ignoreBattle: ");
text.setStyle(text.getStyle().withColor(TextColor.fromRgb(0xFFFFFFFF)).withBold(false));
@ -812,18 +817,15 @@ public class ClientProxy extends CommonProxy
TurnBasedMinecraftMod.proxy.displayComponent(parentComponent);
break;
}
case EDIT_ATTACK_POWER:
{
case EDIT_ATTACK_POWER: {
TextComponent text = new TextComponent("attackPower: ");
text.setStyle(text.getStyle().withColor(TextColor.fromRgb(0xFFFFFFFF)).withBold(false));
for(int i = 0; i <= 15; ++i)
{
for (int i = 0; i <= 15; ++i) {
TextComponent option = new TextComponent(Integer.toString(i));
option.setStyle(option.getStyle().withColor(TextColor.fromRgb(0xFFFFFF00)).withClickEvent(new ClickEvent(ClickEvent.Action.RUN_COMMAND, "/tbm-edit edit attackPower " + Integer.toString(i))));
text.getSiblings().add(option);
if(i < 15)
{
if (i < 15) {
text.getSiblings().add(new TextComponent(", "));
}
}
@ -834,18 +836,15 @@ public class ClientProxy extends CommonProxy
TurnBasedMinecraftMod.proxy.displayComponent(parentComponent);
break;
}
case EDIT_ATTACK_PROBABILITY:
{
case EDIT_ATTACK_PROBABILITY: {
TextComponent text = new TextComponent("attackProbability: ");
text.setStyle(text.getStyle().withColor(TextColor.fromRgb(0xFFFFFFFF)).withBold(false));
for(int i = 10; i <= 100; i += 10)
{
for (int i = 10; i <= 100; i += 10) {
TextComponent option = new TextComponent(Integer.toString(i) + "%");
option.setStyle(option.getStyle().withColor(TextColor.fromRgb(0xFFFFFF00)).withClickEvent(new ClickEvent(ClickEvent.Action.RUN_COMMAND, "/tbm-edit edit attackProbability " + Integer.toString(i))));
text.getSiblings().add(option);
if(i < 100)
{
if (i < 100) {
text.getSiblings().add(new TextComponent(", "));
}
}
@ -856,18 +855,15 @@ public class ClientProxy extends CommonProxy
TurnBasedMinecraftMod.proxy.displayComponent(parentComponent);
break;
}
case EDIT_ATTACK_VARIANCE:
{
case EDIT_ATTACK_VARIANCE: {
TextComponent text = new TextComponent("attackVariance: ");
text.setStyle(text.getStyle().withColor(TextColor.fromRgb(0xFFFFFFFF)).withBold(false));
for(int i = 0; i <= 10; ++i)
{
for (int i = 0; i <= 10; ++i) {
TextComponent option = new TextComponent(Integer.toString(i));
option.setStyle(option.getStyle().withColor(TextColor.fromRgb(0xFFFFFF00)).withClickEvent(new ClickEvent(ClickEvent.Action.RUN_COMMAND, "/tbm-edit edit attackVariance " + Integer.toString(i))));
text.getSiblings().add(option);
if(i < 10)
{
if (i < 10) {
text.getSiblings().add(new TextComponent(", "));
}
}
@ -878,18 +874,15 @@ public class ClientProxy extends CommonProxy
TurnBasedMinecraftMod.proxy.displayComponent(parentComponent);
break;
}
case EDIT_ATTACK_EFFECT:
{
case EDIT_ATTACK_EFFECT: {
TextComponent text = new TextComponent("attackEffect: ");
text.setStyle(text.getStyle().withColor(TextColor.fromRgb(0xFFFFFFFF)).withBold(false));
for(EntityInfo.Effect e : EntityInfo.Effect.values())
{
for (EntityInfo.Effect e : EntityInfo.Effect.values()) {
TextComponent option = new TextComponent(e.toString());
option.setStyle(option.getStyle().withColor(TextColor.fromRgb(0xFFFFFF00)).withClickEvent(new ClickEvent(ClickEvent.Action.RUN_COMMAND, "/tbm-edit edit attackEffect " + e.toString())));
text.getSiblings().add(option);
if(e != EntityInfo.Effect.UNKNOWN)
{
if (e != EntityInfo.Effect.UNKNOWN) {
// TODO find a better way to handle printing comma for items before last
text.getSiblings().add(new TextComponent(", "));
}
@ -899,18 +892,15 @@ public class ClientProxy extends CommonProxy
TurnBasedMinecraftMod.proxy.displayComponent(parentComponent);
break;
}
case EDIT_ATTACK_EFFECT_PROBABILITY:
{
case EDIT_ATTACK_EFFECT_PROBABILITY: {
TextComponent text = new TextComponent("attackEffectProbability: ");
text.setStyle(text.getStyle().withColor(TextColor.fromRgb(0xFFFFFFFF)).withBold(false));
for(int i = 0; i <= 100; i += 10)
{
for (int i = 0; i <= 100; i += 10) {
TextComponent option = new TextComponent(Integer.toString(i) + "%");
option.setStyle(option.getStyle().withColor(TextColor.fromRgb(0xFFFFFF00)).withClickEvent(new ClickEvent(ClickEvent.Action.RUN_COMMAND, "/tbm-edit edit attackEffectProbability " + Integer.toString(i))));
text.getSiblings().add(option);
if(i < 100)
{
if (i < 100) {
text.getSiblings().add(new TextComponent(", "));
}
}
@ -921,18 +911,15 @@ public class ClientProxy extends CommonProxy
TurnBasedMinecraftMod.proxy.displayComponent(parentComponent);
break;
}
case EDIT_DEFENSE_DAMAGE:
{
case EDIT_DEFENSE_DAMAGE: {
TextComponent text = new TextComponent("defenseDamage: ");
text.setStyle(text.getStyle().withColor(TextColor.fromRgb(0xFFFFFFFF)).withBold(false));
for(int i = 0; i <= 15; ++i)
{
for (int i = 0; i <= 15; ++i) {
TextComponent option = new TextComponent(Integer.toString(i));
option.setStyle(option.getStyle().withColor(TextColor.fromRgb(0xFFFFFF00)).withClickEvent(new ClickEvent(ClickEvent.Action.RUN_COMMAND, "/tbm-edit edit defenseDamage " + Integer.toString(i))));
text.getSiblings().add(option);
if(i < 15)
{
if (i < 15) {
text.getSiblings().add(new TextComponent(", "));
}
}
@ -943,18 +930,15 @@ public class ClientProxy extends CommonProxy
TurnBasedMinecraftMod.proxy.displayComponent(parentComponent);
break;
}
case EDIT_DEFENSE_DAMAGE_PROBABILITY:
{
case EDIT_DEFENSE_DAMAGE_PROBABILITY: {
TextComponent text = new TextComponent("defenseDamageProbability: ");
text.setStyle(text.getStyle().withColor(TextColor.fromRgb(0xFFFFFFFF)).withBold(false));
for(int i = 0; i <= 100; i += 10)
{
for (int i = 0; i <= 100; i += 10) {
TextComponent option = new TextComponent(Integer.toString(i) + "%");
option.setStyle(option.getStyle().withColor(TextColor.fromRgb(0xFFFFFF00)).withClickEvent(new ClickEvent(ClickEvent.Action.RUN_COMMAND, "/tbm-edit edit defenseDamageProbability " + Integer.toString(i))));
text.getSiblings().add(option);
if(i < 100)
{
if (i < 100) {
text.getSiblings().add(new TextComponent(", "));
}
}
@ -965,18 +949,15 @@ public class ClientProxy extends CommonProxy
TurnBasedMinecraftMod.proxy.displayComponent(parentComponent);
break;
}
case EDIT_EVASION:
{
case EDIT_EVASION: {
TextComponent text = new TextComponent("evasion: ");
text.setStyle(text.getStyle().withColor(TextColor.fromRgb(0xFFFFFFFF)).withBold(false));
for(int i = 0; i <= 100; i += 10)
{
for (int i = 0; i <= 100; i += 10) {
TextComponent option = new TextComponent(Integer.toString(i) + "%");
option.setStyle(option.getStyle().withColor(TextColor.fromRgb(0xFFFFFF00)).withClickEvent(new ClickEvent(ClickEvent.Action.RUN_COMMAND, "/tbm-edit edit evasion " + Integer.toString(i))));
text.getSiblings().add(option);
if(i < 100)
{
if (i < 100) {
text.getSiblings().add(new TextComponent(", "));
}
}
@ -987,18 +968,15 @@ public class ClientProxy extends CommonProxy
TurnBasedMinecraftMod.proxy.displayComponent(parentComponent);
break;
}
case EDIT_SPEED:
{
case EDIT_SPEED: {
TextComponent text = new TextComponent("speed: ");
text.setStyle(text.getStyle().withColor(TextColor.fromRgb(0xFFFFFFFF)).withBold(false));
for(int i = 0; i <= 100; i += 10)
{
for (int i = 0; i <= 100; i += 10) {
TextComponent option = new TextComponent(Integer.toString(i));
option.setStyle(option.getStyle().withColor(TextColor.fromRgb(0xFFFFFF00)).withClickEvent(new ClickEvent(ClickEvent.Action.RUN_COMMAND, "/tbm-edit edit speed " + Integer.toString(i))));
text.getSiblings().add(option);
if(i < 100)
{
if (i < 100) {
text.getSiblings().add(new TextComponent(", "));
}
}
@ -1009,15 +987,13 @@ public class ClientProxy extends CommonProxy
TurnBasedMinecraftMod.proxy.displayComponent(parentComponent);
break;
}
case EDIT_CATEGORY:
{
case EDIT_CATEGORY: {
TextComponent text = new TextComponent("category: ");
text.setStyle(text.getStyle().withColor(TextColor.fromRgb(0xFFFFFFFF)).withBold(false));
TextComponent option = new TextComponent("monster");
option.setStyle(option.getStyle().withColor(TextColor.fromRgb(0xFFFFFF00)).withClickEvent(new ClickEvent(ClickEvent.Action.RUN_COMMAND, "/tbm-edit edit category monster")));
if(TurnBasedMinecraftMod.proxy.getConfig().isIgnoreBattleType("monster"))
{
if (TurnBasedMinecraftMod.proxy.getConfig().isIgnoreBattleType("monster")) {
TextComponent optionInfo = new TextComponent("(battle-");
optionInfo.setStyle(optionInfo.getStyle().withColor(TextColor.fromRgb(0xFFFFFFFF)));
TextComponent optionInfoBool = new TextComponent("disabled");
@ -1025,9 +1001,7 @@ public class ClientProxy extends CommonProxy
optionInfo.getSiblings().add(optionInfoBool);
optionInfo.getSiblings().add(new TextComponent(")"));
option.getSiblings().add(optionInfo);
}
else
{
} else {
TextComponent optionInfo = new TextComponent("(battle-");
optionInfo.setStyle(optionInfo.getStyle().withColor(TextColor.fromRgb(0xFFFFFFFF)));
TextComponent optionInfoBool = new TextComponent("enabled");
@ -1041,8 +1015,7 @@ public class ClientProxy extends CommonProxy
option = new TextComponent("animal");
option.setStyle(option.getStyle().withColor(TextColor.fromRgb(0xFFFFFF00)).withClickEvent(new ClickEvent(ClickEvent.Action.RUN_COMMAND, "/tbm-edit edit category animal")));
if(TurnBasedMinecraftMod.proxy.getConfig().isIgnoreBattleType("animal"))
{
if (TurnBasedMinecraftMod.proxy.getConfig().isIgnoreBattleType("animal")) {
TextComponent optionInfo = new TextComponent("(battle-");
optionInfo.setStyle(optionInfo.getStyle().withColor(TextColor.fromRgb(0xFFFFFFFF)));
TextComponent optionInfoBool = new TextComponent("disabled");
@ -1050,9 +1023,7 @@ public class ClientProxy extends CommonProxy
optionInfo.getSiblings().add(optionInfoBool);
optionInfo.getSiblings().add(new TextComponent(")"));
option.getSiblings().add(optionInfo);
}
else
{
} else {
TextComponent optionInfo = new TextComponent("(battle-");
optionInfo.setStyle(optionInfo.getStyle().withColor(TextColor.fromRgb(0xFFFFFFFF)));
TextComponent optionInfoBool = new TextComponent("enabled");
@ -1066,8 +1037,7 @@ public class ClientProxy extends CommonProxy
option = new TextComponent("passive");
option.setStyle(option.getStyle().withColor(TextColor.fromRgb(0xFFFFFF00)).withClickEvent(new ClickEvent(ClickEvent.Action.RUN_COMMAND, "/tbm-edit edit category passive")));
if(TurnBasedMinecraftMod.proxy.getConfig().isIgnoreBattleType("passive"))
{
if (TurnBasedMinecraftMod.proxy.getConfig().isIgnoreBattleType("passive")) {
TextComponent optionInfo = new TextComponent("(battle-");
optionInfo.setStyle(optionInfo.getStyle().withColor(TextColor.fromRgb(0xFFFFFFFF)));
TextComponent optionInfoBool = new TextComponent("disabled");
@ -1075,9 +1045,7 @@ public class ClientProxy extends CommonProxy
optionInfo.getSiblings().add(optionInfoBool);
optionInfo.getSiblings().add(new TextComponent(")"));
option.getSiblings().add(optionInfo);
}
else
{
} else {
TextComponent optionInfo = new TextComponent("(battle-");
optionInfo.setStyle(optionInfo.getStyle().withColor(TextColor.fromRgb(0xFFFFFFFF)));
TextComponent optionInfoBool = new TextComponent("enabled");
@ -1091,8 +1059,7 @@ public class ClientProxy extends CommonProxy
option = new TextComponent("boss");
option.setStyle(option.getStyle().withColor(TextColor.fromRgb(0xFFFFFF00)).withClickEvent(new ClickEvent(ClickEvent.Action.RUN_COMMAND, "/tbm-edit edit category boss")));
if(TurnBasedMinecraftMod.proxy.getConfig().isIgnoreBattleType("boss"))
{
if (TurnBasedMinecraftMod.proxy.getConfig().isIgnoreBattleType("boss")) {
TextComponent optionInfo = new TextComponent("(battle-");
optionInfo.setStyle(optionInfo.getStyle().withColor(TextColor.fromRgb(0xFFFFFFFF)));
TextComponent optionInfoBool = new TextComponent("disabled");
@ -1100,9 +1067,7 @@ public class ClientProxy extends CommonProxy
optionInfo.getSiblings().add(optionInfoBool);
optionInfo.getSiblings().add(new TextComponent(")"));
option.getSiblings().add(optionInfo);
}
else
{
} else {
TextComponent optionInfo = new TextComponent("(battle-");
optionInfo.setStyle(optionInfo.getStyle().withColor(TextColor.fromRgb(0xFFFFFFFF)));
TextComponent optionInfoBool = new TextComponent("enabled");
@ -1116,8 +1081,7 @@ public class ClientProxy extends CommonProxy
option = new TextComponent("player");
option.setStyle(option.getStyle().withColor(TextColor.fromRgb(0xFFFFFF00)).withClickEvent(new ClickEvent(ClickEvent.Action.RUN_COMMAND, "/tbm-edit edit category player")));
if(TurnBasedMinecraftMod.proxy.getConfig().isIgnoreBattleType("player"))
{
if (TurnBasedMinecraftMod.proxy.getConfig().isIgnoreBattleType("player")) {
TextComponent optionInfo = new TextComponent("(battle-");
optionInfo.setStyle(optionInfo.getStyle().withColor(TextColor.fromRgb(0xFFFFFFFF)));
TextComponent optionInfoBool = new TextComponent("disabled");
@ -1125,9 +1089,7 @@ public class ClientProxy extends CommonProxy
optionInfo.getSiblings().add(optionInfoBool);
optionInfo.getSiblings().add(new TextComponent(")"));
option.getSiblings().add(optionInfo);
}
else
{
} else {
TextComponent optionInfo = new TextComponent("(battle-");
optionInfo.setStyle(optionInfo.getStyle().withColor(TextColor.fromRgb(0xFFFFFFFF)));
TextComponent optionInfoBool = new TextComponent("enabled");
@ -1144,18 +1106,15 @@ public class ClientProxy extends CommonProxy
TurnBasedMinecraftMod.proxy.displayComponent(parentComponent);
break;
}
case EDIT_DECISION_ATTACK:
{
case EDIT_DECISION_ATTACK: {
TextComponent text = new TextComponent("decisionAttack: ");
text.setStyle(text.getStyle().withColor(TextColor.fromRgb(0xFFFFFFFF)).withBold(false));
for(int i = 0; i <= 100; i += 10)
{
for (int i = 0; i <= 100; i += 10) {
TextComponent option = new TextComponent(Integer.toString(i) + "%");
option.setStyle(option.getStyle().withColor(TextColor.fromRgb(0xFFFFFF00)).withClickEvent(new ClickEvent(ClickEvent.Action.RUN_COMMAND, "/tbm-edit edit decisionAttack " + Integer.toString(i))));
text.getSiblings().add(option);
if(i < 100)
{
if (i < 100) {
text.getSiblings().add(new TextComponent(", "));
}
}
@ -1164,18 +1123,15 @@ public class ClientProxy extends CommonProxy
TurnBasedMinecraftMod.proxy.displayComponent(parentComponent);
break;
}
case EDIT_DECISION_DEFEND:
{
case EDIT_DECISION_DEFEND: {
TextComponent text = new TextComponent("decisionDefend: ");
text.setStyle(text.getStyle().withColor(TextColor.fromRgb(0xFFFFFFFF)).withBold(false));
for(int i = 0; i <= 100; i += 10)
{
for (int i = 0; i <= 100; i += 10) {
TextComponent option = new TextComponent(Integer.toString(i) + "%");
option.setStyle(option.getStyle().withColor(TextColor.fromRgb(0xFFFFFF00)).withClickEvent(new ClickEvent(ClickEvent.Action.RUN_COMMAND, "/tbm-edit edit decisionDefend " + Integer.toString(i))));
text.getSiblings().add(option);
if(i < 100)
{
if (i < 100) {
text.getSiblings().add(new TextComponent(", "));
}
}
@ -1184,18 +1140,15 @@ public class ClientProxy extends CommonProxy
TurnBasedMinecraftMod.proxy.displayComponent(parentComponent);
break;
}
case EDIT_DECISION_FLEE:
{
case EDIT_DECISION_FLEE: {
TextComponent text = new TextComponent("decisionFlee: ");
text.setStyle(text.getStyle().withColor(TextColor.fromRgb(0xFFFFFFFF)).withBold(false));
for(int i = 0; i <= 100; i += 10)
{
for (int i = 0; i <= 100; i += 10) {
TextComponent option = new TextComponent(Integer.toString(i) + "%");
option.setStyle(option.getStyle().withColor(TextColor.fromRgb(0xFFFFFF00)).withClickEvent(new ClickEvent(ClickEvent.Action.RUN_COMMAND, "/tbm-edit edit decisionFlee " + Integer.toString(i))));
text.getSiblings().add(option);
if(i < 100)
{
if (i < 100) {
text.getSiblings().add(new TextComponent(", "));
}
}

View file

@ -5,6 +5,7 @@ import com.burnedkirby.TurnBasedMinecraft.common.networking.PacketBattleMessage;
import net.minecraft.resources.ResourceKey;
import net.minecraft.server.level.ServerPlayer;
import net.minecraft.world.damagesource.DamageSource;
import net.minecraft.world.effect.MobEffects;
import net.minecraft.world.entity.Entity;
import net.minecraft.world.entity.LivingEntity;
import net.minecraft.world.entity.Mob;
@ -1218,7 +1219,13 @@ public class Battle
{
if(c.entity instanceof Player)
{
if(TurnBasedMinecraftMod.proxy.getConfig().getPlayerSpeed() > fastestEnemySpeed)
int playerSpeed = TurnBasedMinecraftMod.proxy.getConfig().getPlayerSpeed();
if (((Player) c.entity).hasEffect(MobEffects.MOVEMENT_SPEED)) {
playerSpeed = TurnBasedMinecraftMod.proxy.getConfig().getPlayerHasteSpeed();
} else if (((Player) c.entity).hasEffect(MobEffects.MOVEMENT_SLOWDOWN)) {
playerSpeed = TurnBasedMinecraftMod.proxy.getConfig().getPlayerSlowSpeed();
}
if(playerSpeed > fastestEnemySpeed)
{
fastestEnemySpeed = TurnBasedMinecraftMod.proxy.getConfig().getPlayerSpeed();
}
@ -1238,7 +1245,13 @@ public class Battle
{
if(c.entity instanceof Player)
{
if(TurnBasedMinecraftMod.proxy.getConfig().getPlayerSpeed() > fastestEnemySpeed)
int playerSpeed = TurnBasedMinecraftMod.proxy.getConfig().getPlayerSpeed();
if (((Player) c.entity).hasEffect(MobEffects.MOVEMENT_SPEED)) {
playerSpeed = TurnBasedMinecraftMod.proxy.getConfig().getPlayerHasteSpeed();
} else if (((Player) c.entity).hasEffect(MobEffects.MOVEMENT_SLOWDOWN)) {
playerSpeed = TurnBasedMinecraftMod.proxy.getConfig().getPlayerSlowSpeed();
}
if(playerSpeed > fastestEnemySpeed)
{
fastestEnemySpeed = TurnBasedMinecraftMod.proxy.getConfig().getPlayerSpeed();
}
@ -1255,7 +1268,13 @@ public class Battle
int fleeProbability = 0;
if(next.entity instanceof Player)
{
if(fastestEnemySpeed >= TurnBasedMinecraftMod.proxy.getConfig().getPlayerSpeed())
int playerSpeed = TurnBasedMinecraftMod.proxy.getConfig().getPlayerSpeed();
if (((Player) next.entity).hasEffect(MobEffects.MOVEMENT_SPEED)) {
playerSpeed = TurnBasedMinecraftMod.proxy.getConfig().getPlayerHasteSpeed();
} else if (((Player) next.entity).hasEffect(MobEffects.MOVEMENT_SLOWDOWN)) {
playerSpeed = TurnBasedMinecraftMod.proxy.getConfig().getPlayerSlowSpeed();
}
if(fastestEnemySpeed >= playerSpeed)
{
fleeProbability = TurnBasedMinecraftMod.proxy.getConfig().getFleeBadProbability();
}

View file

@ -936,16 +936,46 @@ public class Config
return playerSpeed;
}
public void setPlayerSpeed(int speed) {
if (speed < 0) {
speed = 0;
} else if (speed > 100) {
speed = 100;
}
playerSpeed = speed;
}
public int getPlayerHasteSpeed()
{
return playerHasteSpeed;
}
public void setPlayerHasteSpeed(int speed) {
if (speed < 0) {
speed = 0;
} else if (speed > 100) {
speed = 100;
}
playerHasteSpeed = speed;
}
public int getPlayerSlowSpeed()
{
return playerSlowSpeed;
}
public void setPlayerSlowSpeed(int speed) {
if (speed < 0) {
speed = 0;
} else if (speed > 100) {
speed = 100;
}
playerSlowSpeed = speed;
}
public int getPlayerAttackProbability()
{
return playerAttackProbability;
@ -1096,11 +1126,85 @@ public class Config
return true;
}
public boolean updateConfigAppendToStringArray(String path, String string_value) {
File configFile = new File(TurnBasedMinecraftMod.CONFIG_FILE_PATH);
CommentedFileConfig conf = getConfigObj(configFile);
Collection<String> strings;
try {
strings = conf.get(path);
} catch (Exception e) {
TurnBasedMinecraftMod.logger.warn("Exception during fetching Collection<String> from config (append)");
TurnBasedMinecraftMod.logger.warn(e);
return false;
}
if (strings.contains(string_value)) {
return false;
}
strings.add(string_value);
try {
conf.set(path, strings);
} catch (Exception e) {
TurnBasedMinecraftMod.logger.warn("Exception during setting Collection<String> in config (append)");
TurnBasedMinecraftMod.logger.warn(e);
return false;
}
conf.save();
conf.close();
return true;
}
public boolean updateConfigRemoveFromStringArray(String path, String string_value) {
File configFile = new File(TurnBasedMinecraftMod.CONFIG_FILE_PATH);
CommentedFileConfig conf = getConfigObj(configFile);
Collection<String> strings;
try {
strings = conf.get(path);
} catch (Exception e) {
TurnBasedMinecraftMod.logger.warn("Exception during fetching Collection<String> from config (removal)");
TurnBasedMinecraftMod.logger.warn(e);
return false;
}
if (!strings.contains(string_value)) {
return false;
}
strings.remove(string_value);
try {
conf.set(path, strings);
} catch (Exception e) {
TurnBasedMinecraftMod.logger.warn("Exception during setting Collection<String> in config (removal)");
TurnBasedMinecraftMod.logger.warn(e);
return false;
}
conf.save();
conf.close();
return true;
}
public boolean isIgnoreBattleType(String type)
{
return ignoreBattleTypes.contains(type);
}
public Collection<String> getIgnoreBattleTypes() {
return ignoreBattleTypes;
}
public boolean removeIgnoreBattleType(String category) {
return ignoreBattleTypes.remove(category);
}
public boolean addIgnoreBattleType(String category) {
return ignoreBattleTypes.add(category);
}
public int getMinimumHitPercentage()
{
return minimumHitPercentage;

View file

@ -11,6 +11,8 @@ import com.mojang.brigadier.exceptions.CommandSyntaxException;
import com.mojang.brigadier.exceptions.SimpleCommandExceptionType;
import net.minecraft.commands.Commands;
import net.minecraft.commands.arguments.EntityArgument;
import net.minecraft.network.chat.ClickEvent;
import net.minecraft.network.chat.HoverEvent;
import net.minecraft.network.chat.TextComponent;
import net.minecraft.resources.ResourceLocation;
import net.minecraft.server.level.ServerPlayer;
@ -984,6 +986,176 @@ public class TurnBasedMinecraftMod {
}
return 1;
})))
.then(Commands.literal("ignore_battle_types").executes(c -> {
TextComponent response = new TextComponent("Use ");
TextComponent subResponse = new TextComponent("/tbm-server-edit ignore_battle_types add/remove <category> ");
subResponse.setStyle(subResponse.getStyle().withColor(0xFFFFFF00));
response.append(subResponse);
subResponse = new TextComponent("ignore_battle_types is currently: [");
response.append(subResponse);
boolean isFirst = true;
for (String category : TurnBasedMinecraftMod.proxy.getConfig().getIgnoreBattleTypes()) {
if (!isFirst) {
response.append(new TextComponent(", "));
}
subResponse = new TextComponent(category);
subResponse.setStyle(subResponse.getStyle()
.withColor(0xFF00FF00)
.withClickEvent(new ClickEvent(
ClickEvent.Action.RUN_COMMAND,
"/tbm-server-edit ignore_battle_types remove " + category))
.withHoverEvent(new HoverEvent(
HoverEvent.Action.SHOW_TEXT,
new TextComponent("Click to remove category"))));
response.append(subResponse);
isFirst = false;
}
response.append(new TextComponent("] "));
c.getSource().sendSuccess(response, false);
return 1;
})
.then(Commands.literal("add").executes(c -> {
c.getSource().sendFailure(new TextComponent("/tbm-server-edit ignore_battle_types add <category>"));
return 1;
})
.then(Commands.argument("category", StringArgumentType.greedyString()).executes(c -> {
String category = StringArgumentType.getString(c, "category");
if (TurnBasedMinecraftMod.proxy.getConfig().addIgnoreBattleType(category)
&& TurnBasedMinecraftMod.proxy.getConfig().updateConfigAppendToStringArray("server_config.ignore_battle_types", category)) {
TextComponent response = new TextComponent("Successfully appended category \"");
TextComponent sub = new TextComponent(category);
sub.setStyle(sub.getStyle().withColor(0xFF00FF00));
response.append(sub);
sub = new TextComponent("\" to ignore_battle_types");
response.append(sub);
c.getSource().sendSuccess(response, true);
return 1;
}
c.getSource().sendFailure(new TextComponent(
"Failed to append category \"" + category + "\" to ignore_battle_types"));
return 1;
})))
.then(Commands.literal("remove").executes(c -> {
c.getSource().sendFailure(new TextComponent("/tbm-server-edit ignore_battle_types remove <category>"));
return 1;
})
.then(Commands.argument("category", StringArgumentType.greedyString()).executes(c -> {
String category = StringArgumentType.getString(c, "category");
if (TurnBasedMinecraftMod.proxy.getConfig().removeIgnoreBattleType(category)
&& TurnBasedMinecraftMod.proxy.getConfig().updateConfigRemoveFromStringArray("server_config.ignore_battle_types", category)) {
TextComponent response = new TextComponent("Successfully removed category \"");
TextComponent sub = new TextComponent(category);
sub.setStyle(sub.getStyle().withColor(0xFF00FF00));
response.append(sub);
sub = new TextComponent("\" from ignore_battle_types");
response.append(sub);
c.getSource().sendSuccess(response, true);
return 1;
}
c.getSource().sendFailure(new TextComponent(
"Failed to remove category \"" + category + "\" to ignore_battle_types"));
return 1;
}))))
.then(Commands.literal("player_speed").executes(c -> {
TextComponent parent = new TextComponent("Use ");
TextComponent sub = new TextComponent("/tbm-server-edit player_speed <0-100>");
sub.setStyle(sub.getStyle().withColor(0xFFFFFF00));
parent.append(sub);
c.getSource().sendSuccess(parent, false);
return 1;
})
.then(Commands.argument("speed", IntegerArgumentType.integer()).executes(c -> {
int speed = IntegerArgumentType.getInteger(c, "speed");
// setPlayerSpeed() in Config validates the value. Set it, then fetch it again.
TurnBasedMinecraftMod.proxy.getConfig().setPlayerSpeed(speed);
speed = TurnBasedMinecraftMod.proxy.getConfig().getPlayerSpeed();
if (!TurnBasedMinecraftMod.proxy.getConfig().updateConfig("server_config.player_speed", speed)) {
TurnBasedMinecraftMod.logger.warn(
"Failed to set \"server_config.player_speed\" in config file!");
c.getSource().sendFailure(new TextComponent(
"Failed to set player_speed to \""
+ speed
+ "\" in config file!"));
} else {
TextComponent response = new TextComponent("Successfully set player_speed to: ");
TextComponent subResponse = new TextComponent(String.valueOf(speed));
subResponse.setStyle(subResponse.getStyle().withColor(0xFF00FF00));
response.append(subResponse);
c.getSource().sendSuccess(response, true);
}
return 1;
})))
.then(Commands.literal("player_haste_speed").executes(c -> {
TextComponent parent = new TextComponent("Use ");
TextComponent sub = new TextComponent("/tbm-server-edit player_haste_speed <0-100>");
sub.setStyle(sub.getStyle().withColor(0xFFFFFF00));
parent.append(sub);
c.getSource().sendSuccess(parent, false);
return 1;
})
.then(Commands.argument("haste_speed", IntegerArgumentType.integer()).executes(c -> {
int haste_speed = IntegerArgumentType.getInteger(c, "haste_speed");
// setPlayerHasteSpeed() in Config validates the value. Set it, then fetch it again.
TurnBasedMinecraftMod.proxy.getConfig().setPlayerHasteSpeed(haste_speed);
haste_speed = TurnBasedMinecraftMod.proxy.getConfig().getPlayerHasteSpeed();
if (!TurnBasedMinecraftMod.proxy.getConfig().updateConfig("server_config.player_haste_speed", haste_speed)) {
TurnBasedMinecraftMod.logger.warn(
"Failed to set \"server_config.player_haste_speed\" in config file!");
c.getSource().sendFailure(new TextComponent(
"Failed to set player_haste_speed to \""
+ haste_speed
+ "\" in config file!"));
} else {
TextComponent response = new TextComponent("Successfully set player_haste_speed to: ");
TextComponent subResponse = new TextComponent(String.valueOf(haste_speed));
subResponse.setStyle(subResponse.getStyle().withColor(0xFF00FF00));
response.append(subResponse);
c.getSource().sendSuccess(response, true);
}
return 1;
})))
.then(Commands.literal("player_slow_speed").executes(c -> {
TextComponent parent = new TextComponent("Use ");
TextComponent sub = new TextComponent("/tbm-server-edit player_slow_speed <0-100>");
sub.setStyle(sub.getStyle().withColor(0xFFFFFF00));
parent.append(sub);
c.getSource().sendSuccess(parent, false);
return 1;
})
.then(Commands.argument("slow_speed", IntegerArgumentType.integer()).executes(c -> {
int slow_speed = IntegerArgumentType.getInteger(c, "slow_speed");
// setPlayerSlowSpeed() in Config validates the value. Set it, then fetch it again.
TurnBasedMinecraftMod.proxy.getConfig().setPlayerSlowSpeed(slow_speed);
slow_speed = TurnBasedMinecraftMod.proxy.getConfig().getPlayerSlowSpeed();
if (!TurnBasedMinecraftMod.proxy.getConfig().updateConfig("server_config.player_slow_speed", slow_speed)) {
TurnBasedMinecraftMod.logger.warn(
"Failed to set \"server_config.player_slow_speed\" in config file!");
c.getSource().sendFailure(new TextComponent(
"Failed to set player_slow_speed to \""
+ slow_speed
+ "\" in config file!"));
} else {
TextComponent response = new TextComponent("Successfully set player_slow_speed to: ");
TextComponent subResponse = new TextComponent(String.valueOf(slow_speed));
subResponse.setStyle(subResponse.getStyle().withColor(0xFF00FF00));
response.append(subResponse);
c.getSource().sendSuccess(response, true);
}
return 1;
})))
);
}