PaperMC/Spigot-Server-Patches/Player-Exhaustion-Multipliers.patch

58 lines
3.3 KiB
Diff
Raw Normal View History

2014-07-07 02:18:38 +02:00
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
2015-01-29 22:25:50 +01:00
From: gsand <gsandowns@gmail.com>
2016-03-01 00:09:49 +01:00
Date: Tue, 1 Mar 2016 13:43:16 -0600
2014-07-07 02:18:38 +02:00
Subject: [PATCH] Player Exhaustion Multipliers
2016-03-01 00:09:49 +01:00
diff --git a/src/main/java/com/destroystokyo/paper/PaperWorldConfig.java b/src/main/java/com/destroystokyo/paper/PaperWorldConfig.java
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
--- a/src/main/java/com/destroystokyo/paper/PaperWorldConfig.java
+++ b/src/main/java/com/destroystokyo/paper/PaperWorldConfig.java
@@ -0,0 +0,0 @@ public class PaperWorldConfig {
private void nerfedMobsShouldJump() {
nerfedMobsShouldJump = getBoolean("spawner-nerfed-mobs-should-jump", false);
2016-03-01 00:09:49 +01:00
}
+
+ public float blockBreakExhaustion;
+ public float playerSwimmingExhaustion;
+ public void exhaustionValues() {
+ blockBreakExhaustion = getFloat("player-exhaustion.block-break", 0.025F);
+ playerSwimmingExhaustion = getFloat("player-exhaustion.swimming", 0.015F);
+ log("Player exhaustion penalty for breaking blocks is " + blockBreakExhaustion);
+ log("Player exhaustion penalty for swimming is " + playerSwimmingExhaustion);
+ }
}
2014-07-07 02:18:38 +02:00
diff --git a/src/main/java/net/minecraft/server/Block.java b/src/main/java/net/minecraft/server/Block.java
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
--- a/src/main/java/net/minecraft/server/Block.java
+++ b/src/main/java/net/minecraft/server/Block.java
@@ -0,0 +0,0 @@ public class Block {
2016-03-01 00:09:49 +01:00
public void a(World world, EntityHuman entityhuman, BlockPosition blockposition, IBlockData iblockdata, TileEntity tileentity, ItemStack itemstack) {
entityhuman.b(StatisticList.a(this));
2014-07-09 05:05:35 +02:00
- entityhuman.applyExhaustion(0.025F);
2016-03-01 00:09:49 +01:00
+ entityhuman.applyExhaustion(world.paperConfig.blockBreakExhaustion); // Paper - Configurable block break exhaustion
if (this.o() && EnchantmentManager.getEnchantmentLevel(Enchantments.SILK_TOUCH, itemstack) > 0) {
ItemStack itemstack1 = this.u(iblockdata);
2014-07-07 02:18:38 +02:00
diff --git a/src/main/java/net/minecraft/server/EntityHuman.java b/src/main/java/net/minecraft/server/EntityHuman.java
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
--- a/src/main/java/net/minecraft/server/EntityHuman.java
+++ b/src/main/java/net/minecraft/server/EntityHuman.java
2014-11-28 02:17:45 +01:00
@@ -0,0 +0,0 @@ public abstract class EntityHuman extends EntityLiving {
2014-07-07 02:18:38 +02:00
i = Math.round(MathHelper.sqrt(d0 * d0 + d1 * d1 + d2 * d2) * 100.0F);
if (i > 0) {
2016-03-01 00:09:49 +01:00
this.a(StatisticList.q, i);
2014-07-09 05:05:35 +02:00
- this.applyExhaustion(0.015F * (float) i * 0.01F);
2016-03-01 00:09:49 +01:00
+ this.applyExhaustion(world.paperConfig.playerSwimmingExhaustion); // Paper - Configurable swimming exhaustion
2014-07-07 02:18:38 +02:00
}
2016-03-01 00:09:49 +01:00
} else if (this.isInWater()) {
2014-07-07 02:18:38 +02:00
i = Math.round(MathHelper.sqrt(d0 * d0 + d2 * d2) * 100.0F);
if (i > 0) {
2016-03-01 00:09:49 +01:00
this.a(StatisticList.m, i);
2014-07-09 05:05:35 +02:00
- this.applyExhaustion(0.015F * (float) i * 0.01F);
2016-03-01 00:09:49 +01:00
+ this.applyExhaustion(world.paperConfig.playerSwimmingExhaustion); // Paper - Configurable swimming exhaustion
2014-07-07 02:18:38 +02:00
}
2016-03-01 00:09:49 +01:00
} else if (this.n_()) {
2014-07-07 02:18:38 +02:00
if (d1 > 0.0D) {
2015-03-08 02:16:09 +01:00
--