From 1e62c1ed66f9c3a9497d0f3c51b25271ea588d45 Mon Sep 17 00:00:00 2001 From: Sotr Date: Wed, 15 Apr 2020 03:51:50 +0700 Subject: [PATCH] Akarin Optimize door interact with pathfinding --- .../akarin/server/IndexedBlockPosition.java | 35 +++++++++++++ .../server/BehaviorInteractDoor.java | 49 ++++++++++++++++--- .../net/minecraft/server/BehaviorSleep.java | 2 +- 3 files changed, 77 insertions(+), 9 deletions(-) create mode 100644 src/main/java/io/akarin/server/IndexedBlockPosition.java diff --git a/src/main/java/io/akarin/server/IndexedBlockPosition.java b/src/main/java/io/akarin/server/IndexedBlockPosition.java new file mode 100644 index 0000000000..83bf1d4cab --- /dev/null +++ b/src/main/java/io/akarin/server/IndexedBlockPosition.java @@ -0,0 +1,35 @@ +package io.akarin.server; + +import net.minecraft.server.BlockPosition; + +public class IndexedBlockPosition { + private final int index; + private final BlockPosition position; + + public IndexedBlockPosition(int index, BlockPosition position) { + this.index = index; + this.position = position; + } + + public static IndexedBlockPosition of(int index, BlockPosition position) { + return new IndexedBlockPosition(index, position); + } + + public int index() { + return index; + } + + public BlockPosition get() { + return position; + } + + @Override + public int hashCode() { + return position.hashCode(); + } + + @Override + public boolean equals(Object obj) { + return position.equals(obj); + } +} diff --git a/src/main/java/net/minecraft/server/BehaviorInteractDoor.java b/src/main/java/net/minecraft/server/BehaviorInteractDoor.java index 01d9c2d92c..3db22c5f4d 100644 --- a/src/main/java/net/minecraft/server/BehaviorInteractDoor.java +++ b/src/main/java/net/minecraft/server/BehaviorInteractDoor.java @@ -1,7 +1,9 @@ package net.minecraft.server; import com.google.common.collect.ImmutableMap; +import com.google.common.collect.Lists; import com.google.common.collect.Sets; +import io.akarin.server.IndexedBlockPosition; import java.util.Iterator; import java.util.List; import java.util.Set; @@ -19,32 +21,63 @@ public class BehaviorInteractDoor extends Behavior { BehaviorController behaviorcontroller = entityliving.getBehaviorController(); PathEntity pathentity = (PathEntity) behaviorcontroller.getMemory(MemoryModuleType.PATH).get(); List list = (List) behaviorcontroller.getMemory(MemoryModuleType.INTERACTABLE_DOORS).get(); + // Akarin start - remove stream + /* List list1 = (List) pathentity.d().stream().map((pathpoint) -> { return new BlockPosition(pathpoint.a, pathpoint.b, pathpoint.c); }).collect(Collectors.toList()); - Set set = this.a(worldserver, list, list1); + */ + + List points = pathentity.getPoints(); + java.util.Map list1 = new java.util.HashMap(points.size()); + for (int index = 0; index < points.size(); index++) { + PathPoint point = points.get(index); + list1.put(new BlockPosition(point.a, point.b, point.c), index); + } + + // Akarin end + Set set = this.a(worldserver, list, list1); // Akarin - IndexedBlockPosition int j = pathentity.f() - 1; this.a(worldserver, list1, set, j, entityliving, behaviorcontroller); } - private Set a(WorldServer worldserver, List list, List list1) { + private Set a(WorldServer worldserver, List list, java.util.Map list1) { // Akarin - List -> Map, IndexedBlockPosition + // Akarin start - remove stream + /* Stream stream = list.stream().filter((globalpos) -> { return globalpos.getDimensionManager() == worldserver.getWorldProvider().getDimensionManager(); }).map(GlobalPos::getBlockPosition); list1.getClass(); return (Set) stream.filter(list1::contains).collect(Collectors.toSet()); + */ + + Set set = Sets.newHashSet(); + DimensionManager manager = worldserver.getWorldProvider().getDimensionManager(); + + for (GlobalPos globalPos : list) { + if (globalPos.getDimensionManager() == manager) { + BlockPosition position = globalPos.getBlockPosition(); + Integer index = list1.get(position); + if (index != null) // contains + set.add(IndexedBlockPosition.of(index, position)); + } + } + + return set; + // Akarin end } - private void a(WorldServer worldserver, List list, Set set, int i, EntityLiving entityliving, BehaviorController behaviorcontroller) { - set.forEach((blockposition) -> { - int j = list.indexOf(blockposition); + private void a(WorldServer worldserver, java.util.Map list, Set set, int i, EntityLiving entityliving, BehaviorController behaviorcontroller) { // Akarin - List -> Map, IndexedBlockPosition + set.forEach((indexedblockposition) -> { // Akarin - IndexedBlockPosition + BlockPosition blockposition = indexedblockposition.get(); // Akarin - IndexedBlockPosition + // int j = list.indexOf(blockposition); // Akarin - IndexedBlockPosition IBlockData iblockdata = worldserver.getType(blockposition); Block block = iblockdata.getBlock(); if (TagsBlock.WOODEN_DOORS.isTagged(block) && block instanceof BlockDoor) { - boolean flag = j >= i; + boolean flag = indexedblockposition.index() >= i; // Akarin - IndexedBlockPosition // CraftBukkit start - entities opening doors org.bukkit.event.entity.EntityInteractEvent event = new org.bukkit.event.entity.EntityInteractEvent(entityliving.getBukkitEntity(), org.bukkit.craftbukkit.block.CraftBlock.at(entityliving.world, blockposition)); @@ -74,14 +107,14 @@ public class BehaviorInteractDoor extends Behavior { a(worldserver, list, i, entityliving, behaviorcontroller); } - public static void a(WorldServer worldserver, List list, int i, EntityLiving entityliving, BehaviorController behaviorcontroller) { + public static void a(WorldServer worldserver, java.util.Map list, int i, EntityLiving entityliving, BehaviorController behaviorcontroller) { // Akarin - List -> Map behaviorcontroller.getMemory(MemoryModuleType.OPENED_DOORS).ifPresent((set) -> { Iterator iterator = set.iterator(); while (iterator.hasNext()) { GlobalPos globalpos = (GlobalPos) iterator.next(); BlockPosition blockposition = globalpos.getBlockPosition(); - int j = list.indexOf(blockposition); + int j = list.getOrDefault(blockposition, -1); // Akarin - List -> Map if (worldserver.getWorldProvider().getDimensionManager() != globalpos.getDimensionManager()) { iterator.remove(); diff --git a/src/main/java/net/minecraft/server/BehaviorSleep.java b/src/main/java/net/minecraft/server/BehaviorSleep.java index dfe0f66500..46eb633084 100644 --- a/src/main/java/net/minecraft/server/BehaviorSleep.java +++ b/src/main/java/net/minecraft/server/BehaviorSleep.java @@ -57,7 +57,7 @@ public class BehaviorSleep extends Behavior { protected void a(WorldServer worldserver, EntityLiving entityliving, long i) { if (i > this.a) { entityliving.getBehaviorController().getMemory(MemoryModuleType.OPENED_DOORS).ifPresent((set) -> { - BehaviorInteractDoor.a(worldserver, (List) ImmutableList.of(), 0, entityliving, entityliving.getBehaviorController()); + BehaviorInteractDoor.a(worldserver, com.google.common.collect.ImmutableMap.of(), 0, entityliving, entityliving.getBehaviorController()); // Akarin - List -> Map }); entityliving.entitySleep(((GlobalPos) entityliving.getBehaviorController().getMemory(MemoryModuleType.HOME).get()).getBlockPosition()); } -- 2.25.1.windows.1