Skip to content

Commit

Permalink
Fixed two commands at once
Browse files Browse the repository at this point in the history
- Fixed strange things happening when you have /cobblestone and /autosmell turned on at once
  • Loading branch information
qWojtpl authored Apr 29, 2023
1 parent 8001ebb commit 5c3b2c3
Show file tree
Hide file tree
Showing 3 changed files with 17 additions and 9 deletions.
Binary file modified AutoSmell.jar
Binary file not shown.
2 changes: 1 addition & 1 deletion plugin/pom.xml
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,7 @@

<groupId>pl</groupId>
<artifactId>AutoSmell</artifactId>
<version>1.0.2</version>
<version>1.0.3</version>
<packaging>jar</packaging>

<name>AutoSmell</name>
Expand Down
24 changes: 16 additions & 8 deletions plugin/src/main/java/pl/autosmell/events/Events.java
Original file line number Diff line number Diff line change
Expand Up @@ -2,21 +2,18 @@

import org.bukkit.Location;
import org.bukkit.Material;
import org.bukkit.Sound;
import org.bukkit.enchantments.Enchantment;
import org.bukkit.entity.Player;
import org.bukkit.event.EventHandler;
import org.bukkit.event.EventPriority;
import org.bukkit.event.Listener;
import org.bukkit.event.block.BlockBreakEvent;
import org.bukkit.event.block.BlockDropItemEvent;
import org.bukkit.inventory.Inventory;
import org.bukkit.inventory.ItemStack;
import pl.autosmell.AutoSmell;
import pl.autosmell.data.DataHandler;

import java.util.Collection;
import java.util.Random;

public class Events implements Listener {

Expand All @@ -43,18 +40,31 @@ public void onBreakOre(BlockBreakEvent event) {
if(event.isCancelled()) return;
Player player = event.getPlayer();
if(!player.hasPermission(plugin.getPermissionManager().getPermission(dataHandler.getAutoSmellPermission()))) return;
ItemStack item = player.getInventory().getItemInMainHand();
if(item.getEnchantmentLevel(Enchantment.SILK_TOUCH) > 0) return;
if(!dataHandler.getSmellData().containsKey(player.getName())) return;
if(!dataHandler.getSmellData().get(player.getName())) return;
Material blockType = event.getBlock().getType();
Material[] materials = new Material[]{Material.ANCIENT_DEBRIS,
Material.IRON_ORE, Material.DEEPSLATE_IRON_ORE,
Material.GOLD_ORE, Material.DEEPSLATE_GOLD_ORE,
Material.COPPER_ORE, Material.DEEPSLATE_COPPER_ORE
};
boolean found = false;
for(Material m : materials) {
if(m.equals(blockType)) {
found = true;
break;
}
}
if(!found) return;
ItemStack item = player.getInventory().getItemInMainHand();
if(item.getEnchantmentLevel(Enchantment.SILK_TOUCH) > 0) return;
Collection<ItemStack> drops = event.getBlock().getDrops(item);
if(drops.size() != 1) return;
int count = 0;
for(ItemStack drop : drops) {
count = drop.getAmount();
}
Location blockLoc = event.getBlock().getLocation();
Material blockType = event.getBlock().getType();
event.setDropItems(false);
if(blockType.equals(Material.ANCIENT_DEBRIS)) {
if(hasSpace(player, Material.NETHERITE_SCRAP)) {
Expand Down Expand Up @@ -86,8 +96,6 @@ public void onBreakOre(BlockBreakEvent event) {
blockLoc.getWorld().dropItem(blockLoc, new ItemStack(Material.COPPER_INGOT));
}
}
} else {
event.setDropItems(true);
}
}

Expand Down

0 comments on commit 5c3b2c3

Please sign in to comment.