mirror of
https://github.com/Minestom/Minestom.git
synced 2025-01-03 23:17:48 +01:00
Merge pull request #268 from Kebab11noel/summon-fix
Added entity class argument to /summon command
This commit is contained in:
commit
e9655c75f4
@ -3,17 +3,22 @@ package demo.commands;
|
|||||||
import net.minestom.server.command.CommandSender;
|
import net.minestom.server.command.CommandSender;
|
||||||
import net.minestom.server.command.builder.Command;
|
import net.minestom.server.command.builder.Command;
|
||||||
import net.minestom.server.command.builder.CommandContext;
|
import net.minestom.server.command.builder.CommandContext;
|
||||||
|
import net.minestom.server.command.builder.arguments.ArgumentEnum;
|
||||||
import net.minestom.server.command.builder.arguments.ArgumentType;
|
import net.minestom.server.command.builder.arguments.ArgumentType;
|
||||||
import net.minestom.server.command.builder.arguments.minecraft.registry.ArgumentEntityType;
|
import net.minestom.server.command.builder.arguments.minecraft.registry.ArgumentEntityType;
|
||||||
import net.minestom.server.command.builder.arguments.relative.ArgumentRelativeVec3;
|
import net.minestom.server.command.builder.arguments.relative.ArgumentRelativeVec3;
|
||||||
import net.minestom.server.command.builder.condition.Conditions;
|
import net.minestom.server.command.builder.condition.Conditions;
|
||||||
import net.minestom.server.entity.Entity;
|
import net.minestom.server.entity.Entity;
|
||||||
|
import net.minestom.server.entity.EntityCreature;
|
||||||
|
import net.minestom.server.entity.EntityType;
|
||||||
|
import net.minestom.server.entity.LivingEntity;
|
||||||
import org.jetbrains.annotations.NotNull;
|
import org.jetbrains.annotations.NotNull;
|
||||||
|
|
||||||
public class SummonCommand extends Command {
|
public class SummonCommand extends Command {
|
||||||
|
|
||||||
private final ArgumentEntityType entity;
|
private final ArgumentEntityType entity;
|
||||||
private final ArgumentRelativeVec3 pos;
|
private final ArgumentRelativeVec3 pos;
|
||||||
|
private final ArgumentEnum<EntityClass> entityClass;
|
||||||
|
|
||||||
public SummonCommand() {
|
public SummonCommand() {
|
||||||
super("summon");
|
super("summon");
|
||||||
@ -21,12 +26,36 @@ public class SummonCommand extends Command {
|
|||||||
|
|
||||||
entity = ArgumentType.EntityType("entity type");
|
entity = ArgumentType.EntityType("entity type");
|
||||||
pos = ArgumentType.RelativeVec3("pos");
|
pos = ArgumentType.RelativeVec3("pos");
|
||||||
addSyntax(this::execute, entity, pos);
|
entityClass = ArgumentType.Enum("class", EntityClass.class);
|
||||||
|
entityClass.setFormat(ArgumentEnum.Format.LOWER_CASED);
|
||||||
|
entityClass.setDefaultValue(EntityClass.CREATURE);
|
||||||
|
addSyntax(this::execute, entity, pos, entityClass);
|
||||||
|
setDefaultExecutor((sender, context) -> sender.sendMessage("Usage: /summon <type> <x> <y> <z> <class>"));
|
||||||
}
|
}
|
||||||
|
|
||||||
private void execute(@NotNull CommandSender commandSender, @NotNull CommandContext commandContext) {
|
private void execute(@NotNull CommandSender commandSender, @NotNull CommandContext commandContext) {
|
||||||
final Entity entity = new Entity(commandContext.get(this.entity));
|
final Entity entity = commandContext.get(entityClass).instantiate(commandContext.get(this.entity));
|
||||||
//noinspection ConstantConditions - One couldn't possibly execute a command without being in an instance
|
//noinspection ConstantConditions - One couldn't possibly execute a command without being in an instance
|
||||||
entity.setInstance(commandSender.asPlayer().getInstance(), commandContext.get(pos).from(commandSender.asPlayer()).toPosition());
|
entity.setInstance(commandSender.asPlayer().getInstance(), commandContext.get(pos).from(commandSender.asPlayer()).toPosition());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@SuppressWarnings("unused")
|
||||||
|
enum EntityClass {
|
||||||
|
BASE(Entity::new),
|
||||||
|
LIVING(LivingEntity::new),
|
||||||
|
CREATURE(EntityCreature::new);
|
||||||
|
private final EntityFactory factory;
|
||||||
|
|
||||||
|
EntityClass(EntityFactory factory) {
|
||||||
|
this.factory = factory;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Entity instantiate(EntityType type) {
|
||||||
|
return factory.newInstance(type);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
interface EntityFactory {
|
||||||
|
Entity newInstance(EntityType type);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user