Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Updates EffEquip, CondIsWearing, and adds CondIsSaddled #6849

Merged
merged 24 commits into from
Dec 15, 2024
Merged
Show file tree
Hide file tree
Changes from 14 commits
Commits
Show all changes
24 commits
Select commit Hold shift + click to select a range
72e1898
Add wolf and update horse support
cheeezburga Jul 2, 2024
03a0cdd
Fixed star imports
cheeezburga Jul 2, 2024
bb25458
Merge branch 'dev/feature' into update-eff-equip
cheeezburga Aug 30, 2024
d14fdcb
Some more updates to EffEquip and it's test
cheeezburga Aug 30, 2024
430a0ab
Merge branch 'dev/feature' into update-eff-equip
cheeezburga Sep 2, 2024
e50ec03
Adds saddle condition and changes some small EffEquip stuff
cheeezburga Sep 2, 2024
94af02a
Adds saddle test and changes CondIsSaddled to avoid potential conflict
cheeezburga Sep 3, 2024
9e42efe
Just some tiny changes to CondIsWearing
cheeezburga Sep 3, 2024
d59ea69
Updates EffEquip and its test
cheeezburga Sep 3, 2024
b601a72
Merge branch 'dev/feature' into update-eff-equip
cheeezburga Sep 3, 2024
f90975e
Fixes wolf armor test failing
cheeezburga Sep 3, 2024
0ebb2ff
Merge remote-tracking branch 'origin/update-eff-equip' into update-ef…
cheeezburga Sep 3, 2024
880556d
Apply suggestions from code review
cheeezburga Sep 3, 2024
04a8d4e
Suggestions and stuff
cheeezburga Sep 3, 2024
90094ef
Suggestions
cheeezburga Sep 5, 2024
2c2c284
Suggestions (Nullable annotation)
cheeezburga Sep 6, 2024
f8ab358
Fixes entity equipment being checked per type instead of per entity
cheeezburga Sep 6, 2024
76c5d9c
Suggestion
cheeezburga Sep 14, 2024
8b772c2
Merge branch 'dev/feature' into update-eff-equip
cheeezburga Sep 14, 2024
33719f0
Small change to description
cheeezburga Sep 14, 2024
0827751
Merge branch 'dev/feature' into update-eff-equip
cheeezburga Oct 2, 2024
83a0c6c
Merge branch 'dev/feature' into update-eff-equip
cheeezburga Oct 5, 2024
5058a00
Merge branch 'dev/feature' into update-eff-equip
sovdeeth Oct 13, 2024
fc6f4e0
Merge branch 'dev/feature' into update-eff-equip
sovdeeth Dec 15, 2024
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
51 changes: 51 additions & 0 deletions src/main/java/ch/njol/skript/conditions/CondIsSaddled.java
Original file line number Diff line number Diff line change
@@ -0,0 +1,51 @@
package ch.njol.skript.conditions;

import ch.njol.skript.conditions.base.PropertyCondition;
import ch.njol.skript.doc.Description;
import ch.njol.skript.doc.Examples;
import ch.njol.skript.doc.Name;
import ch.njol.skript.doc.Since;
import ch.njol.skript.lang.Expression;
import ch.njol.skript.lang.SkriptParser.ParseResult;
import ch.njol.util.Kleenean;
import org.bukkit.Material;
import org.bukkit.entity.AbstractHorse;
import org.bukkit.entity.LivingEntity;
import org.bukkit.entity.Steerable;
import org.bukkit.inventory.ItemStack;

@Name("Is Saddled")
@Description("Checks whether a given entity (horse or steerable) is wearing a saddle.")
@Examples("send whether {_horse} is saddled")
@Since("INSERT VERSION")
public class CondIsSaddled extends PropertyCondition<LivingEntity> {

static {
register(CondIsSaddled.class, "[exact:(exactly|properly)] saddled", "livingentities");
cheeezburga marked this conversation as resolved.
Show resolved Hide resolved
}
cheeezburga marked this conversation as resolved.
Show resolved Hide resolved

private boolean exact;

@Override
public boolean init(Expression<?>[] exprs, int matchedPattern, Kleenean isDelayed, ParseResult parseResult) {
exact = parseResult.hasTag("exact");
return super.init(exprs, matchedPattern, isDelayed, parseResult);
}

@Override
public boolean check(LivingEntity entity) {
if (entity instanceof Steerable steerable) {
return steerable.hasSaddle();
} else if (entity instanceof AbstractHorse horse) {
ItemStack saddle = horse.getInventory().getSaddle();
return exact ? (saddle != null && saddle.equals(new ItemStack(Material.SADDLE))) : (saddle != null);
}
return false;
}

@Override
protected String getPropertyName() {
return exact ? "properly saddled" : "saddled";
}

}
83 changes: 36 additions & 47 deletions src/main/java/ch/njol/skript/conditions/CondIsWearing.java
Original file line number Diff line number Diff line change
@@ -1,29 +1,5 @@
/**
* This file is part of Skript.
*
* Skript is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* Skript is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with Skript. If not, see <http://www.gnu.org/licenses/>.
*
* Copyright Peter Güttinger, SkriptLang team and contributors
*/
package ch.njol.skript.conditions;

