2023-03-15 03:30:00 +11:00
|
|
|
--- a/net/minecraft/world/damagesource/DamageSources.java
|
|
|
|
+++ b/net/minecraft/world/damagesource/DamageSources.java
|
2024-10-23 02:15:00 +11:00
|
|
|
@@ -43,9 +43,15 @@
|
2023-03-15 03:30:00 +11:00
|
|
|
private final DamageSource stalagmite;
|
2023-06-08 01:30:00 +10:00
|
|
|
private final DamageSource outsideBorder;
|
|
|
|
private final DamageSource genericKill;
|
2023-03-15 03:30:00 +11:00
|
|
|
+ // CraftBukkit start
|
2024-02-11 09:54:25 +11:00
|
|
|
+ private final DamageSource melting;
|
|
|
|
+ private final DamageSource poison;
|
2023-03-15 03:30:00 +11:00
|
|
|
|
2024-12-11 22:26:55 +01:00
|
|
|
public DamageSources(RegistryAccess registryManager) {
|
|
|
|
this.damageTypes = registryManager.lookupOrThrow(Registries.DAMAGE_TYPE);
|
2023-03-15 03:30:00 +11:00
|
|
|
+ this.melting = this.source(DamageTypes.ON_FIRE).melting();
|
|
|
|
+ this.poison = this.source(DamageTypes.MAGIC).poison();
|
|
|
|
+ // CraftBukkit end
|
|
|
|
this.inFire = this.source(DamageTypes.IN_FIRE);
|
2024-06-14 01:05:00 +10:00
|
|
|
this.campfire = this.source(DamageTypes.CAMPFIRE);
|
2023-03-15 03:30:00 +11:00
|
|
|
this.lightningBolt = this.source(DamageTypes.LIGHTNING_BOLT);
|
2024-03-09 14:13:04 -08:00
|
|
|
@@ -83,7 +89,17 @@
|
|
|
|
|
2024-12-11 22:26:55 +01:00
|
|
|
private DamageSource source(ResourceKey<DamageType> key, @Nullable Entity source, @Nullable Entity attacker) {
|
|
|
|
return new DamageSource(this.damageTypes.getOrThrow(key), source, attacker);
|
2024-03-09 14:13:04 -08:00
|
|
|
+ }
|
2024-12-11 22:26:55 +01:00
|
|
|
+
|
2024-02-11 09:54:25 +11:00
|
|
|
+ // CraftBukkit start
|
|
|
|
+ public DamageSource melting() {
|
|
|
|
+ return this.melting;
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ public DamageSource poison() {
|
|
|
|
+ return this.poison;
|
2024-03-09 14:13:04 -08:00
|
|
|
}
|
2024-02-11 09:54:25 +11:00
|
|
|
+ // CraftBukkit end
|
2024-12-11 22:26:55 +01:00
|
|
|
|
2024-02-11 09:54:25 +11:00
|
|
|
public DamageSource inFire() {
|
|
|
|
return this.inFire;
|
2024-03-09 14:13:04 -08:00
|
|
|
@@ -254,7 +270,7 @@
|
2024-05-04 08:15:51 +10:00
|
|
|
}
|
|
|
|
|
2024-12-11 22:26:55 +01:00
|
|
|
public DamageSource explosion(@Nullable Entity source, @Nullable Entity attacker) {
|
|
|
|
- return this.source(attacker != null && source != null ? DamageTypes.PLAYER_EXPLOSION : DamageTypes.EXPLOSION, source, attacker);
|
2024-03-09 14:13:04 -08:00
|
|
|
+ return this.source(attacker != null && source != null ? DamageTypes.PLAYER_EXPLOSION : DamageTypes.EXPLOSION, source, attacker); // Paper - revert to vanilla
|
2024-12-11 22:26:55 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
public DamageSource sonicBoom(Entity attacker) {
|
2024-03-09 14:13:04 -08:00
|
|
|
@@ -262,9 +278,15 @@
|
2024-05-04 08:15:51 +10:00
|
|
|
}
|
|
|
|
|
2024-12-11 22:26:55 +01:00
|
|
|
public DamageSource badRespawnPointExplosion(Vec3 position) {
|
|
|
|
- return new DamageSource(this.damageTypes.getOrThrow(DamageTypes.BAD_RESPAWN_POINT), position);
|
|
|
|
+ // CraftBukkit start
|
|
|
|
+ return this.badRespawnPointExplosion(position, null);
|
2024-04-29 20:08:56 +10:00
|
|
|
}
|
|
|
|
|
2024-12-11 22:26:55 +01:00
|
|
|
+ public DamageSource badRespawnPointExplosion(Vec3 vec3d, org.bukkit.block.BlockState blockState) {
|
2024-10-23 02:15:00 +11:00
|
|
|
+ return new DamageSource(this.damageTypes.getOrThrow(DamageTypes.BAD_RESPAWN_POINT), vec3d).directBlockState(blockState);
|
2024-04-29 20:08:56 +10:00
|
|
|
+ // CraftBukkit end
|
2024-12-11 22:26:55 +01:00
|
|
|
+ }
|
|
|
|
+
|
2024-04-29 20:08:56 +10:00
|
|
|
public DamageSource outOfBorder() {
|
2024-12-11 22:26:55 +01:00
|
|
|
return this.outsideBorder;
|
|
|
|
}
|