From d52a942fa822b7685f0e8ce41f80d50b1d055467 Mon Sep 17 00:00:00 2001 From: TylerS1066 Date: Thu, 5 Sep 2024 12:07:44 -0500 Subject: [PATCH] Further improve performance using guava sets --- .../movecraft/mapUpdater/update/CraftRotateCommand.java | 9 +++++---- 1 file changed, 5 insertions(+), 4 deletions(-) diff --git a/Movecraft/src/main/java/net/countercraft/movecraft/mapUpdater/update/CraftRotateCommand.java b/Movecraft/src/main/java/net/countercraft/movecraft/mapUpdater/update/CraftRotateCommand.java index 185304f51..4a94d7974 100644 --- a/Movecraft/src/main/java/net/countercraft/movecraft/mapUpdater/update/CraftRotateCommand.java +++ b/Movecraft/src/main/java/net/countercraft/movecraft/mapUpdater/update/CraftRotateCommand.java @@ -1,5 +1,6 @@ package net.countercraft.movecraft.mapUpdater.update; +import com.google.common.collect.Sets; import it.unimi.dsi.fastutil.Hash; import it.unimi.dsi.fastutil.objects.Object2ObjectMap; import it.unimi.dsi.fastutil.objects.Object2ObjectOpenCustomHashMap; @@ -83,7 +84,7 @@ public void doUpdate() { originalLocations.add(MathUtils.rotateVec(counterRotation, movecraftLocation.subtract(originLocation)).add(originLocation)); } - final HitBox to = craft.getHitBox().difference(originalLocations); + final Set to = Sets.difference(craft.getHitBox().asSet(), originalLocations.asSet()); for (MovecraftLocation location : to) { var data = location.toBukkit(craft.getWorld()).getBlock().getBlockData(); @@ -92,7 +93,7 @@ public void doUpdate() { } } //The subtraction of the set of coordinates in the HitBox cube and the HitBox itself - final HitBox invertedHitBox = new SetHitBox(craft.getHitBox().boundingHitBox()).difference(craft.getHitBox()); + final SetHitBox invertedHitBox = new SetHitBox(Sets.difference(craft.getHitBox().boundingHitBox().asSet(), craft.getHitBox().asSet())); //A set of locations that are confirmed to be "exterior" locations final SetHitBox exterior = new SetHitBox(); final SetHitBox interior = new SetHitBox(); @@ -138,10 +139,10 @@ public void doUpdate() { } } exterior.addAll(visited); - interior.addAll(invertedHitBox.difference(exterior)); + interior.addAll(Sets.difference(invertedHitBox.asSet(), exterior.asSet())); final WorldHandler handler = Movecraft.getInstance().getWorldHandler(); - for (MovecraftLocation location : invertedHitBox.difference(exterior)) { + for (MovecraftLocation location : Sets.difference(invertedHitBox.asSet(), exterior.asSet())) { var data = location.toBukkit(craft.getWorld()).getBlock().getBlockData(); if (!passthroughBlocks.contains(data.getMaterial())) { continue;