import org.bukkit.entity.LivingEntity;
import org.bukkit.event.Event;
import org.bukkit.inventory.EntityEquipment;
import org.bukkit.inventory.ItemStack;
import org.eclipse.jdt.annotation.Nullable;

import ch.njol.skript.aliases.ItemType;
import ch.njol.skript.conditions.base.PropertyCondition;
import ch.njol.skript.conditions.base.PropertyCondition.PropertyType;
Expand All @@ -35,56 +11,69 @@
import ch.njol.skript.lang.Expression;
import ch.njol.skript.lang.SkriptParser.ParseResult;
import ch.njol.util.Kleenean;
import org.bukkit.entity.LivingEntity;
import org.bukkit.event.Event;
import org.bukkit.inventory.EntityEquipment;
import org.bukkit.inventory.EquipmentSlot;
import org.bukkit.inventory.ItemStack;
import org.eclipse.jdt.annotation.Nullable;
cheeezburga marked this conversation as resolved.
Show resolved Hide resolved

import java.util.Arrays;

/**
* @author Peter Güttinger
*/
@Name("Is Wearing")
@Description("Checks whether a player is wearing some armour.")
@Examples({"player is wearing an iron chestplate and iron leggings",
"player is wearing all diamond armour"})
@Description("Checks whether an entity is wearing some items (usually armor).")
@Examples({
"player is wearing an iron chestplate and iron leggings",
"player is wearing all diamond armour",
"target is wearing wolf armor"
})
@Since("1.0")
public class CondIsWearing extends Condition {

static {
PropertyCondition.register(CondIsWearing.class, "wearing %itemtypes%", "livingentities");
}

@SuppressWarnings("null")
@SuppressWarnings("NotNullFieldNotInitialized")
private Expression<LivingEntity> entities;
@SuppressWarnings("null")
@SuppressWarnings("NotNullFieldNotInitialized")
private Expression<ItemType> types;

@SuppressWarnings({"unchecked", "null"})
@Override
public boolean init(final Expression<?>[] vars, final int matchedPattern, final Kleenean isDelayed, final ParseResult parseResult) {
public boolean init(Expression<?>[] vars, int matchedPattern, Kleenean isDelayed, ParseResult parseResult) {
entities = (Expression<LivingEntity>) vars[0];
types = (Expression<ItemType>) vars[1];
setNegated(matchedPattern == 1);
return true;
}

@Override
public boolean check(final Event e) {
return entities.check(e,
en -> types.check(e,
t -> {
EntityEquipment equip = en.getEquipment();
if (equip == null)
return false; // No equipment -> not wearing anything
for (final ItemStack is : equip.getArmorContents()) {
if (t.isOfType(is) ^ t.isAll())
return !t.isAll();
public boolean check(Event event) {
return entities.check(event,
entity -> types.check(event,
type -> {
EntityEquipment equipment = entity.getEquipment();
if (equipment == null)
return false; // spigot nullability, no identifier as to why this occurs

ItemStack[] contents = Arrays.stream(EquipmentSlot.values())
.map(equipment::getItem)
.toArray(ItemStack[]::new);
cheeezburga marked this conversation as resolved.
Show resolved Hide resolved

for (ItemStack content : contents) {
if (type.isOfType(content) ^ type.isAll())
return !type.isAll();
}
return t.isAll();
return type.isAll();
}),
isNegated());
}

@Override
public String toString(final @Nullable Event e, final boolean debug) {
return PropertyCondition.toString(this, PropertyType.BE, e, debug, entities,
"wearing " + types.toString(e, debug));
public String toString(@Nullable Event event, boolean debug) {
return PropertyCondition.toString(this, PropertyType.BE, event, debug, entities,
"wearing " + types.toString(event, debug));
}

}
116 changes: 52 additions & 64 deletions src/main/java/ch/njol/skript/effects/EffEquip.java
Original file line number Diff line number Diff line change
@@ -1,77 +1,64 @@
/**
* This file is part of Skript.
*
* Skript is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* Skript is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with Skript. If not, see <http://www.gnu.org/licenses/>.
*
* Copyright Peter Güttinger, SkriptLang team and contributors
*/
package ch.njol.skript.effects;

import ch.njol.skript.Skript;
import ch.njol.skript.aliases.ItemData;
import ch.njol.skript.aliases.ItemType;
import ch.njol.skript.bukkitutil.PlayerUtils;
import ch.njol.skript.doc.Description;
import ch.njol.skript.doc.Examples;
import ch.njol.skript.doc.Name;
import ch.njol.skript.doc.Since;
import ch.njol.skript.lang.Effect;
import ch.njol.skript.lang.Expression;
import ch.njol.skript.lang.SkriptParser.ParseResult;
import ch.njol.util.Kleenean;
import org.bukkit.Material;
import org.bukkit.Tag;
import org.bukkit.entity.AbstractHorse;
import org.bukkit.entity.ChestedHorse;
import org.bukkit.entity.Horse;
import org.bukkit.entity.LivingEntity;
import org.bukkit.entity.Llama;
import org.bukkit.entity.Pig;
import org.bukkit.entity.Player;
import org.bukkit.entity.Steerable;
import org.bukkit.entity.Wolf;
import org.bukkit.event.Event;
import org.bukkit.inventory.AbstractHorseInventory;
import org.bukkit.inventory.EntityEquipment;
import org.bukkit.inventory.Inventory;
import org.bukkit.inventory.EquipmentSlot;
import org.bukkit.inventory.HorseInventory;
import org.bukkit.inventory.ItemStack;
import org.bukkit.inventory.LlamaInventory;
import org.eclipse.jdt.annotation.Nullable;
cheeezburga marked this conversation as resolved.
Show resolved Hide resolved

import ch.njol.skript.Skript;
import ch.njol.skript.aliases.Aliases;
import ch.njol.skript.aliases.ItemType;
import ch.njol.skript.bukkitutil.PlayerUtils;
import ch.njol.skript.doc.Description;
import ch.njol.skript.doc.Examples;
import ch.njol.skript.doc.Name;
import ch.njol.skript.doc.Since;
import ch.njol.skript.lang.Effect;
import ch.njol.skript.lang.Expression;
import ch.njol.skript.lang.SkriptParser.ParseResult;
import ch.njol.util.Kleenean;
import org.jetbrains.annotations.UnknownNullability;

@Name("Equip")
@Description("Equips or unequips an entity with some given armor. This will replace any armor that the entity is wearing.")
@Description({
"Equips or unequips an entity with the given itemtypes (usually armor).",
"This effect will replace any armor that the entity is already wearing."
})
@Examples({
"equip player with diamond helmet",
"equip player with all diamond armor",
"unequip diamond chestplate from player",
"unequip all armor from player",
"unequip player's armor"
})
@Since("1.0, 2.7 (multiple entities, unequip)")
@Since("1.0, 2.7 (multiple entities, unequip), INSERT VERSION (wolves)")
public class EffEquip extends Effect {

static {
Skript.registerEffect(EffEquip.class,
"equip [%livingentities%] with %itemtypes%",
"make %livingentities% wear %itemtypes%",
"unequip %itemtypes% [from %livingentities%]",
"unequip %livingentities%'[s] (armor|equipment)"
"unequip %livingentities%'[s] (armo[u]r|equipment)"
);
}

@SuppressWarnings("NotNullFieldNotInitialized")
private Expression<LivingEntity> entities;
@Nullable
@UnknownNullability
private Expression<ItemType> itemTypes;
cheeezburga marked this conversation as resolved.
Show resolved Hide resolved

private boolean equip = true;
Expand All @@ -93,19 +80,22 @@ public boolean init(Expression<?>[] exprs, int matchedPattern, Kleenean isDelaye
return true;
}

private static final boolean SUPPORTS_STEERABLE = Skript.classExists("org.bukkit.entity.Steerable");

private static ItemType CHESTPLATE;
private static ItemType LEGGINGS;
cheeezburga marked this conversation as resolved.
Show resolved Hide resolved
private static ItemType BOOTS;
private static ItemType CARPET;
private static ItemType WOLF_ARMOR;
private static final ItemType HORSE_ARMOR = new ItemType(Material.IRON_HORSE_ARMOR, Material.GOLDEN_HORSE_ARMOR, Material.DIAMOND_HORSE_ARMOR);
private static final ItemType SADDLE = new ItemType(Material.SADDLE);
private static final ItemType CHEST = new ItemType(Material.CHEST);

static {
boolean usesWoolCarpetTag = Skript.fieldExists(Tag.class, "WOOL_CARPET");
CARPET = new ItemType(usesWoolCarpetTag ? Tag.WOOL_CARPETS : Tag.CARPETS);

boolean hasWolfArmor = Skript.fieldExists(Material.class, "WOLF_ARMOR");
WOLF_ARMOR = hasWolfArmor ? new ItemType(Material.WOLF_ARMOR) : new ItemType();

// added in 1.20.6
if (Skript.fieldExists(Tag.class, "ITEM_CHEST_ARMOR")) {
CHESTPLATE = new ItemType(Tag.ITEMS_CHEST_ARMOR);
Expand Down Expand Up @@ -146,9 +136,7 @@ public boolean init(Expression<?>[] exprs, int matchedPattern, Kleenean isDelaye
}
}



private static final ItemType[] ALL_EQUIPMENT = new ItemType[] {CHESTPLATE, LEGGINGS, BOOTS, HORSE_ARMOR, SADDLE, CHEST, CARPET};
private static final ItemType[] ALL_EQUIPMENT = new ItemType[] {CHESTPLATE, LEGGINGS, BOOTS, HORSE_ARMOR, SADDLE, CHEST, CARPET, WOLF_ARMOR};

@Override
protected void execute(Event event) {
Expand All @@ -161,44 +149,44 @@ protected void execute(Event event) {
unequipHelmet = true;
}
for (LivingEntity entity : entities.getArray(event)) {
if (SUPPORTS_STEERABLE && entity instanceof Steerable) {
if (entity instanceof Steerable steerable) {
for (ItemType itemType : itemTypes) {
if (SADDLE.isOfType(itemType.getMaterial())) {
((Steerable) entity).setSaddle(equip);
}
}
} else if (entity instanceof Pig) {
for (ItemType itemType : itemTypes) {
if (itemType.isOfType(Material.SADDLE)) {
((Pig) entity).setSaddle(equip);
break;
steerable.setSaddle(equip);
}
}
} else if (entity instanceof Llama) {
LlamaInventory inv = ((Llama) entity).getInventory();
} else if (entity instanceof Llama llama) {
LlamaInventory inv = llama.getInventory();
for (ItemType itemType : itemTypes) {
for (ItemStack item : itemType.getAll()) {
if (CARPET.isOfType(item)) {
inv.setDecor(equip ? item : null);
} else if (CHEST.isOfType(item)) {
((Llama) entity).setCarryingChest(equip);
llama.setCarryingChest(equip);
}
}
}
} else if (entity instanceof AbstractHorse) {
// Spigot's API is bad, just bad... Abstract horse doesn't have horse inventory!
Inventory inv = ((AbstractHorse) entity).getInventory();
} else if (entity instanceof AbstractHorse horse) {
AbstractHorseInventory inv = horse.getInventory();
for (ItemType itemType : itemTypes) {
for (ItemStack item : itemType.getAll()) {
if (SADDLE.isOfType(item)) {
inv.setItem(0, equip ? item : null); // Slot 0=saddle
} else if (HORSE_ARMOR.isOfType(item)) {
inv.setItem(1, equip ? item : null); // Slot 1=armor
} else if (CHEST.isOfType(item) && entity instanceof ChestedHorse) {
((ChestedHorse) entity).setCarryingChest(equip);
inv.setSaddle(equip ? item : null);
} else if (HORSE_ARMOR.isOfType(item) && entity instanceof Horse) {
((HorseInventory) inv).setArmor(equip ? item : null);
} else if (CHEST.isOfType(item) && entity instanceof ChestedHorse chestedHorse) { // a Donkey, Mule, Llama or TraderLlama. NOT a Horse
chestedHorse.setCarryingChest(equip);
}
}
}
} else if (entity instanceof Wolf wolf) {
EntityEquipment equipment = wolf.getEquipment();
for (ItemType itemType : itemTypes) {
for (ItemStack item : itemType.getAll()) {
if (WOLF_ARMOR.isOfType(item))
equipment.setItem(EquipmentSlot.BODY, equip ? item : null);
}
}
} else {
EntityEquipment equipment = entity.getEquipment();
if (equipment == null)
Expand All @@ -220,8 +208,8 @@ protected void execute(Event event) {
equipment.setHelmet(null);
}
}
if (entity instanceof Player)
PlayerUtils.updateInventory((Player) entity);
if (entity instanceof Player player)
PlayerUtils.updateInventory(player);
}
}
}
Expand Down
Loading