Group presets now use the InputParser system

This commit is contained in:
Esophose 2020-01-10 06:42:19 -07:00
parent b07f844d59
commit 2303696a09
2 changed files with 29 additions and 64 deletions

View file

@ -25,15 +25,16 @@ public class ParticlePlaceholderExpansion extends PlaceholderExpansion {
if (pplayer == null)
return null;
if (placeholder.equals("active_amount")) {
switch (placeholder) {
case "active_amount":
return String.valueOf(pplayer.getActiveParticles().size());
} else if (placeholder.equals("group_amount")) {
return String.valueOf(pplayer.getParticleGroups().size());
} else if (placeholder.equals("fixed_amount")) {
case "group_amount":
return String.valueOf(pplayer.getParticleGroups().size() - 1);
case "fixed_amount":
return String.valueOf(pplayer.getFixedParticles().size());
} else if (placeholder.equals("is_moving")) {
case "is_moving":
return String.valueOf(pplayer.isMoving());
} else if (placeholder.equals("can_see_particles")) {
case "can_see_particles":
return String.valueOf(pplayer.canSeeParticles());
}

View file

@ -9,7 +9,7 @@ import dev.esophose.playerparticles.particles.ParticleGroup;
import dev.esophose.playerparticles.particles.ParticleGroupPreset;
import dev.esophose.playerparticles.particles.ParticlePair;
import dev.esophose.playerparticles.styles.ParticleStyle;
import dev.esophose.playerparticles.util.ParticleUtils;
import dev.esophose.playerparticles.util.inputparser.InputParser;
import java.io.File;
import java.io.IOException;
import java.io.InputStream;
@ -96,8 +96,8 @@ public class ParticleGroupPresetManager extends Manager {
ConfigurationSection particleSection = groupSection.getConfigurationSection(stringId);
int id = Integer.parseInt(stringId);
ParticleEffect effect = ParticleEffect.fromName(particleSection.getString("effect"));
ParticleStyle style = ParticleStyle.fromName(particleSection.getString("style"));
ParticleEffect effect = new InputParser(null, new String[] { particleSection.getString("effect") }).next(ParticleEffect.class);
ParticleStyle style = new InputParser(null, new String[] { particleSection.getString("style") }).next(ParticleStyle.class);
if (effect == null) {
PlayerParticles.getInstance().getLogger().severe("Invalid effect name: '" + particleSection.getString("effect") + "'!");
@ -117,69 +117,33 @@ public class ParticleGroupPresetManager extends Manager {
String dataString = particleSection.getString("data");
if (dataString != null && !dataString.isEmpty()) {
String[] args = dataString.split(" ");
InputParser inputParser = new InputParser(null, args);
if (effect.hasProperty(ParticleProperty.COLORABLE)) {
if (effect == ParticleEffect.NOTE) {
if (args[0].equalsIgnoreCase("rainbow")) {
noteColorData = new NoteColor(99);
} else if (args[0].equalsIgnoreCase("random")) {
noteColorData = new NoteColor(98);
} else {
int note;
try {
note = Integer.parseInt(args[0]);
} catch (Exception e) {
PlayerParticles.getInstance().getLogger().severe("Invalid note: '" + args[0] + "'!");
noteColorData = inputParser.next(NoteColor.class);
if (noteColorData == null) {
PlayerParticles.getInstance().getLogger().severe("Invalid note: '" + dataString + "'!");
throw new Exception();
}
if (note < 0 || note > 23) {
PlayerParticles.getInstance().getLogger().severe("Invalid note: '" + args[0] + "'!");
throw new Exception();
}
noteColorData = new NoteColor(note);
}
} else {
if (args[0].equalsIgnoreCase("rainbow")) {
colorData = new OrdinaryColor(999, 999, 999);
} else if (args[0].equalsIgnoreCase("random")) {
colorData = new OrdinaryColor(998, 998, 998);
} else {
int r, g, b;
try {
r = Integer.parseInt(args[0]);
g = Integer.parseInt(args[1]);
b = Integer.parseInt(args[2]);
} catch (Exception e) {
PlayerParticles.getInstance().getLogger().severe("Invalid color: '" + args[0] + " " + args[1] + " " + args[2] + "'!");
colorData = inputParser.next(OrdinaryColor.class);
if (colorData == null) {
PlayerParticles.getInstance().getLogger().severe("Invalid color: '" + dataString + "'!");
throw new Exception();
}
if (r < 0 || r > 255 || g < 0 || g > 255 || b < 0 || b > 255) {
PlayerParticles.getInstance().getLogger().severe("Invalid color: '" + args[0] + " " + args[1] + " " + args[2] + "'!");
throw new Exception();
}
colorData = new OrdinaryColor(r, g, b);
}
}
} else if (effect.hasProperty(ParticleProperty.REQUIRES_MATERIAL_DATA)) {
if (effect == ParticleEffect.BLOCK || effect == ParticleEffect.FALLING_DUST) {
try {
blockData = ParticleUtils.closestMatch(args[0]);
if (blockData == null || !blockData.isBlock()) throw new Exception();
} catch (Exception e) {
PlayerParticles.getInstance().getLogger().severe("Invalid block: '" + args[0] + "'!");
blockData = inputParser.next(Material.class);
if (blockData == null || !blockData.isBlock()) {
PlayerParticles.getInstance().getLogger().severe("Invalid block: '" + dataString + "'!");
throw new Exception();
}
} else if (effect == ParticleEffect.ITEM) {
try {
itemData = ParticleUtils.closestMatch(args[0]);
if (itemData == null || itemData.isBlock()) throw new Exception();
} catch (Exception e) {
PlayerParticles.getInstance().getLogger().severe("Invalid item: '" + args[0] + "'!");
itemData = inputParser.next(Material.class);
if (itemData == null || itemData.isBlock()) {
PlayerParticles.getInstance().getLogger().severe("Invalid item: '" + dataString + "'!");
throw new Exception();
}
}