Search in sources :

Example 11 with BlockData

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;
}
Also used : Target(com.elmakers.mine.bukkit.utility.Target) Block(org.bukkit.block.Block) BlockData(com.elmakers.mine.bukkit.api.block.BlockData) Location(org.bukkit.Location)

Example 12 with BlockData

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;
}
Also used : BlockData(com.elmakers.mine.bukkit.api.block.BlockData)

Example 13 with BlockData

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);
    }
}
Also used : ArrayList(java.util.ArrayList) BlockData(com.elmakers.mine.bukkit.api.block.BlockData)

Example 14 with 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;
}
Also used : Entity(org.bukkit.entity.Entity) LivingEntity(org.bukkit.entity.LivingEntity) HashMap(java.util.HashMap) ArrayList(java.util.ArrayList) World(org.bukkit.World) MageController(com.elmakers.mine.bukkit.api.magic.MageController) LostWand(com.elmakers.mine.bukkit.api.wand.LostWand) Player(org.bukkit.entity.Player) Zombie(org.bukkit.entity.Zombie) CodeSource(java.security.CodeSource) EntityType(org.bukkit.entity.EntityType) ZipInputStream(java.util.zip.ZipInputStream) Mage(com.elmakers.mine.bukkit.api.magic.Mage) Block(org.bukkit.block.Block) File(java.io.File) ChatColor(org.bukkit.ChatColor) ZipEntry(java.util.zip.ZipEntry) DecimalFormat(java.text.DecimalFormat) Ageable(org.bukkit.entity.Ageable) URL(java.net.URL) UndoList(com.elmakers.mine.bukkit.block.UndoList) Batch(com.elmakers.mine.bukkit.api.batch.Batch) MagicController(com.elmakers.mine.bukkit.magic.MagicController) Skeleton(org.bukkit.entity.Skeleton) BlockData(com.elmakers.mine.bukkit.api.block.BlockData) MagicAPI(com.elmakers.mine.bukkit.api.magic.MagicAPI) ZipInputStream(java.util.zip.ZipInputStream) InputStream(java.io.InputStream) BukkitTask(org.bukkit.scheduler.BukkitTask) Slime(org.bukkit.entity.Slime) WandCleanupRunnable(com.elmakers.mine.bukkit.wand.WandCleanupRunnable) BlockVector(org.bukkit.util.BlockVector) Plugin(org.bukkit.plugin.Plugin) Location(org.bukkit.Location) NumberFormat(java.text.NumberFormat)

Example 15 with BlockData

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;
}
Also used : UndoQueue(com.elmakers.mine.bukkit.api.block.UndoQueue) MaterialBrush(com.elmakers.mine.bukkit.api.block.MaterialBrush) BlockList(com.elmakers.mine.bukkit.api.block.BlockList) Block(org.bukkit.block.Block) BlockData(com.elmakers.mine.bukkit.api.block.BlockData)

Aggregations

BlockData (com.elmakers.mine.bukkit.api.block.BlockData)22 Block (org.bukkit.block.Block)6 ArrayList (java.util.ArrayList)2 Nullable (javax.annotation.Nullable)2 Location (org.bukkit.Location)2 FallingBlock (org.bukkit.entity.FallingBlock)2 ItemStack (org.bukkit.inventory.ItemStack)2 CastContext (com.elmakers.mine.bukkit.api.action.CastContext)1 Batch (com.elmakers.mine.bukkit.api.batch.Batch)1 BlockList (com.elmakers.mine.bukkit.api.block.BlockList)1 MaterialBrush (com.elmakers.mine.bukkit.api.block.MaterialBrush)1 UndoList (com.elmakers.mine.bukkit.api.block.UndoList)1 UndoQueue (com.elmakers.mine.bukkit.api.block.UndoQueue)1 Mage (com.elmakers.mine.bukkit.api.magic.Mage)1 MageController (com.elmakers.mine.bukkit.api.magic.MageController)1 MagicAPI (com.elmakers.mine.bukkit.api.magic.MagicAPI)1 MaterialSet (com.elmakers.mine.bukkit.api.magic.MaterialSet)1 LostWand (com.elmakers.mine.bukkit.api.wand.LostWand)1 UndoList (com.elmakers.mine.bukkit.block.UndoList)1 MagicController (com.elmakers.mine.bukkit.magic.MagicController)1