mirror of
				https://github.com/mcMMO-Dev/mcMMO.git
				synced 2025-10-26 06:53:43 +01:00 
			
		
		
		
	Another dupe fix + 1.16 support part 4
This commit is contained in:
		| @@ -1,37 +1,43 @@ | |||||||
| Version 2.1.119 | Version 2.1.119 | ||||||
|     1.16 Support |     1.16 Support | ||||||
|  |     Fixed another dupe bug | ||||||
|     mcMMO is now aware of turtle shell and treats it appropriately |     mcMMO is now aware of turtle shell and treats it appropriately | ||||||
|  |     mcMMO is now aware of chainmail armor and treats it appropriately | ||||||
|  |     Calculations which change depend on the quality of your tool or armor has had netherrack support coded in | ||||||
|  |     All excavation drops that can drop from soul_sand now also drop from soul_soil (edited treasures.yml) | ||||||
|  |  | ||||||
|  |     Added 'Bamboo_Sapling' to bonus drops for Herbalism in experience.yml | ||||||
|     Added 'Ancient_Debris' with a value of 7777 to mining experience tables in experience.yml |     Added 'Ancient_Debris' with a value of 7777 to mining experience tables in experience.yml | ||||||
|     Added 'Netherite_Scrap' to bonus drops for Mining in config.yml |  | ||||||
|     Added 'Ancient_Debris' to bonus drops for Mining in config.yml |  | ||||||
|     Added 'Basalt' with a value of 40 to mining experience tables in experience.yml |     Added 'Basalt' with a value of 40 to mining experience tables in experience.yml | ||||||
|     Added 'Crimson_Fungus' with a value of 50 to herbalism experience tables in experience.yml |     Added 'Crimson_Fungus' with a value of 50 to herbalism experience tables in experience.yml | ||||||
|     Added 'Crimson_Fungus' to bonus drops for Herbalism in config.yml |  | ||||||
|     Added 'Warped_Fungus' with a value of 50 to herbalism experience tables in experience.yml |     Added 'Warped_Fungus' with a value of 50 to herbalism experience tables in experience.yml | ||||||
|     Added 'Warped_Fungus' to bonus drops for Herbalism in config.yml |  | ||||||
|     Added 'Warped_Nylium' with a value of 5 to mining experience tables in experience.yml |     Added 'Warped_Nylium' with a value of 5 to mining experience tables in experience.yml | ||||||
|     Added 'Warped_Nylium' to bonus drops for Mining in config.yml |  | ||||||
|     Added 'Crimson_Nylium' with a value of 5 to mining experience tables in experience.yml |     Added 'Crimson_Nylium' with a value of 5 to mining experience tables in experience.yml | ||||||
|     Added 'Crimson_Nylium' to bonus drops for Mining in config.yml |  | ||||||
|     Added 'Crimson_Stem' with a value of 35 to woodcutting experience tables in experience.yml |     Added 'Crimson_Stem' with a value of 35 to woodcutting experience tables in experience.yml | ||||||
|     Added 'Crimson_Roots' with a value of 35 to woodcutting experience tables in experience.yml |     Added 'Crimson_Roots' with a value of 35 to woodcutting experience tables in experience.yml | ||||||
|     Added 'Warped_Stem' with a value of 35 to woodcutting experience tables in experience.yml |     Added 'Warped_Stem' with a value of 35 to woodcutting experience tables in experience.yml | ||||||
|     Added 'Warped_Roots' with a value of 35 to woodcutting experience tables in experience.yml |     Added 'Warped_Roots' with a value of 35 to woodcutting experience tables in experience.yml | ||||||
|     Added 'Ancient_Debris' with a value of 200 to smelting experience tables in experience.yml |     Added 'Ancient_Debris' with a value of 200 to smelting experience tables in experience.yml | ||||||
|     Added 'Crimson_Stem' to bonus drops for Woodcutting in config.yml |  | ||||||
|     Added 'Warped_Stem' to bonus drops for Woodcutting in config.yml |  | ||||||
|     Added 'Nether_Sprouts' with a value of 10 to Herbalism experience tables in experience.yml |     Added 'Nether_Sprouts' with a value of 10 to Herbalism experience tables in experience.yml | ||||||
|     Added 'Shroomlight' with a value of 100 to Woodcutting experience tables in experience.yml |     Added 'Shroomlight' with a value of 100 to Woodcutting experience tables in experience.yml | ||||||
|     Added 'Shroomlight' to bonus drops for Woodcutting in config.yml |  | ||||||
|     Added 'Soul_Soil' with a value of 50 to Excavation experience tables in experience.yml |     Added 'Soul_Soil' with a value of 50 to Excavation experience tables in experience.yml | ||||||
|     Added 'Nether_Wart_Block' with a value of 20 to Woodcutting experience tables in experience.yml |     Added 'Nether_Wart_Block' with a value of 20 to Woodcutting experience tables in experience.yml | ||||||
|     Added 'Nether_Wart_Block' with a value of 20 to Herbalism experience tables in experience.yml |     Added 'Nether_Wart_Block' with a value of 20 to Herbalism experience tables in experience.yml | ||||||
|     Added 'Warped_Wart_Block' with a value of 20 to Woodcutting experience tables in experience.yml |     Added 'Warped_Wart_Block' with a value of 20 to Woodcutting experience tables in experience.yml | ||||||
|     Added 'Warped_Wart_Block' with a value of 20 to Herbalism experience tables in experience.yml |     Added 'Warped_Wart_Block' with a value of 20 to Herbalism experience tables in experience.yml | ||||||
|     Added 'Weeping_Vines' with a value of 10 to Herbalism experience tables in experience.yml |     Added 'Weeping_Vines' with a value of 10 to Herbalism experience tables in experience.yml | ||||||
|     All excavation drops that can drop from soul_sand now also drop from soul_soil (edited treasures.yml) |  | ||||||
|  |  | ||||||
|  |     Added 'Ancient_Debris' to bonus drops for Mining in config.yml | ||||||
|  |     Added 'Netherite_Scrap' to bonus drops for Mining in config.yml | ||||||
|  |     Added 'Crimson_Fungus' to bonus drops for Herbalism in config.yml | ||||||
|  |     Added 'Warped_Fungus' to bonus drops for Herbalism in config.yml | ||||||
|  |     Added 'Warped_Nylium' to bonus drops for Mining in config.yml | ||||||
|  |     Added 'Crimson_Nylium' to bonus drops for Mining in config.yml | ||||||
|  |     Added 'Crimson_Stem' to bonus drops for Woodcutting in config.yml | ||||||
|  |     Added 'Warped_Stem' to bonus drops for Woodcutting in config.yml | ||||||
|  |     Added 'Shroomlight' to bonus drops for Woodcutting in config.yml | ||||||
|  |  | ||||||
|  |     NOTES: You may have to edit your configs for this update to mcMMO, either do it manually or delete the config files to regenerate them. | ||||||
|  |  | ||||||
| Version 2.1.118 | Version 2.1.118 | ||||||
|     Fixed another dupe bug |     Fixed another dupe bug | ||||||
|   | |||||||
| @@ -153,6 +153,9 @@ public class mcMMO extends JavaPlugin { | |||||||
|  |  | ||||||
|             modManager = new ModManager(); |             modManager = new ModManager(); | ||||||
|  |  | ||||||
|  |             //Init Material Maps | ||||||
|  |             materialMapStore = new MaterialMapStore(); | ||||||
|  |  | ||||||
|             loadConfigFiles(); |             loadConfigFiles(); | ||||||
|  |  | ||||||
|             if (!noErrorsInConfigFiles) { |             if (!noErrorsInConfigFiles) { | ||||||
| @@ -250,9 +253,6 @@ public class mcMMO extends JavaPlugin { | |||||||
|             getServer().getPluginManager().disablePlugin(this); |             getServer().getPluginManager().disablePlugin(this); | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         //Init Material Maps |  | ||||||
|         materialMapStore = new MaterialMapStore(); |  | ||||||
|  |  | ||||||
|         //Init player level values |         //Init player level values | ||||||
|         playerLevelUtils = new PlayerLevelUtils(); |         playerLevelUtils = new PlayerLevelUtils(); | ||||||
|  |  | ||||||
|   | |||||||
| @@ -136,11 +136,11 @@ public class MiningManager extends SkillManager { | |||||||
|  |  | ||||||
|         List<BlockState> ores = new ArrayList<BlockState>(); |         List<BlockState> ores = new ArrayList<BlockState>(); | ||||||
|  |  | ||||||
|         List<Block> newYieldList = new ArrayList<>(); |         List<Block> notOres = new ArrayList<>(); | ||||||
|         for (Block targetBlock : event.blockList()) { |         for (Block targetBlock : event.blockList()) { | ||||||
|             //Containers usually have 0 XP unless someone edited their config in a very strange way |             //Containers usually have 0 XP unless someone edited their config in a very strange way | ||||||
|             if (ExperienceConfig.getInstance().getXp(PrimarySkillType.MINING, targetBlock) == 0 || targetBlock instanceof Container || mcMMO.getPlaceStore().isTrue(targetBlock)) { |             if (ExperienceConfig.getInstance().getXp(PrimarySkillType.MINING, targetBlock) == 0 || targetBlock instanceof Container || mcMMO.getPlaceStore().isTrue(targetBlock)) { | ||||||
|                 newYieldList.add(targetBlock); |                 notOres.add(targetBlock); | ||||||
|             } else { |             } else { | ||||||
|                 ores.add(targetBlock.getState()); |                 ores.add(targetBlock.getState()); | ||||||
|             } |             } | ||||||
| @@ -156,7 +156,7 @@ public class MiningManager extends SkillManager { | |||||||
| //        float debrisYield = yield - debrisReduction; | //        float debrisYield = yield - debrisReduction; | ||||||
|  |  | ||||||
|         for (BlockState blockState : ores) { |         for (BlockState blockState : ores) { | ||||||
|             if (Misc.getRandom().nextFloat() < (newYieldList.size() + oreBonus)) { |             if (Misc.getRandom().nextFloat() < (notOres.size() + oreBonus)) { | ||||||
|                 xp += Mining.getBlockXp(blockState); |                 xp += Mining.getBlockXp(blockState); | ||||||
|  |  | ||||||
|                 Misc.dropItem(Misc.getBlockCenter(blockState), new ItemStack(blockState.getType())); // Initial block that would have been dropped |                 Misc.dropItem(Misc.getBlockCenter(blockState), new ItemStack(blockState.getType())); // Initial block that would have been dropped | ||||||
| @@ -168,8 +168,9 @@ public class MiningManager extends SkillManager { | |||||||
|         } |         } | ||||||
|  |  | ||||||
|         //Replace the event blocklist with the newYield list |         //Replace the event blocklist with the newYield list | ||||||
|         event.blockList().clear(); |         event.setYield(0F); | ||||||
|         event.blockList().addAll(newYieldList); | //        event.blockList().clear(); | ||||||
|  | //        event.blockList().addAll(notOres); | ||||||
|  |  | ||||||
|         applyXpGain(xp, XPGainReason.PVE); |         applyXpGain(xp, XPGainReason.PVE); | ||||||
|     } |     } | ||||||
|   | |||||||
| @@ -98,6 +98,8 @@ public class SwordsManager extends SkillManager { | |||||||
|  |  | ||||||
|     public int getToolTier(ItemStack itemStack) |     public int getToolTier(ItemStack itemStack) | ||||||
|     { |     { | ||||||
|  |         if(ItemUtils.isNetherriteTool(itemStack)) | ||||||
|  |             return 5; | ||||||
|         if(ItemUtils.isDiamondTool(itemStack)) |         if(ItemUtils.isDiamondTool(itemStack)) | ||||||
|             return 4; |             return 4; | ||||||
|         else if(ItemUtils.isIronTool(itemStack) || ItemUtils.isGoldTool(itemStack)) |         else if(ItemUtils.isIronTool(itemStack) || ItemUtils.isGoldTool(itemStack)) | ||||||
|   | |||||||
| @@ -2,6 +2,7 @@ package com.gmail.nossr50.util; | |||||||
|  |  | ||||||
| import org.bukkit.Material; | import org.bukkit.Material; | ||||||
|  |  | ||||||
|  | import java.util.HashMap; | ||||||
| import java.util.HashSet; | import java.util.HashSet; | ||||||
| import java.util.Locale; | import java.util.Locale; | ||||||
|  |  | ||||||
| @@ -53,6 +54,8 @@ public class MaterialMapStore { | |||||||
|  |  | ||||||
|     private HashSet<String> ores; |     private HashSet<String> ores; | ||||||
|  |  | ||||||
|  |     private HashMap<String, Integer> tierValue; | ||||||
|  |  | ||||||
|  |  | ||||||
|     public MaterialMapStore() |     public MaterialMapStore() | ||||||
|     { |     { | ||||||
| @@ -96,7 +99,9 @@ public class MaterialMapStore { | |||||||
|  |  | ||||||
|         ores = new HashSet<>(); |         ores = new HashSet<>(); | ||||||
|  |  | ||||||
|         fillHardcodedHashSets(); |         tierValue = new HashMap<>(); | ||||||
|  |  | ||||||
|  |         fillVanillaMaterialRegisters(); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     public boolean isMultiBlockPlant(Material material) |     public boolean isMultiBlockPlant(Material material) | ||||||
| @@ -139,7 +144,7 @@ public class MaterialMapStore { | |||||||
|         return canMakeShroomyWhiteList.contains(material.getKey().getKey()); |         return canMakeShroomyWhiteList.contains(material.getKey().getKey()); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     private void fillHardcodedHashSets() |     private void fillVanillaMaterialRegisters() | ||||||
|     { |     { | ||||||
|         fillAbilityBlackList(); |         fillAbilityBlackList(); | ||||||
|         fillToolBlackList(); |         fillToolBlackList(); | ||||||
| @@ -155,6 +160,34 @@ public class MaterialMapStore { | |||||||
|         fillTools(); |         fillTools(); | ||||||
|         fillEnchantables(); |         fillEnchantables(); | ||||||
|         fillOres(); |         fillOres(); | ||||||
|  |  | ||||||
|  |         fillTierMap(); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     private void fillTierMap() { | ||||||
|  |         for(String id : leatherArmor) { | ||||||
|  |             tierValue.put(id, 1); | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         for(String id : ironArmor) { | ||||||
|  |             tierValue.put(id, 2); | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         for(String id : goldArmor) { | ||||||
|  |             tierValue.put(id, 3); | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         for(String id : chainmailArmor) { | ||||||
|  |             tierValue.put(id, 3); | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         for(String id : diamondArmor) { | ||||||
|  |             tierValue.put(id, 6); | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         for(String id : netherriteArmor) { | ||||||
|  |             tierValue.put(id, 12); | ||||||
|  |         } | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     private void fillOres() { |     private void fillOres() { | ||||||
| @@ -1040,6 +1073,14 @@ public class MaterialMapStore { | |||||||
|         toolBlackList.add("stonecutter"); |         toolBlackList.add("stonecutter"); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     public int getTier(Material material) { | ||||||
|  |         return getTier(material.getKey().getKey()); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public int getTier(String id) { | ||||||
|  |         return tierValue.getOrDefault(id, 1); //1 for unknown items | ||||||
|  |     } | ||||||
|  |  | ||||||
|     private void addToHashSet(String string, HashSet<String> stringHashSet) |     private void addToHashSet(String string, HashSet<String> stringHashSet) | ||||||
|     { |     { | ||||||
|         stringHashSet.add(string.toLowerCase(Locale.ENGLISH)); |         stringHashSet.add(string.toLowerCase(Locale.ENGLISH)); | ||||||
|   | |||||||
| @@ -411,12 +411,9 @@ public final class CombatUtils { | |||||||
|         if(metadataValue.size() <= 0) |         if(metadataValue.size() <= 0) | ||||||
|             return; |             return; | ||||||
|  |  | ||||||
|         if(metadataValue != null) |         OldName oldName = (OldName) metadataValue.get(0); | ||||||
|         { |         entity.setCustomName(oldName.asString()); | ||||||
|             OldName oldName = (OldName) metadataValue.get(0); |         entity.setCustomNameVisible(false); | ||||||
|             entity.setCustomName(oldName.asString()); |  | ||||||
|             entity.setCustomNameVisible(false); |  | ||||||
|         } |  | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
| @@ -480,33 +477,7 @@ public final class CombatUtils { | |||||||
|      * @return the armor quality of a specific Item Stack |      * @return the armor quality of a specific Item Stack | ||||||
|      */ |      */ | ||||||
|     private static int getArmorQuality(ItemStack itemStack) { |     private static int getArmorQuality(ItemStack itemStack) { | ||||||
|         int quality = 0; |         return mcMMO.getMaterialMapStore().getTier(itemStack.getType().getKey().getKey()); | ||||||
|  |  | ||||||
|         switch(itemStack.getType()) { |  | ||||||
|             case LEATHER_HELMET: |  | ||||||
|             case LEATHER_BOOTS: |  | ||||||
|             case LEATHER_CHESTPLATE: |  | ||||||
|             case LEATHER_LEGGINGS: |  | ||||||
|                 return 1; |  | ||||||
|             case IRON_HELMET: |  | ||||||
|             case IRON_BOOTS: |  | ||||||
|             case IRON_CHESTPLATE: |  | ||||||
|             case IRON_LEGGINGS: |  | ||||||
|                 return 2; |  | ||||||
|             case GOLDEN_HELMET: |  | ||||||
|             case GOLDEN_BOOTS: |  | ||||||
|             case GOLDEN_CHESTPLATE: |  | ||||||
|             case GOLDEN_LEGGINGS: |  | ||||||
|                 return 3; |  | ||||||
|             case DIAMOND_HELMET: |  | ||||||
|             case DIAMOND_BOOTS: |  | ||||||
|             case DIAMOND_CHESTPLATE: |  | ||||||
|             case DIAMOND_LEGGINGS: |  | ||||||
|                 return 6; |  | ||||||
|             default: |  | ||||||
|                 return 1; |  | ||||||
|  |  | ||||||
|         } |  | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
|   | |||||||
| @@ -427,6 +427,7 @@ Skills: | |||||||
| ### | ### | ||||||
| Bonus_Drops: | Bonus_Drops: | ||||||
|     Herbalism: |     Herbalism: | ||||||
|  |         Bamboo_Sapling: true | ||||||
|         Crimson_Fungus: true |         Crimson_Fungus: true | ||||||
|         Warped_Fungus: true |         Warped_Fungus: true | ||||||
|         Chorus_Fruit: true |         Chorus_Fruit: true | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 nossr50
					nossr50