package engine.devcmd.cmds; import engine.devcmd.AbstractDevCmd; import engine.gameManager.LootManager; import engine.gameManager.NPCManager; import engine.gameManager.ZoneManager; import engine.objects.*; import java.util.ArrayList; import java.util.concurrent.ThreadLocalRandom; public class SimulateBootyCmd extends AbstractDevCmd { public SimulateBootyCmd() { super("bootysim"); } @Override protected void _doCmd(PlayerCharacter playerCharacter, String[] words, AbstractGameObject target) { if (playerCharacter == null) return; String newline = "\r\n "; String output; output = "Booty Simulation:" + newline; Mob mob = (Mob) target; output += "Name: " + mob.getName() + newline; output += "Special Loot:" + newline; if (mob.bootySet != 0) { for (BootySetEntry entry : NPCManager._bootySetMap.get(mob.bootySet)) { ItemBase item = ItemBase.getItemBase(entry.itemBase); if (item != null) { output += "[" + entry.bootyType + "] " + item.getName() + " [Chance] " + entry.dropChance + newline; } } } ArrayList GlassItems = new ArrayList(); ArrayList Resources = new ArrayList(); ArrayList Runes = new ArrayList(); ArrayList Contracts = new ArrayList(); ArrayList Offerings = new ArrayList(); ArrayList OtherDrops = new ArrayList(); ArrayList EquipmentDrops = new ArrayList(); int failures = 0; int goldAmount = 0; for (int i = 0; i < 100; ++i) { try { mob.loadInventory(); for (Item lootItem : mob.getCharItemManager().getInventory()) { switch (lootItem.getItemBase().getType()) { case CONTRACT: //CONTRACT Contracts.add(lootItem); break; case OFFERING: //OFFERING Offerings.add(lootItem); break; case RESOURCE: //RESOURCE Resources.add(lootItem); break; case RUNE: //RUNE Runes.add(lootItem); break; case WEAPON: //WEAPON if (lootItem.getItemBase().isGlass()) GlassItems.add(lootItem); else OtherDrops.add(lootItem); break; case GOLD: goldAmount += lootItem.getNumOfItems(); break; default: OtherDrops.add(lootItem); break; } } } catch (Exception ex) { failures++; } if (mob.getEquip() != null) { for (MobEquipment me : mob.getEquip().values()) { if (me.getDropChance() == 0) continue; float equipmentRoll = ThreadLocalRandom.current().nextInt(99) + 1; float dropChance = me.getDropChance() * 100; if (equipmentRoll > (dropChance)) continue; MobLoot ml = new MobLoot(mob, me.getItemBase(), false); if (ml != null) EquipmentDrops.add(ml); } } } output += "MobBase BootySet: " + mob.getMobBase().bootySet + newline; output += "Mob BootySet: " + mob.bootySet + newline; output += "Tables Rolled On: " + newline; boolean hotZoneRan = false; float dropRate = 1.0f; if (ZoneManager.inHotZone(mob.getLoc())) dropRate = LootManager.HOTZONE_DROP_RATE; else dropRate = LootManager.NORMAL_DROP_RATE; for (BootySetEntry entry : NPCManager._bootySetMap.get(mob.getMobBase().bootySet)) { if (entry.bootyType.equals("GOLD")) output += "NORMAL TABLE [" + entry.bootyType + "] " + entry.genTable + ": " + entry.dropChance + newline; else output += "NORMAL TABLE [" + entry.bootyType + "] " + entry.genTable + ": " + entry.dropChance * dropRate + newline; if (hotZoneRan == false && ZoneManager.inHotZone(mob.getLoc()) && LootManager.generalItemTables.containsKey(entry.genTable + 1)) { output += "HOTZONE TABLE [" + entry.bootyType + "] " + (entry.genTable + 1) + ": " + entry.dropChance * dropRate + newline; hotZoneRan = true; } } output += "GLASS DROPS: " + GlassItems.size() + newline; output += "RUNE DROPS: " + Runes.size() + newline; output += "CONTRACTS DROPS: " + Contracts.size() + newline; output += "RESOURCE DROPS: " + Resources.size() + newline; output += "OFFERINGS DROPPED: " + Offerings.size() + newline; output += "ENCHANTED ITEMS DROPPED: " + OtherDrops.size() + newline; output += "TOTAL GOLD DROPPED: " + goldAmount + newline; output += "EQUIPMENT DROPPED: " + EquipmentDrops.size() + newline; output += "FAILED ROLLS: " + failures + newline; throwbackInfo(playerCharacter, output); } @Override protected String _getHelpString() { return "Simulates loot drops"; } @Override protected String _getUsageString() { return "'/bootysim targetID'"; } }