001/* 002 * Trident - A Multithreaded Server Alternative 003 * Copyright 2014 The TridentSDK Team 004 * 005 * Licensed under the Apache License, Version 2.0 (the "License"); 006 * you may not use this file except in compliance with the License. 007 * You may obtain a copy of the License at 008 * 009 * http://www.apache.org/licenses/LICENSE-2.0 010 * 011 * Unless required by applicable law or agreed to in writing, software 012 * distributed under the License is distributed on an "AS IS" BASIS, 013 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 014 * See the License for the specific language governing permissions and 015 * limitations under the License. 016 */ 017 018package net.tridentsdk.event.entity; 019 020import net.tridentsdk.entity.Entity; 021import net.tridentsdk.entity.LivingEntity; 022import net.tridentsdk.entity.living.Player; 023 024/** 025 * Called when an entity dies, especially if it was a LivingEntity 026 * 027 * @author The TridentSDK Team 028 * @since 0.3-alpha-DP 029 */ 030public class EntityDeathEvent extends EntityEvent { 031 /** 032 * @param entity the entity that has died 033 */ 034 public EntityDeathEvent(Entity entity) { 035 super(entity); 036 } 037 038 public EntityDamageEvent deathCause() { 039 return this.entity().lastDamageEvent(); 040 } 041 042 /** 043 * Returns a Player if a player was involved in the killing of this entity, else null 044 */ 045 public Player killedByPlayer() { 046 return this.entity().lastPlayerDamager(); 047 } 048 049 /** 050 * Returns whether or not a player was involved in the killing of this entity 051 */ 052 public boolean wasKilledByPlayer() { 053 return this.killedByPlayer() == null; 054 } 055 056 @Override 057 public LivingEntity entity() { 058 return (LivingEntity) super.entity(); 059 } 060} 061 062