use of com.elmakers.mine.bukkit.api.block.BlockData in project MagicPlugin by elBukkit.
the class SimulateBatch method process.
@Override
public int process(int maxBlocks) {
int processedBlocks = 0;
if (state == SimulationState.INITIALIZING) {
// Reset state
x = 0;
y = 0;
z = 0;
r = 0;
updatingIndex = 0;
bornBlocks.clear();
deadBlocks.clear();
liveBlocks.clear();
// Process the casting first, and only if specially configured to do so.
if (isAutomata) {
// Look for a target
target();
// reloads, so for now just bail and hope the timing works out.
if (heartBlock == null || !heartBlock.getChunk().isLoaded()) {
finish();
return processedBlocks;
}
// Check for death since activation (e.g. during delay period)
if (this.blockLimit < minBlocks) {
if (DEBUG) {
controller.getLogger().info("DIED with block count " + liveBlocks.size() + ", and block limit " + this.blockLimit);
}
die();
return processedBlocks;
}
// Reset potential new locations
potentialHeartBlocks.clear();
}
processedBlocks++;
state = SimulationState.SCANNING;
}
while (state == SimulationState.SCANNING && processedBlocks <= maxBlocks) {
simulateBlocks(x, y, z);
y++;
if (y > yRadius) {
y = 0;
if (x < radius) {
x++;
} else {
z--;
if (z < 0) {
r++;
z = r;
x = 0;
}
}
}
if (r > radius) {
state = SimulationState.UPDATING;
}
}
while (state == SimulationState.UPDATING && processedBlocks <= maxBlocks) {
int deadIndex = updatingIndex;
if (deadIndex >= 0 && deadIndex < deadBlocks.size()) {
Block killBlock = deadBlocks.get(deadIndex);
if (!killBlock.getChunk().isLoaded()) {
killBlock.getChunk().load();
return processedBlocks;
}
if (birthMaterial.is(killBlock)) {
removeBlock(killBlock);
} else {
// to re-simulate...
if (bornBlocks.size() > 0) {
bornBlocks.remove(bornBlocks.size() - 1);
}
}
processedBlocks++;
}
int bornIndex = updatingIndex - deadBlocks.size();
if (bornIndex >= 0 && bornIndex < bornBlocks.size()) {
Block birthBlock = bornBlocks.get(bornIndex);
if (!birthBlock.getChunk().isLoaded()) {
birthBlock.getChunk().load();
return processedBlocks;
}
createBlock(birthBlock);
}
updatingIndex++;
if (updatingIndex >= deadBlocks.size() + bornBlocks.size()) {
state = SimulationState.PRUNE;
// Wait at least a tick
return maxBlocks;
}
}
if (state == SimulationState.PRUNE) {
if (liveBlocks.isEmpty()) {
if (DEBUG) {
controller.getLogger().info("Died, no blocks are alive");
}
die();
return processedBlocks;
}
if (undoList != null) {
undoList.prune();
}
state = SimulationState.TARGETING;
}
// Each of the following states will end in this tick
if (state == SimulationState.TARGETING) {
if (isAutomata && potentialHeartBlocks.size() > 0) {
switch(targetMode) {
case HUNT:
Collections.sort(potentialHeartBlocks);
break;
case FLEE:
Collections.sort(potentialHeartBlocks);
break;
default:
Collections.shuffle(potentialHeartBlocks);
break;
}
// Find a valid block for the command
heartTargetBlock = null;
Block backupBlock = null;
for (Target target : potentialHeartBlocks) {
Block block = target.getBlock();
if (block != null && birthMaterial.is(block)) {
heartTargetBlock = block;
break;
}
}
// just use that one.
if (heartTargetBlock == null)
heartTargetBlock = backupBlock;
// Search for a power block
if (heartTargetBlock == null && DEBUG) {
controller.getLogger().info("Could not find a valid command block location");
}
}
if (DEBUG && heartTargetBlock != null) {
controller.getLogger().info("Moved: " + heartTargetBlock.getLocation().toVector().subtract(center.toVector()) + " from " + potentialHeartBlocks.size() + " potential locations");
}
state = SimulationState.HEART_UPDATE;
}
if (state == SimulationState.HEART_UPDATE) {
if (isAutomata) {
if (heartTargetBlock != null) {
if (!heartTargetBlock.getChunk().isLoaded()) {
finish();
return processedBlocks;
}
if (reflectChance > 0) {
com.elmakers.mine.bukkit.block.UndoList.getRegistry().unregisterReflective(heartTargetBlock);
}
heartBlock = heartTargetBlock;
Location newLocation = heartTargetBlock.getLocation();
newLocation.setPitch(center.getPitch());
newLocation.setYaw(center.getYaw());
center = newLocation;
mage.setLocation(newLocation);
} else {
if (DEBUG) {
controller.getLogger().info("Died, could not find target heart block");
}
die();
return processedBlocks;
}
}
delayTimeout = System.currentTimeMillis() + delay;
state = delay > 0 ? SimulationState.DELAY : SimulationState.CLEANUP;
}
if (state == SimulationState.DELAY) {
processedBlocks++;
if (System.currentTimeMillis() > delayTimeout) {
state = SimulationState.CLEANUP;
}
return processedBlocks;
}
if (state == SimulationState.CLEANUP) {
if (this.blockLimit <= 0) {
state = SimulationState.CHECK;
} else {
int undidCount = 0;
while (processedBlocks <= maxBlocks && undoList.size() > this.blockLimit) {
BlockData undid = undoList.undoNext(false);
if (undid == null)
break;
if (liveBlocks.remove(undid.getId())) {
undidCount++;
}
}
if (DEBUG && undidCount > 0) {
controller.getLogger().info("UNDID: " + undidCount + " remaining: " + liveBlocks.size() + "/" + blockLimit);
}
if (undoList.size() <= this.blockLimit) {
state = SimulationState.CHECK;
}
}
}
if (state == SimulationState.CHECK) {
int lostBlocks = 0;
if (undoList != null) {
Iterator<BlockData> iterator = undoList.iterator();
while (iterator.hasNext()) {
BlockData block = iterator.next();
long blockId = block.getId();
if (block.getMaterial() == deathMaterial && block.getBlock().getType() != birthMaterial.getMaterial()) {
liveBlocks.remove(blockId);
lostBlocks++;
this.blockLimit--;
}
if (!block.isDifferent()) {
undoList.removeFromMap(block);
iterator.remove();
}
}
}
if (lostBlocks > 0) {
if (DEBUG) {
controller.getLogger().info(spell.getKey() + " LOST " + lostBlocks + " blocks, remaining: " + this.liveBlocks.size() + "/" + this.blockLimit);
}
spell.playEffects("hurt");
}
state = SimulationState.FINISHED;
}
if (state == SimulationState.FINISHED) {
spell.playEffects("tick");
if (isAutomata) {
state = SimulationState.INITIALIZING;
} else {
finish();
}
}
return processedBlocks;
}
use of com.elmakers.mine.bukkit.api.block.BlockData in project MagicPlugin by elBukkit.
the class UndoBatch method process.
@Override
public int process(int maxBlocks) {
int processedBlocks = 0;
double undoSpeed = undoList.getUndoSpeed();
if (undoSpeed > 0 && listProcessed < listSize) {
partialWork += undoSpeed;
if (partialWork > 1) {
maxBlocks = (int) Math.floor(partialWork);
partialWork = partialWork - maxBlocks;
} else {
return 0;
}
}
while (undoList.size() > 0 && processedBlocks < maxBlocks) {
BlockData undone = undoList.undoNext(applyPhysics);
if (undone == null) {
break;
}
processedBlocks++;
listProcessed++;
}
if (undoList.size() == 0) {
finish();
}
return processedBlocks;
}
use of com.elmakers.mine.bukkit.api.block.BlockData in project MagicPlugin by elBukkit.
the class BlockList method save.
@Override
public void save(ConfigurationSection node) {
node.set("world", worldName);
List<String> blockData = new ArrayList<>();
if (blockList != null) {
for (BlockData block : blockList) {
blockData.add(block.toString());
}
node.set("blocks", blockData);
}
}
use of com.elmakers.mine.bukkit.api.block.BlockData in project MagicPlugin by elBukkit.
the class MagicCommandExecutor method onMagicList.
protected boolean onMagicList(CommandSender sender, String subCommand, String[] args) {
String usage = "Usage: magic list <wands|map|automata|tasks|schematics|entities|blocks>";
String listCommand = "";
if (args.length > 1) {
listCommand = args[1];
if (!api.hasPermission(sender, "Magic.commands.magic." + subCommand + "." + listCommand)) {
sendNoPermission(sender);
return false;
}
} else {
sender.sendMessage(ChatColor.GRAY + "For more specific information, add 'tasks', 'wands', 'maps', 'schematics', 'entities', 'blocks' or 'automata' parameter.");
MageController apiController = api.getController();
if (apiController != null && apiController instanceof MagicController) {
MagicController controller = (MagicController) apiController;
long timeout = controller.getPhysicsTimeout();
if (timeout > 0) {
long seconds = (timeout - System.currentTimeMillis()) / 1000;
sender.sendMessage(ChatColor.GREEN + "Physics handler active for another " + ChatColor.DARK_GREEN + seconds + ChatColor.GREEN + " seconds");
} else {
sender.sendMessage(ChatColor.GRAY + "Physics handler inactive");
}
}
Collection<Mage> mages = controller.getMages();
sender.sendMessage(ChatColor.AQUA + "Modified blocks (" + ChatColor.LIGHT_PURPLE + UndoList.getRegistry().getModified().size() + ChatColor.AQUA + ")");
sender.sendMessage(ChatColor.AQUA + "Watching blocks (" + ChatColor.LIGHT_PURPLE + UndoList.getRegistry().getWatching().size() + ChatColor.AQUA + ")");
sender.sendMessage(ChatColor.AQUA + "Registered breaking (" + ChatColor.LIGHT_PURPLE + UndoList.getRegistry().getBreaking().size() + ChatColor.AQUA + ")");
sender.sendMessage(ChatColor.AQUA + "Registered breakable (" + ChatColor.LIGHT_PURPLE + UndoList.getRegistry().getBreakable().size() + ChatColor.AQUA + ")");
sender.sendMessage(ChatColor.AQUA + "Registered reflective (" + ChatColor.LIGHT_PURPLE + UndoList.getRegistry().getReflective().size() + ChatColor.AQUA + ")");
sender.sendMessage(ChatColor.LIGHT_PURPLE + "Active mages: " + ChatColor.LIGHT_PURPLE + mages.size());
Collection<com.elmakers.mine.bukkit.api.block.UndoList> pendingUndo = api.getPendingUndo();
sender.sendMessage(ChatColor.AQUA + "Pending undo (" + ChatColor.LIGHT_PURPLE + pendingUndo.size() + ChatColor.AQUA + "): ");
long now = System.currentTimeMillis();
for (com.elmakers.mine.bukkit.api.block.UndoList undo : pendingUndo) {
long remainingTime = (undo.getScheduledTime() - now) / 1000;
sender.sendMessage(ChatColor.AQUA + undo.getName() + ChatColor.GRAY + " will undo in " + ChatColor.WHITE + "" + remainingTime + "" + ChatColor.GRAY + " seconds");
}
Collection<Mage> pending = api.getMagesWithPendingBatches();
sender.sendMessage(ChatColor.AQUA + "Pending casts (" + ChatColor.LIGHT_PURPLE + pending.size() + ChatColor.AQUA + "): ");
for (Mage mage : pending) {
int totalSize = 0;
int totalRemaining = 0;
Collection<Batch> pendingBatches = mage.getPendingBatches();
String names = "";
if (pendingBatches.size() > 0) {
for (Batch batch : pendingBatches) {
names = names + batch.getName() + " ";
totalSize += batch.size();
totalRemaining += batch.remaining();
}
}
sender.sendMessage(ChatColor.AQUA + mage.getName() + ChatColor.GRAY + " has " + ChatColor.WHITE + "" + pendingBatches.size() + "" + ChatColor.GRAY + " pending (" + ChatColor.WHITE + "" + totalRemaining + "/" + totalSize + "" + ChatColor.GRAY + ") (" + names + ")");
}
return true;
}
if (listCommand.equalsIgnoreCase("schematics")) {
List<String> schematics = new ArrayList<>();
try {
Plugin plugin = (Plugin) api;
MagicController controller = (MagicController) api.getController();
// Find built-in schematics
CodeSource src = MagicAPI.class.getProtectionDomain().getCodeSource();
if (src != null) {
URL jar = src.getLocation();
try (InputStream is = jar.openStream();
ZipInputStream zip = new ZipInputStream(is)) {
while (true) {
ZipEntry e = zip.getNextEntry();
if (e == null)
break;
String name = e.getName();
if (name.startsWith("schematics/")) {
schematics.add(name.replace("schematics/", ""));
}
}
}
}
// Check extra path first
File configFolder = plugin.getDataFolder();
File magicSchematicFolder = new File(configFolder, "schematics");
if (magicSchematicFolder.exists()) {
for (File nextFile : magicSchematicFolder.listFiles()) {
schematics.add(nextFile.getName());
}
}
String extraSchematicFilePath = controller.getExtraSchematicFilePath();
if (extraSchematicFilePath != null && extraSchematicFilePath.length() > 0) {
File schematicFolder = new File(configFolder, "../" + extraSchematicFilePath);
if (schematicFolder.exists() && !schematicFolder.equals(magicSchematicFolder)) {
for (File nextFile : schematicFolder.listFiles()) {
schematics.add(nextFile.getName());
}
}
}
} catch (Exception ex) {
sender.sendMessage("Error loading schematics: " + ex.getMessage());
ex.printStackTrace();
;
}
sender.sendMessage(ChatColor.DARK_AQUA + "Found " + ChatColor.LIGHT_PURPLE + schematics.size() + ChatColor.DARK_AQUA + " schematics");
Collections.sort(schematics);
for (String schematic : schematics) {
if (schematic.indexOf(".schematic") > 0) {
sender.sendMessage(ChatColor.AQUA + schematic.replace(".schematic", ""));
}
}
return true;
}
if (listCommand.equalsIgnoreCase("tasks")) {
List<BukkitTask> tasks = Bukkit.getScheduler().getPendingTasks();
HashMap<String, Integer> pluginCounts = new HashMap<>();
HashMap<String, HashMap<String, Integer>> taskCounts = new HashMap<>();
for (BukkitTask task : tasks) {
String pluginName = task.getOwner().getName();
HashMap<String, Integer> pluginTaskCounts = taskCounts.get(pluginName);
if (pluginTaskCounts == null) {
pluginTaskCounts = new HashMap<>();
taskCounts.put(pluginName, pluginTaskCounts);
}
String className = "(Unknown)";
Runnable taskRunnable = CompatibilityUtils.getTaskRunnable(task);
if (taskRunnable != null) {
Class<? extends Runnable> taskClass = taskRunnable.getClass();
className = taskClass.getName();
}
Integer count = pluginTaskCounts.get(className);
if (count == null)
count = 0;
count++;
pluginTaskCounts.put(className, count);
Integer totalCount = pluginCounts.get(pluginName);
if (totalCount == null)
totalCount = 0;
totalCount++;
pluginCounts.put(pluginName, totalCount);
}
sender.sendMessage(ChatColor.LIGHT_PURPLE + "Active tasks: " + tasks.size());
for (Entry<String, HashMap<String, Integer>> pluginEntry : taskCounts.entrySet()) {
String pluginName = pluginEntry.getKey();
sender.sendMessage(" " + ChatColor.DARK_PURPLE + pluginName + ": " + ChatColor.LIGHT_PURPLE + pluginCounts.get(pluginName));
for (Entry<String, Integer> taskEntry : pluginEntry.getValue().entrySet()) {
sender.sendMessage(" " + ChatColor.DARK_PURPLE + taskEntry.getKey() + ": " + ChatColor.LIGHT_PURPLE + taskEntry.getValue());
}
}
return true;
}
if (listCommand.equalsIgnoreCase("wands")) {
String owner = "";
if (args.length > 2) {
owner = args[2];
}
Collection<LostWand> lostWands = api.getLostWands();
int shown = 0;
for (LostWand lostWand : lostWands) {
Location location = lostWand.getLocation();
if (location == null)
continue;
if (owner.length() > 0 && !owner.equalsIgnoreCase(lostWand.getOwner())) {
continue;
}
shown++;
sender.sendMessage(ChatColor.AQUA + lostWand.getName() + ChatColor.WHITE + " (" + lostWand.getOwner() + ") @ " + ChatColor.BLUE + location.getWorld().getName() + " " + location.getBlockX() + " " + location.getBlockY() + " " + location.getBlockZ());
}
sender.sendMessage(shown + " lost wands found" + (owner.length() > 0 ? " for " + owner : ""));
return true;
}
if (listCommand.equalsIgnoreCase("automata")) {
Collection<Mage> automata = api.getAutomata();
for (Mage automaton : automata) {
Location location = automaton.getLocation();
String worldName = location.getWorld().getName();
boolean isOnline = false;
World world = Bukkit.getWorld(worldName);
if (worldName != null) {
isOnline = world.isChunkLoaded(location.getBlockX() >> 4, location.getBlockZ() >> 4);
}
ChatColor nameColor = isOnline ? ChatColor.AQUA : ChatColor.GRAY;
sender.sendMessage(nameColor + automaton.getName() + ChatColor.WHITE + " @ " + ChatColor.BLUE + worldName + " " + location.getBlockX() + " " + location.getBlockY() + " " + location.getBlockZ());
}
sender.sendMessage(automata.size() + " automata active");
return true;
}
if (listCommand.equalsIgnoreCase("maps")) {
String keyword = "";
for (int i = 2; i < args.length; i++) {
if (i != 2)
keyword = keyword + " ";
keyword = keyword + args[i];
}
onMapList(sender, keyword);
return true;
}
if (listCommand.equalsIgnoreCase("blocks")) {
for (BlockData blockData : UndoList.getRegistry().getModified().values()) {
BlockVector blockLocation = blockData.getLocation();
Block block = blockData.getBlock();
sender.sendMessage(ChatColor.BLUE + "Block at " + ChatColor.GRAY + blockLocation.getBlockX() + ChatColor.DARK_GRAY + "," + ChatColor.GRAY + blockLocation.getBlockY() + ChatColor.DARK_GRAY + "," + ChatColor.GRAY + blockLocation.getBlockZ() + ChatColor.BLUE + " stored as " + ChatColor.AQUA + blockData.getMaterial() + ChatColor.BLUE + " is currently " + ChatColor.AQUA + block.getType() + ChatColor.BLUE + " from " + ChatColor.GOLD + blockData.getUndoList().getName());
}
return true;
}
if (listCommand.equalsIgnoreCase("mages")) {
for (Mage mage : api.getController().getMages()) {
Entity mageEntity = mage.getEntity();
Location location = mage.getLocation();
ChatColor mageColor = ChatColor.YELLOW;
if (mage instanceof com.elmakers.mine.bukkit.magic.Mage && ((com.elmakers.mine.bukkit.magic.Mage) mage).isForget()) {
mageColor = ChatColor.RED;
} else if (mage.isAutomaton()) {
mageColor = ChatColor.GOLD;
}
String mageType = mageEntity == null ? "Non-Entity" : mageEntity.getType().name();
String message = ChatColor.AQUA + "Mage " + mageColor + mage.getId() + ChatColor.GRAY + " (" + mage.getName() + ")" + ChatColor.AQUA + " of type " + ChatColor.DARK_AQUA + mageType + ChatColor.AQUA;
if (location != null) {
String worldName = location.getWorld() != null ? location.getWorld().getName() : "(Unknown world)";
message = message + " is at " + ChatColor.BLUE + worldName + " " + ChatColor.DARK_PURPLE + " " + location.getBlockX() + " " + location.getBlockY() + " " + location.getBlockZ();
}
sender.sendMessage(message);
}
return true;
}
if (listCommand.equalsIgnoreCase("entities")) {
World world = Bukkit.getWorlds().get(0);
NumberFormat formatter = new DecimalFormat("#0.0");
List<EntityType> types = Arrays.asList(EntityType.values());
Collections.sort(types, new Comparator<EntityType>() {
@Override
public int compare(EntityType o1, EntityType o2) {
return o1.name().compareTo(o2.name());
}
});
Collection<? extends Player> players = Bukkit.getServer().getOnlinePlayers();
for (Player player : players) {
showEntityInfo(sender, player, EntityType.PLAYER.name() + ChatColor.GRAY + " (" + player.getName() + " [" + (player.isSneaking() ? "sneaking" : "standing") + "])", formatter);
break;
}
final Class<?> worldClass = NMSUtils.getBukkitClass("net.minecraft.server.World");
for (EntityType entityType : types) {
if (entityType.isSpawnable()) {
Entity testEntity = null;
String errorMessage = null;
String entityName = "Entity" + entityType.getEntityClass().getSimpleName();
// Still better than actually adding all of these entities to the world!
if (entityName.equals("EntityGiant")) {
entityName = "EntityGiantZombie";
} else if (entityName.equals("EntityLeashHitch")) {
entityName = "EntityLeash";
} else if (entityName.equals("EntityStorageMinecart")) {
entityName = "EntityMinecartChest";
} else if (entityName.equals("EntitySpawnerMinecart")) {
entityName = "EntityMinecartMobSpawner";
} else if (entityName.equals("EntityCommandMinecart")) {
entityName = "EntityMinecartCommandBlock";
} else if (entityName.equals("EntityPoweredMinecart")) {
entityName = "EntityMinecartFurnace";
} else if (entityName.equals("EntityExplosiveMinecart")) {
entityName = "EntityMinecartTNT";
} else if (entityName.contains("Minecart")) {
entityName = entityType.getEntityClass().getSimpleName();
entityName = entityName.replace("Minecart", "");
entityName = "EntityMinecart" + entityName;
}
try {
Class<?> entityClass = NMSUtils.getBukkitClass("net.minecraft.server." + entityName);
if (entityClass != null) {
Constructor<? extends Object> constructor = entityClass.getConstructor(worldClass);
Object nmsWorld = NMSUtils.getHandle(world);
Object nmsEntity = constructor.newInstance(nmsWorld);
testEntity = NMSUtils.getBukkitEntity(nmsEntity);
if (testEntity == null) {
errorMessage = "Failed to get Bukkit entity for class " + entityName;
}
} else {
errorMessage = "Could not load class " + entityName;
}
} catch (Exception ex) {
testEntity = null;
errorMessage = ex.getClass().getSimpleName() + " [" + entityName + "]";
String message = ex.getMessage();
if (message != null && !message.isEmpty()) {
errorMessage += ": " + message;
}
}
if (testEntity == null) {
sender.sendMessage(ChatColor.BLACK + entityType.name() + ": " + ChatColor.RED + "Spawning error " + ChatColor.DARK_RED + "(" + errorMessage + ")");
continue;
}
String label = entityType.name();
Ageable ageable = (testEntity instanceof Ageable) ? (Ageable) testEntity : null;
Zombie zombie = (testEntity instanceof Zombie) ? (Zombie) testEntity : null;
Skeleton skeleton = (testEntity instanceof Skeleton) ? (Skeleton) testEntity : null;
Slime slime = (testEntity instanceof Slime) ? (Slime) testEntity : null;
if (ageable != null) {
label = label + ChatColor.GRAY + " (Adult)";
ageable.setAdult();
} else if (zombie != null) {
label = label + ChatColor.GRAY + " (Adult)";
zombie.setBaby(false);
} else if (skeleton != null) {
label = label + ChatColor.GRAY + " (NORMAL)";
skeleton.setSkeletonType(Skeleton.SkeletonType.NORMAL);
} else if (slime != null) {
label = label + ChatColor.GRAY + " (Size 1)";
slime.setSize(1);
}
showEntityInfo(sender, testEntity, label, formatter);
if (ageable != null) {
label = entityType.name() + ChatColor.GRAY + " (Baby)";
ageable.setBaby();
showEntityInfo(sender, testEntity, label, formatter);
} else if (zombie != null) {
label = entityType.name() + ChatColor.GRAY + " (Baby)";
zombie.setBaby(true);
showEntityInfo(sender, testEntity, label, formatter);
} else if (skeleton != null) {
label = entityType.name() + ChatColor.GRAY + " (WITHER)";
skeleton.setSkeletonType(Skeleton.SkeletonType.WITHER);
showEntityInfo(sender, testEntity, label, formatter);
} else if (slime != null) {
label = entityType.name() + ChatColor.GRAY + " (Size 2)";
slime.setSize(2);
showEntityInfo(sender, testEntity, label, formatter);
label = entityType.name() + ChatColor.GRAY + " (Size 4)";
slime.setSize(4);
showEntityInfo(sender, testEntity, label, formatter);
label = entityType.name() + ChatColor.GRAY + " (Size 8)";
slime.setSize(8);
showEntityInfo(sender, testEntity, label, formatter);
label = entityType.name() + ChatColor.GRAY + " (Size 16)";
slime.setSize(16);
showEntityInfo(sender, testEntity, label, formatter);
}
}
}
return true;
}
sender.sendMessage(usage);
return true;
}
use of com.elmakers.mine.bukkit.api.block.BlockData in project MagicPlugin by elBukkit.
the class TransmuteSpell method onCast.
@Override
public SpellResult onCast(ConfigurationSection parameters) {
BlockList transmuteAction = null;
/*
* Use target if targeting
*/
Block target = getTargetBlock();
if (target != null) {
UndoQueue undoQueue = mage.getUndoQueue();
transmuteAction = undoQueue.getLast(target);
}
if (transmuteAction == null) {
UndoQueue undoQueue = mage.getUndoQueue();
transmuteAction = undoQueue.getLast();
}
if (transmuteAction == null) {
return SpellResult.NO_TARGET;
}
MaterialBrush buildWith = getBrush();
for (BlockData undoBlock : transmuteAction) {
Block block = undoBlock.getBlock();
buildWith.modify(block);
}
return SpellResult.CAST;
}
Aggregations