8 Commits

Author SHA1 Message Date
YouHaveTrouble b89e332ed4 add more docs, add fromEntity method 2022-05-18 18:30:51 +02:00
YouHaveTrouble 301a358a60 well, that's awkward 2022-05-12 19:15:38 +02:00
YouHaveTrouble f5c33a9476 version bump 2022-05-12 19:09:19 +02:00
YouHaveTrouble 9403e87a32 lowercase 2022-05-12 19:08:02 +02:00
YouHaveTrouble 98a7774230 I'm sorry Toast but I've sinned 2022-05-12 19:07:37 +02:00
YouHaveTrouble 7452dca5e3 notnull and javadocs 2022-05-12 19:03:02 +02:00
YouHaveTrouble 48b44c7173 you better read that 2022-05-12 18:56:59 +02:00
YouHaveTrouble ae307863b4 you better read that 2022-05-12 18:56:18 +02:00
8 changed files with 89 additions and 11 deletions
+3 -3
View File
@@ -6,14 +6,14 @@
<groupId>me.youhavetrouble</groupId> <groupId>me.youhavetrouble</groupId>
<artifactId>Entiddy</artifactId> <artifactId>Entiddy</artifactId>
<version>1.0</version> <version>1.2.0</version>
<packaging>jar</packaging> <packaging>jar</packaging>
<name>EnTiddy</name> <name>Entiddy</name>
<description>A very serious library concerning entities</description> <description>A very serious library concerning entities</description>
<properties> <properties>
<java.version>1.8</java.version> <java.version>17</java.version>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding> <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
</properties> </properties>
+41
View File
@@ -0,0 +1,41 @@
Guys, I swear this is a serious library.
## Dependency
Current version: [![](https://jitpack.io/v/YouHaveTrouble/Entiddy.svg)](https://jitpack.io/#YouHaveTrouble/Entiddy)
### Maven
```xml
<repositories>
<repository>
<id>jitpack.io</id>
<url>https://jitpack.io</url>
</repository>
</repositories>
```
```xml
<dependency>
<groupId>com.github.YouHaveTrouble</groupId>
<artifactId>Entiddy</artifactId>
<version>VERSION</version>
</dependency>
```
### Gradle
```
allprojects {
repositories {
...
maven { url 'https://jitpack.io' }
}
}
```
```
dependencies {
implementation 'com.github.YouHaveTrouble:Entiddy:VERSION'
}
```
@@ -4,6 +4,7 @@ package me.youhavetrouble.entiddy;
import me.youhavetrouble.entiddy.SpecialEntities.JebSheep; import me.youhavetrouble.entiddy.SpecialEntities.JebSheep;
import me.youhavetrouble.entiddy.SpecialEntities.Johnny; import me.youhavetrouble.entiddy.SpecialEntities.Johnny;
import me.youhavetrouble.entiddy.SpecialEntities.KillerBunny; import me.youhavetrouble.entiddy.SpecialEntities.KillerBunny;
import me.youhavetrouble.entiddy.SpecialEntities.Toast;
import org.bukkit.entity.EntityType; import org.bukkit.entity.EntityType;
import org.bukkit.entity.LivingEntity; import org.bukkit.entity.LivingEntity;
import org.bukkit.entity.Player; import org.bukkit.entity.Player;
@@ -11,9 +12,28 @@ import org.jetbrains.annotations.NotNull;
public enum Entiddy { public enum Entiddy {
/**
* Killer bunny that attacks players monthy python style
*/
KILLER_BUNNY(EntityType.RABBIT, new KillerBunny()), KILLER_BUNNY(EntityType.RABBIT, new KillerBunny()),
/**
* Its wool cycles with interpolation through all dye colors
* Sheep with rgb lighting
*/
JEB_SHEEP(EntityType.SHEEP, new JebSheep()), JEB_SHEEP(EntityType.SHEEP, new JebSheep()),
JOHNNY(EntityType.VINDICATOR, new Johnny());
/**
* Johnny is hostile to basically every mob with few exceptions
* HERE'S JOHNNY
*/
JOHNNY(EntityType.VINDICATOR, new Johnny()),
/**
* Toast has the appearance of a black dutch, with a large black and white patch and more black fur around the face
* than the natural black and white spotted rabbit.
*/
TOAST(EntityType.RABBIT, new Toast());
private final EntityType entityType; private final EntityType entityType;
private final EntiddyInterface entiddy; private final EntiddyInterface entiddy;
@@ -40,12 +60,26 @@ public enum Entiddy {
entity.setCustomName("Grumm"); entity.setCustomName("Grumm");
} }
/**
* @return True if entity is one of special/easter egg entities
*/
public static boolean isSpecialEntity(@NotNull LivingEntity entity) { public static boolean isSpecialEntity(@NotNull LivingEntity entity) {
if (entity instanceof Player) return false; if (entity instanceof Player) return false;
for (Entiddy enTiddy: Entiddy.values()) { for (Entiddy entiddy: Entiddy.values()) {
if (enTiddy.entiddy().isInstance(entity)) return true; if (entiddy.entiddy().isInstance(entity)) return true;
} }
return false; return false;
} }
/**
* @return Special entity type or null
*/
public static Entiddy fromEntity(@NotNull LivingEntity entity) {
if (entity instanceof Player) return null;
for (Entiddy entiddy: Entiddy.values()) {
if (entiddy.entiddy().isInstance(entity)) return entiddy;
}
return null;
}
} }
@@ -15,6 +15,9 @@ public interface EntiddyInterface {
*/ */
Entity spawn(@NotNull Location location, @NotNull CreatureSpawnEvent.SpawnReason spawnReason); Entity spawn(@NotNull Location location, @NotNull CreatureSpawnEvent.SpawnReason spawnReason);
boolean isInstance(LivingEntity entity); /**
* @return True if the entity is an instance of the specific special/easter egg type
*/
boolean isInstance(@NotNull LivingEntity entity);
} }
@@ -20,7 +20,7 @@ public class JebSheep implements EntiddyInterface {
} }
@Override @Override
public boolean isInstance(LivingEntity entity) { public boolean isInstance(@NotNull LivingEntity entity) {
if (!(entity instanceof Rabbit)) return false; if (!(entity instanceof Rabbit)) return false;
return entity.getCustomName() != null && entity.getCustomName().equals("jeb_"); return entity.getCustomName() != null && entity.getCustomName().equals("jeb_");
} }
@@ -22,7 +22,7 @@ public class Johnny implements EntiddyInterface {
} }
@Override @Override
public boolean isInstance(LivingEntity entity) { public boolean isInstance(@NotNull LivingEntity entity) {
if (!(entity instanceof Vindicator)) return false; if (!(entity instanceof Vindicator)) return false;
return ((Vindicator) entity).isJohnny(); return ((Vindicator) entity).isJohnny();
} }
@@ -23,7 +23,7 @@ public class KillerBunny implements EntiddyInterface {
} }
@Override @Override
public boolean isInstance(LivingEntity entity) { public boolean isInstance(@NotNull LivingEntity entity) {
if (!(entity instanceof Rabbit)) return false; if (!(entity instanceof Rabbit)) return false;
return ((Rabbit) entity).getRabbitType().equals(Rabbit.Type.THE_KILLER_BUNNY); return ((Rabbit) entity).getRabbitType().equals(Rabbit.Type.THE_KILLER_BUNNY);
} }
@@ -20,7 +20,7 @@ public class Toast implements EntiddyInterface {
} }
@Override @Override
public boolean isInstance(LivingEntity entity) { public boolean isInstance(@NotNull LivingEntity entity) {
if (!(entity instanceof Rabbit)) return false; if (!(entity instanceof Rabbit)) return false;
return entity.getCustomName() != null && entity.getCustomName().equals("Toast"); return entity.getCustomName() != null && entity.getCustomName().equals("Toast");
} }