From 90ee55cc8127607a95f99ce0cc0efce846e42079 Mon Sep 17 00:00:00 2001 From: LemADEC Date: Tue, 23 May 2017 17:54:56 +0200 Subject: [PATCH] Integrated Filler NBT and ship generation --- .../java/cr0s/warpdrive/config/Filler.java | 17 +- .../warpdrive/world/WorldGenSmallShip.java | 62 +++-- .../warpdrive/world/WorldGenStructure.java | 194 +++++--------- src/main/resources/config/filler-default.xml | 245 +++++++++--------- src/main/resources/config/loot-default.xml | 73 +++--- 5 files changed, 280 insertions(+), 311 deletions(-) diff --git a/src/main/java/cr0s/warpdrive/config/Filler.java b/src/main/java/cr0s/warpdrive/config/Filler.java index 3b438590..d005dd4d 100644 --- a/src/main/java/cr0s/warpdrive/config/Filler.java +++ b/src/main/java/cr0s/warpdrive/config/Filler.java @@ -84,14 +84,29 @@ public class Filler implements IXmlRepresentableUnit { public void setBlock(World world, int x, int y, int z) { JumpBlock.setBlockNoLight(world, x, y, z, block, metadata, 2); + if (nbtTagCompound != null) { TileEntity tileEntity = world.getTileEntity(x, y, z); if (tileEntity == null) { WarpDrive.logger.error("No TileEntity found for Filler %s at (%d %d %d)", getName(), x, y, z); return; } - tileEntity.readFromNBT(nbtTagCompound); + + NBTTagCompound nbtTagCompoundTileEntity = new NBTTagCompound(); + tileEntity.writeToNBT(nbtTagCompoundTileEntity); + + for (Object key : nbtTagCompound.func_150296_c()) { + if (key instanceof String) { + nbtTagCompoundTileEntity.setTag((String) key, nbtTagCompound.getTag((String) key)); + } + } + + tileEntity.onChunkUnload(); + tileEntity.readFromNBT(nbtTagCompoundTileEntity); + tileEntity.validate(); tileEntity.markDirty(); + + JumpBlock.refreshBlockStateOnClient(world, x, y, z); } } diff --git a/src/main/java/cr0s/warpdrive/world/WorldGenSmallShip.java b/src/main/java/cr0s/warpdrive/world/WorldGenSmallShip.java index 30799a0e..90f8e5f9 100644 --- a/src/main/java/cr0s/warpdrive/world/WorldGenSmallShip.java +++ b/src/main/java/cr0s/warpdrive/world/WorldGenSmallShip.java @@ -310,7 +310,7 @@ public class WorldGenSmallShip extends WorldGenerator { genStructure.setHullGlass(world, i + 10, j + 5, k + 12); genStructure.setHullPlain(world, i + 10, j + 6, k + 3); genStructure.setHullPlain(world, i + 10, j + 6, k + 6); - genStructure.setCable(world, i + 10, j + 6, k + 7); + genStructure.setWiring(world, i + 10, j + 6, k + 7); genStructure.setHullPlain(world, i + 10, j + 6, k + 8); genStructure.setHullPlain(world, i + 10, j + 6, k + 11); genStructure.setHullPlain(world, i + 10, j + 7, k + 4); @@ -356,9 +356,9 @@ public class WorldGenSmallShip extends WorldGenerator { genStructure.setHullGlass(world, i + 11, j + 5, k + 12); genStructure.setHullPlain(world, i + 11, j + 6, k + 3); genStructure.setHullPlain(world, i + 11, j + 6, k + 5); - genStructure.setCable(world, i + 11, j + 6, k + 6); - genStructure.setCable(world, i + 11, j + 6, k + 7); - genStructure.setCable(world, i + 11, j + 6, k + 8); + genStructure.setWiring(world, i + 11, j + 6, k + 6); + genStructure.setWiring(world, i + 11, j + 6, k + 7); + genStructure.setWiring(world, i + 11, j + 6, k + 8); genStructure.setHullPlain(world, i + 11, j + 6, k + 9); genStructure.setHullPlain(world, i + 11, j + 6, k + 11); genStructure.setHullPlain(world, i + 11, j + 7, k + 4); @@ -387,8 +387,8 @@ public class WorldGenSmallShip extends WorldGenerator { genStructure.setHullPlain(world, i + 12, j + 2, k + 4); genStructure.setHullPlain(world, i + 12, j + 2, k + 5); genStructure.setHullPlain(world, i + 12, j + 2, k + 6); - genStructure.setCable(world, i + 12, j + 2, k + 7); - genStructure.setCable(world, i + 12, j + 2, k + 8); + genStructure.setWiring(world, i + 12, j + 2, k + 7); + genStructure.setWiring(world, i + 12, j + 2, k + 8); if (!isCorrupted || rand.nextBoolean()) { world.setBlock(i + 12, j + 2, k + 9, WarpDrive.blockLift); if (isCreative) {// fill with energy @@ -402,7 +402,7 @@ public class WorldGenSmallShip extends WorldGenerator { genStructure.setHullPlain(world, i + 12, j + 2, k + 11); genStructure.setHullPlain(world, i + 12, j + 3, k + 2); genStructure.setHullPlain(world, i + 12, j + 3, k + 6); - genStructure.setCable(world, i + 12, j + 3, k + 7); + genStructure.setWiring(world, i + 12, j + 3, k + 7); genStructure.setHullPlain(world, i + 12, j + 3, k + 8); genStructure.setHullPlain(world, i + 12, j + 3, k + 12); genStructure.setHullGlass(world, i + 12, j + 4, k + 2); @@ -426,7 +426,7 @@ public class WorldGenSmallShip extends WorldGenerator { genStructure.setHullPlain(world, i + 12, j + 6, k + 3); genStructure.setHullPlain(world, i + 12, j + 6, k + 4); genStructure.setHullPlain(world, i + 12, j + 6, k + 5); - genStructure.setCable(world, i + 12, j + 6, k + 7); + genStructure.setWiring(world, i + 12, j + 6, k + 7); genStructure.setHullPlain(world, i + 12, j + 6, k + 9); genStructure.setHullPlain(world, i + 12, j + 6, k + 10); genStructure.setHullPlain(world, i + 12, j + 6, k + 11); @@ -452,33 +452,43 @@ public class WorldGenSmallShip extends WorldGenerator { genStructure.setHullPlain(world, i + 13, j + 2, k + 10); genStructure.setHullPlain(world, i + 13, j + 2, k + 11); genStructure.setHullPlain(world, i + 13, j + 3, k + 2); - genStructure.setHullPlain(world, i + 13, j + 3, k + 3); + if (rand.nextBoolean()) { + genStructure.setHullPlain(world, i + 13, j + 3, k + 3); + genStructure.setHullGlass(world, i + 13, j + 4, k + 3); + } else if (!isCorrupted || rand.nextBoolean()) { + world.setBlock(i + 13, j + 3, k + 3, WarpDrive.blockAirShield); + world.setBlock(i + 13, j + 4, k + 3, WarpDrive.blockAirShield); + } genStructure.setHullPlain(world, i + 13, j + 3, k + 4); genStructure.setHullPlain(world, i + 13, j + 3, k + 5); genStructure.setHullPlain(world, i + 13, j + 3, k + 6); - genStructure.setCable(world, i + 13, j + 3, k + 7); + genStructure.setWiring(world, i + 13, j + 3, k + 7); genStructure.setHullPlain(world, i + 13, j + 3, k + 8); genStructure.setHullPlain(world, i + 13, j + 3, k + 9); genStructure.setHullPlain(world, i + 13, j + 3, k + 10); - world.setBlock(i + 13, j + 3, k + 11, WarpDrive.blockAirShield); + if (rand.nextBoolean()) { + genStructure.setHullPlain(world, i + 13, j + 3, k + 11); + genStructure.setHullGlass(world, i + 13, j + 4, k + 11); + } else if (!isCorrupted || rand.nextBoolean()) { + world.setBlock(i + 13, j + 3, k + 11, WarpDrive.blockAirShield); + world.setBlock(i + 13, j + 4, k + 11, WarpDrive.blockAirShield); + } genStructure.setHullPlain(world, i + 13, j + 3, k + 12); genStructure.setHullPlain(world, i + 13, j + 4, k + 2); - genStructure.setHullGlass(world, i + 13, j + 4, k + 3); genStructure.setHullPlain(world, i + 13, j + 4, k + 4); genStructure.setHullPlain(world, i + 13, j + 4, k + 5); genStructure.setHullPlain(world, i + 13, j + 4, k + 6); - genStructure.setCable(world, i + 13, j + 4, k + 7); + genStructure.setWiring(world, i + 13, j + 4, k + 7); genStructure.setHullPlain(world, i + 13, j + 4, k + 8); genStructure.setHullPlain(world, i + 13, j + 4, k + 9); genStructure.setHullPlain(world, i + 13, j + 4, k + 10); - world.setBlock(i + 13, j + 4, k + 11, WarpDrive.blockAirShield); genStructure.setHullPlain(world, i + 13, j + 4, k + 12); genStructure.setHullPlain(world, i + 13, j + 5, k + 2); genStructure.setHullPlain(world, i + 13, j + 5, k + 3); world.setBlock(i + 13, j + 5, k + 4, Blocks.glowstone); genStructure.setHullPlain(world, i + 13, j + 5, k + 5); genStructure.setHullPlain(world, i + 13, j + 5, k + 6); - genStructure.setCable(world, i + 13, j + 5, k + 7); + genStructure.setWiring(world, i + 13, j + 5, k + 7); genStructure.setHullPlain(world, i + 13, j + 5, k + 8); genStructure.setHullPlain(world, i + 13, j + 5, k + 9); world.setBlock(i + 13, j + 5, k + 10, Blocks.glowstone); @@ -488,7 +498,7 @@ public class WorldGenSmallShip extends WorldGenerator { genStructure.setHullPlain(world, i + 13, j + 6, k + 4); genStructure.setHullPlain(world, i + 13, j + 6, k + 5); genStructure.setHullPlain(world, i + 13, j + 6, k + 6); - genStructure.setCable(world, i + 13, j + 6, k + 7); + genStructure.setWiring(world, i + 13, j + 6, k + 7); genStructure.setHullPlain(world, i + 13, j + 6, k + 8); genStructure.setHullPlain(world, i + 13, j + 6, k + 9); genStructure.setHullPlain(world, i + 13, j + 6, k + 10); @@ -508,18 +518,18 @@ public class WorldGenSmallShip extends WorldGenerator { genStructure.setHullPlain(world, i + 14, j + 3, k + 9); genStructure.setHullPlain(world, i + 14, j + 3, k + 10); genStructure.setHullPlain(world, i + 14, j + 4, k + 4); - genStructure.setResource(world, i + 14, j + 4, k + 5); - genStructure.setResource(world, i + 14, j + 4, k + 6); + genStructure.setPropulsion(world, i + 14, j + 4, k + 5); + genStructure.setPropulsion(world, i + 14, j + 4, k + 6); genStructure.setHullPlain(world, i + 14, j + 4, k + 7); - genStructure.setResource(world, i + 14, j + 4, k + 8); - genStructure.setResource(world, i + 14, j + 4, k + 9); + genStructure.setPropulsion(world, i + 14, j + 4, k + 8); + genStructure.setPropulsion(world, i + 14, j + 4, k + 9); genStructure.setHullPlain(world, i + 14, j + 4, k + 10); genStructure.setHullPlain(world, i + 14, j + 5, k + 4); - genStructure.setResource(world, i + 14, j + 5, k + 5); - genStructure.setResource(world, i + 14, j + 5, k + 6); + genStructure.setPropulsion(world, i + 14, j + 5, k + 5); + genStructure.setPropulsion(world, i + 14, j + 5, k + 6); genStructure.setHullPlain(world, i + 14, j + 5, k + 7); - genStructure.setResource(world, i + 14, j + 5, k + 8); - genStructure.setResource(world, i + 14, j + 5, k + 9); + genStructure.setPropulsion(world, i + 14, j + 5, k + 8); + genStructure.setPropulsion(world, i + 14, j + 5, k + 9); genStructure.setHullPlain(world, i + 14, j + 5, k + 10); genStructure.setHullPlain(world, i + 14, j + 6, k + 4); genStructure.setHullPlain(world, i + 14, j + 6, k + 5); @@ -535,12 +545,12 @@ public class WorldGenSmallShip extends WorldGenerator { genStructure.setHullPlain(world, i + 15, j + 3, k + 4); genStructure.setHullPlain(world, i + 15, j + 3, k + 10); genStructure.setHullPlain(world, i + 15, j + 4, k + 7); - genStructure.setResource(world, i + 15, j + 5, k + 7); + genStructure.setPropulsion(world, i + 15, j + 5, k + 7); genStructure.setHullPlain(world, i + 15, j + 6, k + 4); genStructure.setHullPlain(world, i + 15, j + 6, k + 7); genStructure.setHullPlain(world, i + 15, j + 6, k + 10); genStructure.setHullPlain(world, i + 16, j + 4, k + 7); - genStructure.setResource(world, i + 16, j + 5, k + 7); + genStructure.setPropulsion(world, i + 16, j + 5, k + 7); genStructure.setHullPlain(world, i + 16, j + 6, k + 7); genStructure.setHullPlain(world, i + 17, j + 5, k + 7); spawnNPC(world, i + 9, j + 3, k + 5); diff --git a/src/main/java/cr0s/warpdrive/world/WorldGenStructure.java b/src/main/java/cr0s/warpdrive/world/WorldGenStructure.java index fe734094..438cffe6 100644 --- a/src/main/java/cr0s/warpdrive/world/WorldGenStructure.java +++ b/src/main/java/cr0s/warpdrive/world/WorldGenStructure.java @@ -2,6 +2,7 @@ package cr0s.warpdrive.world; import cr0s.warpdrive.WarpDrive; import cr0s.warpdrive.config.Dictionary; +import cr0s.warpdrive.config.Filler; import cr0s.warpdrive.config.GenericSet; import cr0s.warpdrive.config.Loot; import cr0s.warpdrive.config.WarpDriveConfig; @@ -21,171 +22,114 @@ import net.minecraft.world.World; public class WorldGenStructure { - private Block hullPlain_block; - private int hullPlain_metadata; - private Block hullGlass_block; - private int hullGlass_metadata; - private Block solarPanel_block; - private int solarPanel_metadata; - private Block cable_block; - private int cable_metadata; - private Block resource_block; - private int resource_metadata; private final boolean corrupted; private final Random rand; + private final Filler fillerHullPlain; + private final Filler fillerHullGlass; + private final Filler fillerSolarPanel; + private final Filler fillerWiring; + private final Filler fillerPropulsion; - public WorldGenStructure(final boolean corrupted, Random rand) { + public WorldGenStructure(final boolean corrupted, final Random rand) { this.corrupted = corrupted; this.rand = rand; - // choose a hull block - switch (rand.nextInt(7)) { - default: - case 0: - case 1: - hullPlain_block = Blocks.stained_hardened_clay; - hullPlain_metadata = rand.nextInt(16); - hullGlass_block = Blocks.stained_glass; - hullGlass_metadata = hullPlain_metadata; - break; - - case 2: - case 3: - case 4: - case 5: - hullPlain_block = WarpDrive.blockHulls_plain[0][0]; - hullPlain_metadata = rand.nextInt(16); - hullGlass_block = WarpDrive.blockHulls_glass[0]; - hullGlass_metadata = hullPlain_metadata; - break; - - case 6: - hullPlain_block = WarpDrive.blockHulls_plain[1][0]; - hullPlain_metadata = rand.nextInt(16); - hullGlass_block = WarpDrive.blockHulls_glass[1]; - hullGlass_metadata = hullPlain_metadata; - break; - - case 10: // disabled since it's tier3 - if (WarpDriveConfig.isIndustrialCraft2Loaded) { - hullPlain_block = WarpDriveConfig.getModBlock("IC2", "blockAlloy"); - hullPlain_metadata = 0; - hullGlass_block = WarpDriveConfig.getModBlock("IC2", "blockAlloyGlass"); - hullGlass_metadata = 0; - } - break; - } - - // choose a solar panel - if (WarpDriveConfig.isIndustrialCraft2Loaded) { - if (WarpDriveConfig.isAdvancedSolarPanelLoaded) { - solarPanel_block = WarpDriveConfig.getModBlock("AdvancedSolarPanel", "BlockAdvSolarPanel"); - solarPanel_metadata = rand.nextInt(2); - } else { - solarPanel_block = WarpDriveConfig.getModBlock("IC2", "blockGenerator"); - solarPanel_metadata = 3; - } - } else if (WarpDriveConfig.isEnderIOLoaded) { - solarPanel_block = WarpDriveConfig.getModBlock("EnderIO", "blockSolarPanel"); - solarPanel_metadata = 0; + // hull plain and glass are linked by same name + final GenericSet fillerSetHull_plain = WarpDriveConfig.FillerManager.getRandomSetFromGroup(rand, "hull_plain"); + if (fillerSetHull_plain == null) { + WarpDrive.logger.warn(String.format("No FillerSet found with group %s during world generation: check your configuration", + "hull_plain")); + fillerHullPlain = new Filler(); + fillerHullPlain.block = Blocks.stone; + fillerHullGlass = new Filler(); + fillerHullGlass.block = Blocks.glass; } else { - solarPanel_block = Blocks.air; - solarPanel_metadata = 0; - } - - // choose a wiring - cable_block = Blocks.air; - cable_metadata = 0; - if (WarpDriveConfig.isIndustrialCraft2Loaded) { - cable_block = WarpDriveConfig.getModBlock("IC2", "blockCable"); - cable_metadata = 0; + fillerHullPlain = fillerSetHull_plain.getRandomUnit(rand); - switch (rand.nextInt(4)) { - case 0: - cable_metadata = 0; - break; - - case 1: - cable_metadata = 3; - break; - - case 2: - cable_metadata = 6; - break; - - case 3: - cable_metadata = 9; - break; - - default: - break; + final String nameFillerGlass = "hull_glass:" + fillerSetHull_plain.getName(); + final GenericSet fillerSetHull_glass = WarpDriveConfig.FillerManager.getGenericSet(nameFillerGlass); + if (fillerSetHull_glass == null) { + WarpDrive.logger.warn(String.format("No FillerSet found with group %s during world generation: check your configuration", + nameFillerGlass)); + fillerHullGlass = new Filler(); + fillerHullGlass.block = Blocks.glass; + } else { + fillerHullGlass = fillerSetHull_glass.getRandomUnit(rand); } } - // choose a resource block - resource_block = Blocks.redstone_block; - resource_metadata = 0; - switch (rand.nextInt(10)) { - case 0: - case 1: - case 2: - case 3: - case 4: - case 5: - resource_block = Blocks.redstone_block; - break; + // solarPanel and wiring are linked by same name + final GenericSet fillerSetSolarPanel = WarpDriveConfig.FillerManager.getRandomSetFromGroup(rand, "ship_solarPanel"); + if (fillerSetSolarPanel == null) { + WarpDrive.logger.warn(String.format("No FillerSet found with group %s during world generation: check your configuration", + "ship_solarPanel")); + fillerSolarPanel = new Filler(); + fillerSolarPanel.block = Blocks.sandstone; + fillerWiring = new Filler(); + fillerWiring.block = Blocks.fence; + } else { + fillerSolarPanel = fillerSetSolarPanel.getRandomUnit(rand); + + final String nameFillerWiring = "ship_wiring:" + fillerSetSolarPanel.getName(); + final GenericSet fillerSetWiring = WarpDriveConfig.FillerManager.getGenericSet(nameFillerWiring); + if (fillerSetWiring == null) { + WarpDrive.logger.warn(String.format("No FillerSet found with group %s during world generation: check your configuration", + nameFillerWiring)); + fillerWiring = new Filler(); + fillerWiring.block = Blocks.fence; + } else { + fillerWiring = fillerSetWiring.getRandomUnit(rand); + } + } - case 6: - case 7: - resource_block = Blocks.lapis_block; - break; - - case 8: - case 9: - resource_block = Blocks.coal_block; - break; - - default: - break; + // propulsion is on it's own + final GenericSet fillerSetPropulsion = WarpDriveConfig.FillerManager.getRandomSetFromGroup(rand, "ship_propulsion"); + if (fillerSetPropulsion == null) { + WarpDrive.logger.warn(String.format("No FillerSet found with group %s during world generation: check your configuration", + "ship_propulsion")); + fillerPropulsion = new Filler(); + fillerPropulsion.block = Blocks.log; + } else { + fillerPropulsion = fillerSetPropulsion.getRandomUnit(rand); } } - public void setHullPlain(World world, final int x, final int y, final int z) { + public void setHullPlain(final World world, final int x, final int y, final int z) { if (corrupted && (rand.nextInt(400) == 1)) { world.newExplosion(null, x + 0.5D, y + 0.5D, z + 0.5D, 17, false, true); } else if (corrupted && (rand.nextInt(10) == 1)) { world.setBlock(x, y, z, Blocks.air, 0, 2); } else { - world.setBlock(x, y, z, hullPlain_block, hullPlain_metadata, 2); + fillerHullPlain.setBlock(world, x, y, z); } } - public void setHullGlass(World world, final int x, final int y, final int z) { + public void setHullGlass(final World world, final int x, final int y, final int z) { if (corrupted && (rand.nextInt(5) == 1)) { world.setBlock(x, y, z, Blocks.air, 0, 2); } else { - world.setBlock(x, y, z, hullGlass_block, hullGlass_metadata, 2); + fillerHullGlass.setBlock(world, x, y, z); } } - public void setSolarPanel(World world, final int x, final int y, final int z) { + public void setSolarPanel(final World world, final int x, final int y, final int z) { if (corrupted && (rand.nextInt(3) == 1)) { world.setBlock(x, y, z, Blocks.air, 0, 2); } else { - world.setBlock(x, y, z, solarPanel_block, solarPanel_metadata, 2); + fillerSolarPanel.setBlock(world, x, y, z); } } - public void setCable(World world, final int x, final int y, final int z) { + public void setWiring(final World world, final int x, final int y, final int z) { if (corrupted && (rand.nextInt(3) == 1)) { world.setBlock(x, y, z, Blocks.air, 0, 2); } else { - world.setBlock(x, y, z, cable_block, cable_metadata, 2); + fillerWiring.setBlock(world, x, y, z); } } - public void setResource(World world, final int x, final int y, final int z) { - world.setBlock(x, y, z, resource_block, resource_metadata, 2); + public void setPropulsion(final World world, final int x, final int y, final int z) { + fillerPropulsion.setBlock(world, x, y, z); } public void fillInventoryWithLoot(final World worldObj, final Random rand, final int x, final int y, final int z, final String group) { @@ -193,7 +137,7 @@ public class WorldGenStructure { if (tileEntity instanceof IInventory) { final IInventory inventory = (IInventory) tileEntity; final int size = inventory.getSizeInventory(); - final int countLoots = Math.min(3 + rand.nextInt(3), size); + final int countLoots = Math.min(rand.nextInt(3) + rand.nextInt(4), size); final GenericSet lootSet = WarpDriveConfig.LootManager.getRandomSetFromGroup(rand, group); if (lootSet == null) { diff --git a/src/main/resources/config/filler-default.xml b/src/main/resources/config/filler-default.xml index 8c34bcdd..c9b892af 100644 --- a/src/main/resources/config/filler-default.xml +++ b/src/main/resources/config/filler-default.xml @@ -3,14 +3,14 @@ xmlns="WarpDrive" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="WarpDrive WarpDrive.xsd"> - + - + @@ -30,7 +30,7 @@ - + @@ -47,8 +47,8 @@ - - + + @@ -68,7 +68,7 @@ - + @@ -81,8 +81,8 @@ - - + + @@ -96,7 +96,7 @@ - + @@ -107,16 +107,15 @@ - - - + + - + @@ -124,24 +123,22 @@ - - - + + - + - - - + + @@ -168,9 +165,8 @@ - - - + + @@ -184,12 +180,11 @@ - - - - - - + + + + + @@ -209,9 +204,8 @@ - - - + + @@ -250,103 +244,108 @@ - - - - - - - - - - - - - - - - - + + + + + + + + + + + + + + + - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + - - - - + + + + - - - - - - - - - - - - - - - - - - - - - - - - - - - - - + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/src/main/resources/config/loot-default.xml b/src/main/resources/config/loot-default.xml index d77331e3..03ff2ff4 100644 --- a/src/main/resources/config/loot-default.xml +++ b/src/main/resources/config/loot-default.xml @@ -18,42 +18,43 @@ When used on machines, we'll give a few trials to find a valid slot for each loot, eventually try another loot, eventually skipping it altogether. --> - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +