all api patches done*
*still waiting for leaf to port datafixer to 1.18 so i can do entity serialization
This commit is contained in:
		
					parent
					
						
							
								f538a34f38
							
						
					
				
			
			
				commit
				
					
						8868dd196d
					
				
			
		
					 33 changed files with 11 additions and 24 deletions
				
			
		|  | @ -1,168 +0,0 @@ | |||
| From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001 | ||||
| From: dodison <kacpik@mapik.eu> | ||||
| Date: Mon, 26 Jul 2021 17:32:36 +0200 | ||||
| Subject: [PATCH] Add critical damage API | ||||
| 
 | ||||
| 
 | ||||
| diff --git a/src/main/java/net/minecraft/world/damagesource/DamageSource.java b/src/main/java/net/minecraft/world/damagesource/DamageSource.java
 | ||||
| index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
 | ||||
| --- a/src/main/java/net/minecraft/world/damagesource/DamageSource.java
 | ||||
| +++ b/src/main/java/net/minecraft/world/damagesource/DamageSource.java
 | ||||
| @@ -0,0 +0,0 @@ public class DamageSource {
 | ||||
|          return this; | ||||
|      } | ||||
|      // CraftBukkit end | ||||
| +    // Paper start - add critical damage API
 | ||||
| +    private boolean critical;
 | ||||
| +    public boolean isCritical() {
 | ||||
| +        return this.critical;
 | ||||
| +    }
 | ||||
| +    public DamageSource critical() {
 | ||||
| +        return this.critical(true);
 | ||||
| +    }
 | ||||
| +    public DamageSource critical(boolean critical) {
 | ||||
| +        this.critical = critical;
 | ||||
| +        return this;
 | ||||
| +    }
 | ||||
| +    // Paper end
 | ||||
