From 6ad554e03554b70fb4bcbd234529915c17d438d7 Mon Sep 17 00:00:00 2001 From: Tom Prince Date: Sun, 5 Jan 2025 20:35:03 -0700 Subject: [PATCH] Use `LinkedHashSet` for Breadth First Search. When using a spray can that runs out partway through, we want to paint the nearest blocks, rather than a random selection of discovered blocks. --- .../gregtechceu/gtceu/utils/BreadthFirstBlockSearch.java | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/src/main/java/com/gregtechceu/gtceu/utils/BreadthFirstBlockSearch.java b/src/main/java/com/gregtechceu/gtceu/utils/BreadthFirstBlockSearch.java index 9addc412d4..2c098b9c6a 100644 --- a/src/main/java/com/gregtechceu/gtceu/utils/BreadthFirstBlockSearch.java +++ b/src/main/java/com/gregtechceu/gtceu/utils/BreadthFirstBlockSearch.java @@ -18,7 +18,7 @@ public class BreadthFirstBlockSearch { public static Set search(Predicate value, BlockPos start, int limit) { Set alreadyVisited = new HashSet<>(); - Set valid = new HashSet<>(); + Set valid = new LinkedHashSet<>(); int iteration = 0; Queue queue = new ArrayDeque<>(); @@ -58,7 +58,7 @@ public static Set conditionalBlockEntitySearch(Class< var level = start.getLevel(); if (level == null) return Set.of(); - var passed = new HashSet(); + var passed = new LinkedHashSet(); var queue = new ObjectArrayFIFOQueue>(16); queue.enqueue(new ImmutableTriple<>(null, start, null)); @@ -87,7 +87,7 @@ public static Set conditionalBlockEntitySearch(Class< public static Set conditionalBlockPosSearch(BlockPos start, BiPredicate condition, int blockLimit, int iterationLimit) { - var passed = new HashSet(); + var passed = new LinkedHashSet(); var queue = new ObjectArrayFIFOQueue>(16); queue.enqueue(new Tuple<>(null, start));