mirror of
https://github.com/PaperMC/Paper.git
synced 2025-01-24 09:16:06 +01:00
SPIGOT-6175: Fix generating loot tables for entities
By: md_5 <git@md-5.net>
This commit is contained in:
parent
5eb09a7d93
commit
0410e56149
1 changed files with 17 additions and 8 deletions
|
@ -75,28 +75,28 @@ public class CraftLootTable implements org.bukkit.loot.LootTable {
|
||||||
WorldServer handle = ((CraftWorld) loc.getWorld()).getHandle();
|
WorldServer handle = ((CraftWorld) loc.getWorld()).getHandle();
|
||||||
|
|
||||||
LootTableInfo.Builder builder = new LootTableInfo.Builder(handle);
|
LootTableInfo.Builder builder = new LootTableInfo.Builder(handle);
|
||||||
builder.set(LootContextParameters.ORIGIN, new Vec3D(loc.getX(), loc.getY(), loc.getZ()));
|
setMaybe(builder, LootContextParameters.ORIGIN, new Vec3D(loc.getX(), loc.getY(), loc.getZ()));
|
||||||
if (getHandle() != LootTable.EMPTY) {
|
if (getHandle() != LootTable.EMPTY) {
|
||||||
// builder.luck(context.getLuck());
|
// builder.luck(context.getLuck());
|
||||||
|
|
||||||
if (context.getLootedEntity() != null) {
|
if (context.getLootedEntity() != null) {
|
||||||
Entity nmsLootedEntity = ((CraftEntity) context.getLootedEntity()).getHandle();
|
Entity nmsLootedEntity = ((CraftEntity) context.getLootedEntity()).getHandle();
|
||||||
builder.set(LootContextParameters.THIS_ENTITY, nmsLootedEntity);
|
setMaybe(builder, LootContextParameters.THIS_ENTITY, nmsLootedEntity);
|
||||||
builder.set(LootContextParameters.DAMAGE_SOURCE, DamageSource.GENERIC);
|
setMaybe(builder, LootContextParameters.DAMAGE_SOURCE, DamageSource.GENERIC);
|
||||||
builder.set(LootContextParameters.ORIGIN, nmsLootedEntity.getPositionVector());
|
setMaybe(builder, LootContextParameters.ORIGIN, nmsLootedEntity.getPositionVector());
|
||||||
}
|
}
|
||||||
|
|
||||||
if (context.getKiller() != null) {
|
if (context.getKiller() != null) {
|
||||||
EntityHuman nmsKiller = ((CraftHumanEntity) context.getKiller()).getHandle();
|
EntityHuman nmsKiller = ((CraftHumanEntity) context.getKiller()).getHandle();
|
||||||
builder.set(LootContextParameters.KILLER_ENTITY, nmsKiller);
|
setMaybe(builder, LootContextParameters.KILLER_ENTITY, nmsKiller);
|
||||||
// If there is a player killer, damage source should reflect that in case loot tables use that information
|
// If there is a player killer, damage source should reflect that in case loot tables use that information
|
||||||
builder.set(LootContextParameters.DAMAGE_SOURCE, DamageSource.playerAttack(nmsKiller));
|
setMaybe(builder, LootContextParameters.DAMAGE_SOURCE, DamageSource.playerAttack(nmsKiller));
|
||||||
builder.set(LootContextParameters.LAST_DAMAGE_PLAYER, nmsKiller); // SPIGOT-5603 - Set minecraft:killed_by_player
|
setMaybe(builder, LootContextParameters.LAST_DAMAGE_PLAYER, nmsKiller); // SPIGOT-5603 - Set minecraft:killed_by_player
|
||||||
}
|
}
|
||||||
|
|
||||||
// SPIGOT-5603 - Use LootContext#lootingModifier
|
// SPIGOT-5603 - Use LootContext#lootingModifier
|
||||||
if (context.getLootingModifier() != LootContext.DEFAULT_LOOT_MODIFIER) {
|
if (context.getLootingModifier() != LootContext.DEFAULT_LOOT_MODIFIER) {
|
||||||
builder.set(LootContextParameters.LOOTING_MOD, context.getLootingModifier());
|
setMaybe(builder, LootContextParameters.LOOTING_MOD, context.getLootingModifier());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -115,8 +115,17 @@ public class CraftLootTable implements org.bukkit.loot.LootTable {
|
||||||
return builder.build(nmsBuilder.build());
|
return builder.build(nmsBuilder.build());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private <T> void setMaybe(LootTableInfo.Builder builder, LootContextParameter<T> param, T value) {
|
||||||
|
if (getHandle().getLootContextParameterSet().getRequired().contains(param) || getHandle().getLootContextParameterSet().getOptional().contains(param)) {
|
||||||
|
builder.set(param, value);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
public static LootContext convertContext(LootTableInfo info) {
|
public static LootContext convertContext(LootTableInfo info) {
|
||||||
Vec3D position = info.getContextParameter(LootContextParameters.ORIGIN);
|
Vec3D position = info.getContextParameter(LootContextParameters.ORIGIN);
|
||||||
|
if (position == null) {
|
||||||
|
position = info.getContextParameter(LootContextParameters.THIS_ENTITY).getPositionVector(); // Every vanilla context has origin or this_entity, see LootContextParameterSets
|
||||||
|
}
|
||||||
Location location = new Location(info.getWorld().getWorld(), position.getX(), position.getY(), position.getZ());
|
Location location = new Location(info.getWorld().getWorld(), position.getX(), position.getY(), position.getZ());
|
||||||
LootContext.Builder contextBuilder = new LootContext.Builder(location);
|
LootContext.Builder contextBuilder = new LootContext.Builder(location);
|
||||||
|
|
||||||
|
|
Loading…
Add table
Reference in a new issue