|   | ||||
|      public static DamageSource sting(LivingEntity attacker) { | ||||
|          return new EntityDamageSource("sting", attacker); | ||||
| diff --git a/src/main/java/net/minecraft/world/entity/LivingEntity.java b/src/main/java/net/minecraft/world/entity/LivingEntity.java
 | ||||
| index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
 | ||||
| --- a/src/main/java/net/minecraft/world/entity/LivingEntity.java
 | ||||
| +++ b/src/main/java/net/minecraft/world/entity/LivingEntity.java
 | ||||
| @@ -0,0 +0,0 @@ public abstract class LivingEntity extends Entity {
 | ||||
|          return this.hasEffect(MobEffects.JUMP) ? (double) (0.1F * (float) (this.getEffect(MobEffects.JUMP).getAmplifier() + 1)) : 0.0D; | ||||
|      } | ||||
|   | ||||
| +    protected long lastJumpTime = 0L; // Paper - add critical damage API
 | ||||
|      protected void jumpFromGround() { | ||||
|          double d0 = (double) this.getJumpPower() + this.getJumpBoostPower(); | ||||
|          Vec3 vec3d = this.getDeltaMovement(); | ||||
| +        // Paper start - add critical damage API
 | ||||
| +        long time = System.nanoTime();
 | ||||
| +        boolean canCrit = true;
 | ||||
| +        if (this instanceof net.minecraft.world.entity.player.Player) {
 | ||||
| +            canCrit = false;
 | ||||
| +            if (time - this.lastJumpTime > (long)(0.250e9)) {
 | ||||
| +                this.lastJumpTime = time;
 | ||||
| +                canCrit = true;
 | ||||
| +            }
 | ||||
| +        }
 | ||||
| +        // Paper end - add critical damage API
 | ||||
|   | ||||
|          this.setDeltaMovement(vec3d.x, d0, vec3d.z); | ||||
|          if (this.isSprinting()) { | ||||
|              float f = this.getYRot() * 0.017453292F; | ||||
|   | ||||
| -            this.setDeltaMovement(this.getDeltaMovement().add((double) (-Mth.sin(f) * 0.2F), 0.0D, (double) (Mth.cos(f) * 0.2F)));
 | ||||
| +            if (canCrit) this.setDeltaMovement(this.getDeltaMovement().add((double) (-Mth.sin(f) * 0.2F), 0.0D, (double) (Mth.cos(f) * 0.2F))); // Paper - add critical damage API
 | ||||
|          } | ||||
|   | ||||
|          this.hasImpulse = true; | ||||
| diff --git a/src/main/java/net/minecraft/world/entity/player/Player.java b/src/main/java/net/minecraft/world/entity/player/Player.java
 | ||||
| index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
 | ||||
| --- a/src/main/java/net/minecraft/world/entity/player/Player.java
 | ||||
| +++ b/src/main/java/net/minecraft/world/entity/player/Player.java
 | ||||
| @@ -0,0 +0,0 @@ public abstract class Player extends LivingEntity {
 | ||||
|                          flag1 = true; | ||||
|                      } | ||||
|   | ||||
| -                    boolean flag2 = flag && this.fallDistance > 0.0F && !this.onGround && !this.onClimbable() && !this.isInWater() && !this.hasEffect(MobEffects.BLINDNESS) && !this.isPassenger() && target instanceof LivingEntity;
 | ||||
| +                    boolean flag2 = flag && this.fallDistance > 0.0F && !this.onGround && !this.onClimbable() && !this.isInWater() && !this.hasEffect(MobEffects.BLINDNESS) && !this.isPassenger() && target instanceof LivingEntity; // Paper - Add critical damage API - conflict on change
 | ||||
|   | ||||
|                      flag2 = flag2 && !level.paperConfig.disablePlayerCrits; // Paper | ||||
|                      flag2 = flag2 && !this.isSprinting(); | ||||
| @@ -0,0 +0,0 @@ public abstract class Player extends LivingEntity {
 | ||||
|                      } | ||||
|   | ||||
|                      Vec3 vec3d = target.getDeltaMovement(); | ||||
| -                    boolean flag5 = target.hurt(DamageSource.playerAttack(this), f);
 | ||||
| +                    boolean flag5 = target.hurt(DamageSource.playerAttack(this).critical(flag2), f); // Paper - add critical damage API
 | ||||
|   | ||||
|                      if (flag5) { | ||||
|                          if (i > 0) { | ||||
| @@ -0,0 +0,0 @@ public abstract class Player extends LivingEntity {
 | ||||
|   | ||||
|                                  if (entityliving != this && entityliving != target && !this.isAlliedTo(entityliving) && (!(entityliving instanceof ArmorStand) || !((ArmorStand) entityliving).isMarker()) && this.distanceToSqr((Entity) entityliving) < 9.0D) { | ||||
|                                      // CraftBukkit start - Only apply knockback if the damage hits | ||||
| -                                    if (entityliving.hurt(DamageSource.playerAttack(this).sweep(), f4)) {
 | ||||
| +                                    if (entityliving.hurt(DamageSource.playerAttack(this).sweep().critical(flag2), f4)) { // Paper - add critical damage API
 | ||||
|                                      entityliving.knockback(0.4000000059604645D, (double) Mth.sin(this.getYRot() * 0.017453292F), (double) (-Mth.cos(this.getYRot() * 0.017453292F)), this); // Paper | ||||
|                                      } | ||||
|                                      // CraftBukkit end | ||||
| diff --git a/src/main/java/net/minecraft/world/entity/projectile/AbstractArrow.java b/src/main/java/net/minecraft/world/entity/projectile/AbstractArrow.java
 | ||||
| index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
 | ||||
| --- a/src/main/java/net/minecraft/world/entity/projectile/AbstractArrow.java
 | ||||
| +++ b/src/main/java/net/minecraft/world/entity/projectile/AbstractArrow.java
 | ||||
| @@ -0,0 +0,0 @@ public abstract class AbstractArrow extends Projectile {
 | ||||
|              } | ||||
|          } | ||||
|   | ||||
| +        if (this.isCritArrow()) damagesource = damagesource.critical(); // Paper - add critical damage API
 | ||||
|          boolean flag = entity.getType() == EntityType.ENDERMAN; | ||||
|          int k = entity.getRemainingFireTicks(); | ||||
|   | ||||
| diff --git a/src/main/java/org/bukkit/craftbukkit/event/CraftEventFactory.java b/src/main/java/org/bukkit/craftbukkit/event/CraftEventFactory.java
 | ||||
| index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
 | ||||
| --- a/src/main/java/org/bukkit/craftbukkit/event/CraftEventFactory.java
 | ||||
| +++ b/src/main/java/org/bukkit/craftbukkit/event/CraftEventFactory.java
 | ||||
| @@ -0,0 +0,0 @@ public class CraftEventFactory {
 | ||||
|                  } else { | ||||
|                      damageCause = DamageCause.ENTITY_EXPLOSION; | ||||
|                  } | ||||
| -                event = new EntityDamageByEntityEvent(damager.getBukkitEntity(), entity.getBukkitEntity(), damageCause, modifiers, modifierFunctions);
 | ||||
| +                event = new EntityDamageByEntityEvent(damager.getBukkitEntity(), entity.getBukkitEntity(), damageCause, modifiers, modifierFunctions, source.isCritical()); // Paper - add critical damage API
 | ||||
|              } | ||||
|              event.setCancelled(cancelled); | ||||
|   | ||||
| @@ -0,0 +0,0 @@ public class CraftEventFactory {
 | ||||
|                  cause = DamageCause.THORNS; | ||||
|              } | ||||
|   | ||||
| -            return CraftEventFactory.callEntityDamageEvent(damager, entity, cause, modifiers, modifierFunctions, cancelled);
 | ||||
| +            return CraftEventFactory.callEntityDamageEvent(damager, entity, cause, modifiers, modifierFunctions, cancelled, source.isCritical()); // Paper - add critical damage API
 | ||||
|          } else if (source == DamageSource.OUT_OF_WORLD) { | ||||
|              EntityDamageEvent event = new EntityDamageByBlockEvent(null, entity.getBukkitEntity(), DamageCause.VOID, modifiers, modifierFunctions); | ||||
|              event.setCancelled(cancelled); | ||||
| @@ -0,0 +0,0 @@ public class CraftEventFactory {
 | ||||
|              } else { | ||||
|                  throw new IllegalStateException(String.format("Unhandled damage of %s by %s from %s", entity, damager.getHandle(), source.msgId)); | ||||
|              } | ||||
| -            EntityDamageEvent event = new EntityDamageByEntityEvent(damager, entity.getBukkitEntity(), cause, modifiers, modifierFunctions);
 | ||||
| +            EntityDamageEvent event = new EntityDamageByEntityEvent(damager, entity.getBukkitEntity(), cause, modifiers, modifierFunctions, source.isCritical()); // Paper - add critical damage API
 | ||||
|              event.setCancelled(cancelled); | ||||
|              CraftEventFactory.callEvent(event); | ||||
|              if (!event.isCancelled()) { | ||||
| @@ -0,0 +0,0 @@ public class CraftEventFactory {
 | ||||
|          } | ||||
|   | ||||
|          if (cause != null) { | ||||
| -            return CraftEventFactory.callEntityDamageEvent(null, entity, cause, modifiers, modifierFunctions, cancelled);
 | ||||
| +            return CraftEventFactory.callEntityDamageEvent(null, entity, cause, modifiers, modifierFunctions, cancelled, source.isCritical()); // Paper - add critical damage API
 | ||||
|          } | ||||
|   | ||||
|          throw new IllegalStateException(String.format("Unhandled damage of %s from %s", entity, source.msgId)); | ||||
|      } | ||||
|   | ||||
| +    @Deprecated // Paper - Add critical damage API
 | ||||
|      private static EntityDamageEvent callEntityDamageEvent(Entity damager, Entity damagee, DamageCause cause, Map<DamageModifier, Double> modifiers, Map<DamageModifier, Function<? super Double, Double>> modifierFunctions) { | ||||
|          return CraftEventFactory.callEntityDamageEvent(damager, damagee, cause, modifiers, modifierFunctions, false); | ||||
|      } | ||||
|   | ||||
| +    // Paper start - Add critical damage API
 | ||||
| +    @Deprecated
 | ||||
|      private static EntityDamageEvent callEntityDamageEvent(Entity damager, Entity damagee, DamageCause cause, Map<DamageModifier, Double> modifiers, Map<DamageModifier, Function<? super Double, Double>> modifierFunctions, boolean cancelled) { | ||||
| +        return CraftEventFactory.callEntityDamageEvent(damager, damagee, cause, modifiers, modifierFunctions, false, false);
 | ||||
| +    }
 | ||||
| +
 | ||||
| +    private static EntityDamageEvent callEntityDamageEvent(Entity damager, Entity damagee, DamageCause cause, Map<DamageModifier, Double> modifiers, Map<DamageModifier, Function<? super Double, Double>> modifierFunctions, boolean cancelled, boolean critical) {
 | ||||
| +        // Paper end
 | ||||
|          EntityDamageEvent event; | ||||
|          if (damager != null) { | ||||
| -            event = new EntityDamageByEntityEvent(damager.getBukkitEntity(), damagee.getBukkitEntity(), cause, modifiers, modifierFunctions);
 | ||||
| +            event = new EntityDamageByEntityEvent(damager.getBukkitEntity(), damagee.getBukkitEntity(), cause, modifiers, modifierFunctions, critical); // Paper - add critical damage API
 | ||||
|          } else { | ||||
|              event = new EntityDamageEvent(damagee.getBukkitEntity(), cause, modifiers, modifierFunctions); | ||||
|          } | ||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Josh Roy
				Josh Roy