mirror of
https://github.com/Samsuik/Sakura.git
synced 2025-12-27 02:39:06 +00:00
Upstream has released updates that appear to apply and compile correctly Paper Changes: PaperMC/Paper@1e7dd72 Remove 'fix Vanilla Minecart speed' patch (#10068) PaperMC/Paper@e7e1c8a Fix and add new scoreboard API (#10037) PaperMC/Paper@49f9f6f Add Registry#getKey (#10066) PaperMC/Paper@4adca3d Update to adventure 4.15 (#10045) PaperMC/Paper@ff7b9b0 Increase default custom payload channel size limit (#10006) PaperMC/Paper@1cda66e Hotfix Entity isInRain reobf issue PaperMC/Paper@61768e0 [ci skip] Remove no longer needed mappings change PaperMC/Paper@e035fd7 Updated Upstream (Bukkit/CraftBukkit/Spigot) PaperMC/Paper@c215ce1 [ci skip] cleanup patch diff from last commit PaperMC/Paper@4fdda9e Keep newlines in outdated client/server message (#10042) PaperMC/Paper@f483b38 fix NPE on EntityTeleportEvent getTo (#10016) PaperMC/Paper@dc62150 Catch async usage of playsound (#10021) PaperMC/Paper@0d6a0c3 Fix command block async message (again) (#10082) PaperMC/Paper@d1f507f Don't fire 2 game events for certain cauldron interactions (#8904) PaperMC/Paper@a401585 Fix campfire recipes not always outputting full result (#8754) PaperMC/Paper@88d28d6 Fix long loading screen when refreshing skins (#10026) PaperMC/Paper@c081104 Add experience points api (#9688) PaperMC/Paper@8221b08 Fix global sound event gamerule not being respected (#8727) PaperMC/Paper@3c0d6aa Updated Upstream (Bukkit/CraftBukkit/Spigot) (#10085) PaperMC/Paper@2c3ccb8 Add drops to shear events (#5678) PaperMC/Paper@b2ffb1b Add PlayerShieldDisableEvent (#9177) PaperMC/Paper@2951732 Add HiddenPotionEffect API (#9910) PaperMC/Paper@e4ab50d Properly disallow async Player#chat (#8123) PaperMC/Paper@5e978d3 Fix Folia scheduler tasks not canceling when plugin disable (#10091) PaperMC/Paper@e56e53f Fix some component bugs in login disconnect packet (#10090) PaperMC/Paper@3484ae9 Call entity_die game event after event cancel check (#10096) PaperMC/Paper@0ae58c0 cleanup player death event adventure logic (#10095) PaperMC/Paper@1281f4f Make region/lock shift accessors per world PaperMC/Paper@983377b Correctly check if bucket dispenses will succeed for event (#10109) PaperMC/Paper@58e120b [ci skip] Remove extraneous diff added in 1.20.3 update (#10101) PaperMC/Paper@816bacc Call EntityChangeBlockEvent for cake eating (#10105) PaperMC/Paper@692db0c fix CustomModelData being removed (#10113) PaperMC/Paper@509876d Keep fully frozen entities fully activated (#10103) PaperMC/Paper@1fa48d1 include relative flags in PlayerTeleportEvent (#8190) PaperMC/Paper@ae001ae Fix untrack event not being called for all 'untracks' (#10110) PaperMC/Paper@259bc76 Pass system properties to maven repo session (#10117) PaperMC/Paper@b2a6d57 Validate ResourceLocation in NBT reading PaperMC/Paper@7eaff48 [ci skip] Replace some magic values with constant references PaperMC/Paper@19a6202 Fix experience & improvements to block events (#8067) PaperMC/Paper@8379027 Fix cmd permission levels for command blocks (#7404) PaperMC/Paper@a93acc4 Fix EntityChangePoseEvent being called during worldgen (#10120) PaperMC/Paper@25a99b1 Fix BlockDestroyEvents effectBlock not being set (#10131) PaperMC/Paper@a58e29d Fix a borked update of 'Properly handle BlockBreakEvent#isDropItems' (#10134) PaperMC/Paper@570cfb4 Validate missed resource location parsing PaperMC/Paper@e46276e Fixup NamespacedKey parsing PaperMC/Paper@f1c5f01 [ci skip] Fix typo PaperMC/Paper@07b956e Fix tests by disabling them
247 lines
11 KiB
Diff
247 lines
11 KiB
Diff
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
|
From: Samsuik <kfian294ma4@gmail.com>
|
|
Date: Fri, 24 Mar 2023 16:29:21 +0000
|
|
Subject: [PATCH] Reduce deltaMovement Allocations
|
|
|
|
|
|
diff --git a/src/main/java/net/minecraft/world/entity/Entity.java b/src/main/java/net/minecraft/world/entity/Entity.java
|
|
index 33a317696c62243952bbf686ff3e52a776672599..8cae7a1ac496995ebe59ad88c56fbc424ca98930 100644
|
|
--- a/src/main/java/net/minecraft/world/entity/Entity.java
|
|
+++ b/src/main/java/net/minecraft/world/entity/Entity.java
|
|
@@ -1237,7 +1237,7 @@ public abstract class Entity implements Nameable, EntityAccess, CommandSource, S
|
|
this.tryCheckInsideBlocks();
|
|
float f = this.getBlockSpeedFactor();
|
|
|
|
- this.setDeltaMovement(this.getDeltaMovement().multiply((double) f, 1.0D, (double) f));
|
|
+ this.multiplyDeltaMovement((double) f, 1.0D, (double) f); // Sakura - reduce movement allocations
|
|
// Paper start - remove expensive streams from here
|
|
boolean noneMatch = true;
|
|
AABB fireSearchBox = this.getBoundingBox().deflate(1.0E-6D);
|
|
@@ -2053,6 +2053,7 @@ public abstract class Entity implements Nameable, EntityAccess, CommandSource, S
|
|
public void moveTo(double x, double y, double z, float yaw, float pitch) {
|
|
// Paper - cancel entity velocity if teleported
|
|
if (!preserveMotion) {
|
|
+ this.movementDirty = false; // Sakura
|
|
this.deltaMovement = Vec3.ZERO;
|
|
} else {
|
|
this.preserveMotion = false;
|
|
@@ -3455,29 +3456,33 @@ public abstract class Entity implements Nameable, EntityAccess, CommandSource, S
|
|
}
|
|
|
|
public void onAboveBubbleCol(boolean drag) {
|
|
- Vec3 vec3d = this.getDeltaMovement();
|
|
+ // Sakura start - reduce movement allocations
|
|
+ // Vec3 vec3d = this.getDeltaMovement();
|
|
+ this.syncDeltaMovement();
|
|
double d0;
|
|
|
|
if (drag) {
|
|
- d0 = Math.max(-0.9D, vec3d.y - 0.03D);
|
|
+ d0 = Math.max(-0.9D, movementY - 0.03D);
|
|
} else {
|
|
- d0 = Math.min(1.8D, vec3d.y + 0.1D);
|
|
+ d0 = Math.min(1.8D, movementY + 0.1D);
|
|
}
|
|
|
|
- this.setDeltaMovement(vec3d.x, d0, vec3d.z);
|
|
+ this.setDeltaMovement(movementX, d0, movementZ);
|
|
}
|
|
|
|
public void onInsideBubbleColumn(boolean drag) {
|
|
- Vec3 vec3d = this.getDeltaMovement();
|
|
+ // Vec3 vec3d = this.getDeltaMovement();
|
|
+ this.syncDeltaMovement();
|
|
double d0;
|
|
|
|
if (drag) {
|
|
- d0 = Math.max(-0.3D, vec3d.y - 0.03D);
|
|
+ d0 = Math.max(-0.3D, movementY - 0.03D);
|
|
} else {
|
|
- d0 = Math.min(0.7D, vec3d.y + 0.06D);
|
|
+ d0 = Math.min(0.7D, movementY + 0.06D);
|
|
}
|
|
|
|
- this.setDeltaMovement(vec3d.x, d0, vec3d.z);
|
|
+ this.setDeltaMovement(movementX, d0, movementZ);
|
|
+ // Sakura end
|
|
this.resetFallDistance();
|
|
}
|
|
|
|
@@ -4471,16 +4476,19 @@ public abstract class Entity implements Nameable, EntityAccess, CommandSource, S
|
|
vec3d = vec3d.normalize();
|
|
}
|
|
|
|
- Vec3 vec3d2 = this.getDeltaMovement();
|
|
+ // Sakura start - reduce movement allocations
|
|
+ // Vec3 vec3d2 = this.getDeltaMovement();
|
|
+ this.syncDeltaMovement();
|
|
|
|
vec3d = vec3d.scale(speed * 1.0D);
|
|
double d3 = 0.003D;
|
|
|
|
- if (Math.abs(vec3d2.x) < 0.003D && Math.abs(vec3d2.z) < 0.003D && vec3d.length() < 0.0045000000000000005D) {
|
|
+ if (Math.abs(movementX) < 0.003D && Math.abs(movementZ) < 0.003D && vec3d.length() < 0.0045000000000000005D) {
|
|
vec3d = vec3d.normalize().scale(0.0045000000000000005D);
|
|
}
|
|
|
|
- this.setDeltaMovement(this.getDeltaMovement().add(vec3d));
|
|
+ this.addDeltaMovement(vec3d.x, vec3d.y, vec3d.z);
|
|
+ // Sakura end
|
|
}
|
|
|
|
this.fluidHeight.put(tag, d1);
|
|
@@ -4551,11 +4559,53 @@ public abstract class Entity implements Nameable, EntityAccess, CommandSource, S
|
|
return this.chunkPosition;
|
|
}
|
|
|
|
+ // Sakura start - reduce movement allocations
|
|
+ private double movementX;
|
|
+ private double movementY;
|
|
+ private double movementZ;
|
|
+ private boolean movementDirty;
|
|
+
|
|
+ public void addDeltaMovement(double x, double y, double z) {
|
|
+ syncDeltaMovement();
|
|
+ movementX += x;
|
|
+ movementY += y;
|
|
+ movementZ += z;
|
|
+ }
|
|
+
|
|
+ public void scaleDeltaMovement(double n) {
|
|
+ syncDeltaMovement();
|
|
+ movementX *= n;
|
|
+ movementY *= n;
|
|
+ movementZ *= n;
|
|
+ }
|
|
+
|
|
+ public void multiplyDeltaMovement(double x, double y, double z) {
|
|
+ syncDeltaMovement();
|
|
+ movementX *= x;
|
|
+ movementY *= y;
|
|
+ movementZ *= z;
|
|
+ }
|
|
+
|
|
+ private void updateDeltaMovement() {
|
|
+ if (movementDirty) {
|
|
+ deltaMovement = new Vec3(movementX, movementY, movementZ);
|
|
+ movementDirty = false;
|
|
+ }
|
|
+ }
|
|
+
|
|
+ private void syncDeltaMovement() {
|
|
+ if (!movementDirty) {
|
|
+ setDeltaMovement(deltaMovement.x, deltaMovement.y, deltaMovement.z);
|
|
+ }
|
|
+ }
|
|
+
|
|
public Vec3 getDeltaMovement() {
|
|
+ updateDeltaMovement();
|
|
return this.deltaMovement;
|
|
}
|
|
|
|
public void setDeltaMovement(Vec3 velocity) {
|
|
+ movementDirty = false;
|
|
synchronized (this.posLock) { // Paper
|
|
this.deltaMovement = velocity;
|
|
} // Paper
|
|
@@ -4566,7 +4616,11 @@ public abstract class Entity implements Nameable, EntityAccess, CommandSource, S
|
|
}
|
|
|
|
public void setDeltaMovement(double x, double y, double z) {
|
|
- this.setDeltaMovement(new Vec3(x, y, z));
|
|
+ movementX = x;
|
|
+ movementY = y;
|
|
+ movementZ = z;
|
|
+ movementDirty = true;
|
|
+ // Sakura end
|
|
}
|
|
|
|
public final int getBlockX() {
|
|
diff --git a/src/main/java/net/minecraft/world/entity/item/FallingBlockEntity.java b/src/main/java/net/minecraft/world/entity/item/FallingBlockEntity.java
|
|
index 3ec931c9aa9e2857e0c24eeb47c1048ace05f6fe..ec8488a2ab16950052a3bff04be6e3ecc3b44891 100644
|
|
--- a/src/main/java/net/minecraft/world/entity/item/FallingBlockEntity.java
|
|
+++ b/src/main/java/net/minecraft/world/entity/item/FallingBlockEntity.java
|
|
@@ -145,7 +145,7 @@ public class FallingBlockEntity extends Entity {
|
|
|
|
++this.time;
|
|
if (!this.isNoGravity()) {
|
|
- this.setDeltaMovement(this.getDeltaMovement().add(0.0D, -0.04D, 0.0D));
|
|
+ this.addDeltaMovement(0.0D, -0.04D, 0.0D); // Sakura - reduce movement allocations
|
|
}
|
|
|
|
this.move(MoverType.SELF, this.getDeltaMovement());
|
|
@@ -192,7 +192,7 @@ public class FallingBlockEntity extends Entity {
|
|
} else {
|
|
BlockState iblockdata = this.level().getBlockState(blockposition);
|
|
|
|
- this.setDeltaMovement(this.getDeltaMovement().multiply(0.7D, -0.5D, 0.7D));
|
|
+ this.multiplyDeltaMovement(0.7D, -0.5D, 0.7D); // Sakura - reduce movement allocations
|
|
if (!iblockdata.is(Blocks.MOVING_PISTON)) {
|
|
if (!this.cancelDrop) {
|
|
boolean flag2 = iblockdata.canBeReplaced((BlockPlaceContext) (new DirectionalPlaceContext(this.level(), blockposition, Direction.DOWN, ItemStack.EMPTY, Direction.UP)));
|
|
@@ -259,7 +259,7 @@ public class FallingBlockEntity extends Entity {
|
|
}
|
|
}
|
|
|
|
- this.setDeltaMovement(this.getDeltaMovement().scale(0.98D));
|
|
+ this.scaleDeltaMovement(0.98D); // Sakura - reduce movement allocations
|
|
}
|
|
}
|
|
|
|
diff --git a/src/main/java/net/minecraft/world/entity/item/PrimedTnt.java b/src/main/java/net/minecraft/world/entity/item/PrimedTnt.java
|
|
index 62a3cd512d473d5ed673386d5c15091a09426945..12067c0372ad2803ffa2501a8296496a9ce7b292 100644
|
|
--- a/src/main/java/net/minecraft/world/entity/item/PrimedTnt.java
|
|
+++ b/src/main/java/net/minecraft/world/entity/item/PrimedTnt.java
|
|
@@ -74,7 +74,7 @@ public class PrimedTnt extends Entity implements TraceableEntity {
|
|
public void tick() {
|
|
if (this.level().spigotConfig.maxTntTicksPerTick > 0 && ++this.level().spigotConfig.currentPrimedTnt > this.level().spigotConfig.maxTntTicksPerTick) { return; } // Spigot
|
|
if (!this.isNoGravity()) {
|
|
- this.setDeltaMovement(this.getDeltaMovement().add(0.0D, -0.04D, 0.0D));
|
|
+ this.addDeltaMovement(0.0D, -0.04D, 0.0D); // Sakura - reduce movement allocations
|
|
}
|
|
|
|
this.move(MoverType.SELF, this.getDeltaMovement());
|
|
@@ -84,9 +84,9 @@ public class PrimedTnt extends Entity implements TraceableEntity {
|
|
return;
|
|
}
|
|
// Paper end
|
|
- this.setDeltaMovement(this.getDeltaMovement().scale(0.98D));
|
|
+ this.scaleDeltaMovement(0.98D); // Sakura - reduce movement allocations
|
|
if (this.onGround()) {
|
|
- this.setDeltaMovement(this.getDeltaMovement().multiply(0.7D, -0.5D, 0.7D));
|
|
+ this.multiplyDeltaMovement(0.7D, -0.5D, 0.7D); // Sakura - reduce movement allocations
|
|
}
|
|
|
|
int i = this.getFuse() - 1;
|
|
diff --git a/src/main/java/net/minecraft/world/level/Explosion.java b/src/main/java/net/minecraft/world/level/Explosion.java
|
|
index 9cd244090c294927a7a92c920854d2282ea3f021..3d4a75302d72bdbe47d0efbe08c89401dbe22a87 100644
|
|
--- a/src/main/java/net/minecraft/world/level/Explosion.java
|
|
+++ b/src/main/java/net/minecraft/world/level/Explosion.java
|
|
@@ -619,10 +619,11 @@ public class Explosion {
|
|
d8 *= d13;
|
|
d9 *= d13;
|
|
d10 *= d13;
|
|
- Vec3 vec3d1 = new Vec3(d8, d9, d10);
|
|
+ // Sakura - moved down
|
|
|
|
- entity.setDeltaMovement(entity.getDeltaMovement().add(vec3d1));
|
|
+ entity.addDeltaMovement(d8, d9, d10); // Sakura reduce deltamovement allocations
|
|
if (entity instanceof Player) {
|
|
+ Vec3 vec3d1 = new Vec3(d8, d9, d10); // Sakura
|
|
Player entityhuman = (Player) entity;
|
|
|
|
if (!entityhuman.isSpectator() && (!entityhuman.isCreative() || !entityhuman.getAbilities().flying) && !level.paperConfig().environment.disableExplosionKnockback) { // Paper - Disable explosion knockback
|
|
diff --git a/src/main/java/net/minecraft/world/level/block/Block.java b/src/main/java/net/minecraft/world/level/block/Block.java
|
|
index e21867d3956078bb0db4ceed45e5811e9acd7377..c2daf4421b5838fe57dc16184c4a5a8c190fa641 100644
|
|
--- a/src/main/java/net/minecraft/world/level/block/Block.java
|
|
+++ b/src/main/java/net/minecraft/world/level/block/Block.java
|
|
@@ -468,7 +468,7 @@ public class Block extends BlockBehaviour implements ItemLike {
|
|
}
|
|
|
|
public void updateEntityAfterFallOn(BlockGetter world, Entity entity) {
|
|
- entity.setDeltaMovement(entity.getDeltaMovement().multiply(1.0D, 0.0D, 1.0D));
|
|
+ entity.multiplyDeltaMovement(1.0D, 0.0D, 1.0D); // Sakura
|
|
}
|
|
|
|
public ItemStack getCloneItemStack(LevelReader world, BlockPos pos, BlockState state) {
|