Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
package dev.mrshawn.deathmessages;

import com.tcoded.folialib.FoliaLib;
import dev.mrshawn.deathmessages.api.PlayerManager;
import dev.mrshawn.deathmessages.api.PlayerCtx;
import dev.mrshawn.deathmessages.commands.CommandManager;
import dev.mrshawn.deathmessages.commands.TabCompleter;
import dev.mrshawn.deathmessages.commands.alias.CommandDeathMessagesToggle;
Expand All @@ -16,7 +16,7 @@
import dev.mrshawn.deathmessages.listeners.EntityDeath;
import dev.mrshawn.deathmessages.listeners.OnCommand;
import dev.mrshawn.deathmessages.listeners.OnInteract;
import dev.mrshawn.deathmessages.listeners.OnJoin;
import dev.mrshawn.deathmessages.listeners.OnConnection;
import dev.mrshawn.deathmessages.listeners.OnMove;
import dev.mrshawn.deathmessages.listeners.OnQuit;
import dev.mrshawn.deathmessages.listeners.PlayerDeath;
Expand All @@ -36,6 +36,7 @@
import org.bukkit.Bukkit;
import org.bukkit.GameRule;
import org.bukkit.World;
import org.bukkit.entity.Player;
import org.bukkit.event.EventPriority;
import org.bukkit.plugin.java.JavaPlugin;

Expand Down Expand Up @@ -105,7 +106,7 @@ private void initListeners() {
new EntityDeath(),
new OnCommand(),
new OnInteract(),
new OnJoin(),
new OnConnection(),
new OnMove(),
new OnQuit(),
new PlayerDeath()
Expand All @@ -125,7 +126,9 @@ private void initHooks() {
}

private void initOnlinePlayers() {
getServer().getOnlinePlayers().forEach(PlayerManager::new);
for (Player player : getServer().getOnlinePlayers()) {
PlayerCtx.create(new PlayerCtx(player));
}
}

private void checkGameRules() {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -15,36 +15,35 @@
import java.util.UUID;
import java.util.concurrent.ConcurrentHashMap;

// Class designed to keep track of damage and data to mobs that were damaged by players

public class EntityManager {
/**
* A class for storing entity's death cotext information, for tracking entity that is killed players
*/
public class EntityCtx {

private final Entity entity;
private final UUID entityUUID;
private final UUID uuid;
private final MobType mobType;
private DamageCause damageCause;
private @Nullable PlayerManager lastPlayerDamager;
private @Nullable PlayerCtx lastPlayerDamager;
private Entity lastExplosiveEntity;
private Projectile lastPlayerProjectile;
private Location lastLocation;

private @Nullable WrappedTask lastPlayerTask;

private static final Map<UUID, EntityManager> entities = new ConcurrentHashMap<>();
private static final Map<UUID, EntityCtx> ENTITY_CONTEXTS = new ConcurrentHashMap<>();

public EntityManager(Entity entity, UUID entityUUID, MobType mobType) {
public EntityCtx(Entity entity, MobType mobType) {
this.entity = entity;
this.entityUUID = entityUUID;
this.uuid = entity.getUniqueId();
this.mobType = mobType;
entities.put(entityUUID, this);
}

public Entity getEntity() {
return entity;
}

public UUID getEntityUUID() {
return entityUUID;
public UUID getUUID() {
return uuid;
}

public MobType getMobType() {
Expand All @@ -55,29 +54,29 @@ public void setLastDamageCause(DamageCause damageCause) {
this.damageCause = damageCause;
}

public DamageCause getLastDamage() {
public DamageCause getLastDamageCause() {
return damageCause;
}

public void setLastPlayerDamager(PlayerManager pm) {
public void setLastPlayerDamager(PlayerCtx damagerCtx) {
setLastExplosiveEntity(null);
setLastProjectileEntity(null);

this.lastPlayerDamager = pm;
this.lastPlayerDamager = damagerCtx;

if (lastPlayerTask != null) {
lastPlayerTask.cancel();
}
lastPlayerTask = DeathMessages.getInstance().foliaLib.getScheduler().runLater(this::destroy, FileStore.CONFIG.getInt(Config.EXPIRE_LAST_DAMAGE_EXPIRE_ENTITY) * 20L);
lastPlayerTask = DeathMessages.getInstance().foliaLib.getScheduler().runLater(() -> EntityCtx.remove(this.getUUID()), FileStore.CONFIG.getInt(Config.EXPIRE_LAST_DAMAGE_EXPIRE_ENTITY) * 20L);
this.damageCause = DamageCause.CUSTOM;
}

public @Nullable PlayerManager getLastPlayerDamager() {
public @Nullable PlayerCtx getLastPlayerDamager() {
return lastPlayerDamager;
}

public void setLastExplosiveEntity(Entity e) {
this.lastExplosiveEntity = e;
public void setLastExplosiveEntity(Entity entity) {
this.lastExplosiveEntity = entity;
}

public Entity getLastExplosiveEntity() {
Expand All @@ -100,11 +99,16 @@ public Location getLastLocation() {
return lastLocation;
}

public static @Nullable EntityManager getEntity(UUID uuid) {
return entities.get(uuid);
public static @Nullable EntityCtx of(UUID uuid) {
return ENTITY_CONTEXTS.get(uuid);
}

public static void create(EntityCtx entityCtx) {
UUID uuid = entityCtx.getUUID();
ENTITY_CONTEXTS.put(uuid, entityCtx);
}

public void destroy() {
entities.remove(this.entityUUID);
public static void remove(UUID uuid) {
ENTITY_CONTEXTS.remove(uuid);
}
}
Loading