Merge pull request #3042 from ZacSharp/waypointImprovements
Waypoint improvements
This commit is contained in:
commit
129ec8472c
@ -18,6 +18,7 @@
|
|||||||
package baritone.behavior;
|
package baritone.behavior;
|
||||||
|
|
||||||
import baritone.Baritone;
|
import baritone.Baritone;
|
||||||
|
import baritone.api.cache.IWaypoint;
|
||||||
import baritone.api.cache.Waypoint;
|
import baritone.api.cache.Waypoint;
|
||||||
import baritone.api.event.events.BlockInteractEvent;
|
import baritone.api.event.events.BlockInteractEvent;
|
||||||
import baritone.api.event.events.PacketEvent;
|
import baritone.api.event.events.PacketEvent;
|
||||||
@ -30,6 +31,7 @@ import baritone.cache.ContainerMemory;
|
|||||||
import baritone.utils.BlockStateInterface;
|
import baritone.utils.BlockStateInterface;
|
||||||
import net.minecraft.block.Block;
|
import net.minecraft.block.Block;
|
||||||
import net.minecraft.block.BlockBed;
|
import net.minecraft.block.BlockBed;
|
||||||
|
import net.minecraft.block.state.IBlockState;
|
||||||
import net.minecraft.init.Blocks;
|
import net.minecraft.init.Blocks;
|
||||||
import net.minecraft.item.ItemStack;
|
import net.minecraft.item.ItemStack;
|
||||||
import net.minecraft.network.Packet;
|
import net.minecraft.network.Packet;
|
||||||
@ -167,8 +169,19 @@ public final class MemoryBehavior extends Behavior {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onBlockInteract(BlockInteractEvent event) {
|
public void onBlockInteract(BlockInteractEvent event) {
|
||||||
if (event.getType() == BlockInteractEvent.Type.USE && BlockStateInterface.getBlock(ctx, event.getPos()) instanceof BlockBed) {
|
if (event.getType() == BlockInteractEvent.Type.USE) {
|
||||||
baritone.getWorldProvider().getCurrentWorld().getWaypoints().addWaypoint(new Waypoint("bed", Waypoint.Tag.BED, BetterBlockPos.from(event.getPos())));
|
BetterBlockPos pos = BetterBlockPos.from(event.getPos());
|
||||||
|
IBlockState state = BlockStateInterface.get(ctx, pos);
|
||||||
|
if (state.getBlock() instanceof BlockBed) {
|
||||||
|
if (state.getValue(BlockBed.PART) == BlockBed.EnumPartType.FOOT) {
|
||||||
|
pos = pos.offset(state.getValue(BlockBed.FACING));
|
||||||
|
}
|
||||||
|
Set<IWaypoint> waypoints = baritone.getWorldProvider().getCurrentWorld().getWaypoints().getByTag(IWaypoint.Tag.BED);
|
||||||
|
boolean exists = waypoints.stream().map(IWaypoint::getLocation).filter(pos::equals).findFirst().isPresent();
|
||||||
|
if (!exists) {
|
||||||
|
baritone.getWorldProvider().getCurrentWorld().getWaypoints().addWaypoint(new Waypoint("bed", Waypoint.Tag.BED, pos));
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -17,9 +17,11 @@
|
|||||||
|
|
||||||
package baritone.command.defaults;
|
package baritone.command.defaults;
|
||||||
|
|
||||||
|
import baritone.Baritone;
|
||||||
import baritone.api.IBaritone;
|
import baritone.api.IBaritone;
|
||||||
import baritone.api.cache.IWaypoint;
|
import baritone.api.cache.IWaypoint;
|
||||||
import baritone.api.cache.Waypoint;
|
import baritone.api.cache.Waypoint;
|
||||||
|
import baritone.api.cache.IWorldData;
|
||||||
import baritone.api.command.Command;
|
import baritone.api.command.Command;
|
||||||
import baritone.api.command.argument.IArgConsumer;
|
import baritone.api.command.argument.IArgConsumer;
|
||||||
import baritone.api.command.datatypes.ForWaypoints;
|
import baritone.api.command.datatypes.ForWaypoints;
|
||||||
@ -41,12 +43,15 @@ import net.minecraft.util.text.event.HoverEvent;
|
|||||||
import java.util.*;
|
import java.util.*;
|
||||||
import java.util.function.BiFunction;
|
import java.util.function.BiFunction;
|
||||||
import java.util.function.Function;
|
import java.util.function.Function;
|
||||||
|
import java.util.stream.Collectors;
|
||||||
import java.util.stream.Stream;
|
import java.util.stream.Stream;
|
||||||
|
|
||||||
import static baritone.api.command.IBaritoneChatControl.FORCE_COMMAND_PREFIX;
|
import static baritone.api.command.IBaritoneChatControl.FORCE_COMMAND_PREFIX;
|
||||||
|
|
||||||
public class WaypointsCommand extends Command {
|
public class WaypointsCommand extends Command {
|
||||||
|
|
||||||
|
private Map<IWorldData,List<IWaypoint>> deletedWaypoints = new HashMap<>();
|
||||||
|
|
||||||
public WaypointsCommand(IBaritone baritone) {
|
public WaypointsCommand(IBaritone baritone) {
|
||||||
super(baritone, "waypoints", "waypoint", "wp");
|
super(baritone, "waypoints", "waypoint", "wp");
|
||||||
}
|
}
|
||||||
@ -125,11 +130,13 @@ public class WaypointsCommand extends Command {
|
|||||||
);
|
);
|
||||||
}
|
}
|
||||||
} else if (action == Action.SAVE) {
|
} else if (action == Action.SAVE) {
|
||||||
IWaypoint.Tag tag = IWaypoint.Tag.getByName(args.getString());
|
IWaypoint.Tag tag = args.hasAny() ? IWaypoint.Tag.getByName(args.peekString()) : null;
|
||||||
if (tag == null) {
|
if (tag == null) {
|
||||||
throw new CommandInvalidStateException(String.format("'%s' is not a tag ", args.consumedString()));
|
tag = IWaypoint.Tag.USER;
|
||||||
|
} else {
|
||||||
|
args.get();
|
||||||
}
|
}
|
||||||
String name = args.hasAny() ? args.getString() : "";
|
String name = (args.hasExactlyOne() || args.hasExactly(4)) ? args.getString() : "";
|
||||||
BetterBlockPos pos = args.hasAny()
|
BetterBlockPos pos = args.hasAny()
|
||||||
? args.getDatatypePost(RelativeBlockPos.INSTANCE, ctx.playerFeet())
|
? args.getDatatypePost(RelativeBlockPos.INSTANCE, ctx.playerFeet())
|
||||||
: ctx.playerFeet();
|
: ctx.playerFeet();
|
||||||
@ -147,7 +154,42 @@ public class WaypointsCommand extends Command {
|
|||||||
for (IWaypoint waypoint : waypoints) {
|
for (IWaypoint waypoint : waypoints) {
|
||||||
ForWaypoints.waypoints(this.baritone).removeWaypoint(waypoint);
|
ForWaypoints.waypoints(this.baritone).removeWaypoint(waypoint);
|
||||||
}
|
}
|
||||||
logDirect(String.format("Cleared %d waypoints", waypoints.length));
|
deletedWaypoints.computeIfAbsent(baritone.getWorldProvider().getCurrentWorld(), k -> new ArrayList<>()).addAll(Arrays.<IWaypoint>asList(waypoints));
|
||||||
|
ITextComponent textComponent = new TextComponentString(String.format("Cleared %d waypoints, click to restore them", waypoints.length));
|
||||||
|
textComponent.getStyle().setClickEvent(new ClickEvent(
|
||||||
|
ClickEvent.Action.RUN_COMMAND,
|
||||||
|
String.format(
|
||||||
|
"%s%s restore @ %s",
|
||||||
|
FORCE_COMMAND_PREFIX,
|
||||||
|
label,
|
||||||
|
Stream.of(waypoints).map(wp -> Long.toString(wp.getCreationTimestamp())).collect(Collectors.joining(" "))
|
||||||
|
)
|
||||||
|
));
|
||||||
|
logDirect(textComponent);
|
||||||
|
} else if (action == Action.RESTORE) {
|
||||||
|
List<IWaypoint> waypoints = new ArrayList<>();
|
||||||
|
List<IWaypoint> deletedWaypoints = this.deletedWaypoints.getOrDefault(baritone.getWorldProvider().getCurrentWorld(), Collections.emptyList());
|
||||||
|
if (args.peekString().equals("@")) {
|
||||||
|
args.get();
|
||||||
|
// no args.requireMin(1) because if the user clears an empty tag there is nothing to restore
|
||||||
|
while (args.hasAny()) {
|
||||||
|
long timestamp = args.getAs(Long.class);
|
||||||
|
for (IWaypoint waypoint : deletedWaypoints) {
|
||||||
|
if (waypoint.getCreationTimestamp() == timestamp) {
|
||||||
|
waypoints.add(waypoint);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
args.requireExactly(1);
|
||||||
|
int size = deletedWaypoints.size();
|
||||||
|
int amount = Math.min(size, args.getAs(Integer.class));
|
||||||
|
waypoints = new ArrayList<>(deletedWaypoints.subList(size - amount, size));
|
||||||
|
}
|
||||||
|
waypoints.forEach(ForWaypoints.waypoints(this.baritone)::addWaypoint);
|
||||||
|
deletedWaypoints.removeIf(waypoints::contains);
|
||||||
|
logDirect(String.format("Restored %d waypoints", waypoints.size()));
|
||||||
} else {
|
} else {
|
||||||
IWaypoint[] waypoints = args.getDatatypeFor(ForWaypoints.INSTANCE);
|
IWaypoint[] waypoints = args.getDatatypeFor(ForWaypoints.INSTANCE);
|
||||||
IWaypoint waypoint = null;
|
IWaypoint waypoint = null;
|
||||||
@ -216,6 +258,20 @@ public class WaypointsCommand extends Command {
|
|||||||
waypoint.getCreationTimestamp()
|
waypoint.getCreationTimestamp()
|
||||||
)
|
)
|
||||||
));
|
));
|
||||||
|
ITextComponent recreateComponent = new TextComponentString("Click to show a command to recreate this waypoint");
|
||||||
|
recreateComponent.getStyle().setClickEvent(new ClickEvent(
|
||||||
|
ClickEvent.Action.SUGGEST_COMMAND,
|
||||||
|
String.format(
|
||||||
|
"%s%s save %s %s %s %s %s",
|
||||||
|
Baritone.settings().prefix.value, // This uses the normal prefix because it is run by the user.
|
||||||
|
label,
|
||||||
|
waypoint.getTag().getName(),
|
||||||
|
waypoint.getName(),
|
||||||
|
waypoint.getLocation().x,
|
||||||
|
waypoint.getLocation().y,
|
||||||
|
waypoint.getLocation().z
|
||||||
|
)
|
||||||
|
));
|
||||||
ITextComponent backComponent = new TextComponentString("Click to return to the waypoints list");
|
ITextComponent backComponent = new TextComponentString("Click to return to the waypoints list");
|
||||||
backComponent.getStyle().setClickEvent(new ClickEvent(
|
backComponent.getStyle().setClickEvent(new ClickEvent(
|
||||||
ClickEvent.Action.RUN_COMMAND,
|
ClickEvent.Action.RUN_COMMAND,
|
||||||
@ -227,10 +283,22 @@ public class WaypointsCommand extends Command {
|
|||||||
));
|
));
|
||||||
logDirect(deleteComponent);
|
logDirect(deleteComponent);
|
||||||
logDirect(goalComponent);
|
logDirect(goalComponent);
|
||||||
|
logDirect(recreateComponent);
|
||||||
logDirect(backComponent);
|
logDirect(backComponent);
|
||||||
} else if (action == Action.DELETE) {
|
} else if (action == Action.DELETE) {
|
||||||
ForWaypoints.waypoints(this.baritone).removeWaypoint(waypoint);
|
ForWaypoints.waypoints(this.baritone).removeWaypoint(waypoint);
|
||||||
logDirect("That waypoint has successfully been deleted");
|
deletedWaypoints.computeIfAbsent(baritone.getWorldProvider().getCurrentWorld(), k -> new ArrayList<>()).add(waypoint);
|
||||||
|
ITextComponent textComponent = new TextComponentString("That waypoint has successfully been deleted, click to restore it");
|
||||||
|
textComponent.getStyle().setClickEvent(new ClickEvent(
|
||||||
|
ClickEvent.Action.RUN_COMMAND,
|
||||||
|
String.format(
|
||||||
|
"%s%s restore @ %s",
|
||||||
|
FORCE_COMMAND_PREFIX,
|
||||||
|
label,
|
||||||
|
waypoint.getCreationTimestamp()
|
||||||
|
)
|
||||||
|
));
|
||||||
|
logDirect(textComponent);
|
||||||
} else if (action == Action.GOAL) {
|
} else if (action == Action.GOAL) {
|
||||||
Goal goal = new GoalBlock(waypoint.getLocation());
|
Goal goal = new GoalBlock(waypoint.getLocation());
|
||||||
baritone.getCustomGoalProcess().setGoal(goal);
|
baritone.getCustomGoalProcess().setGoal(goal);
|
||||||
@ -262,6 +330,8 @@ public class WaypointsCommand extends Command {
|
|||||||
.sortAlphabetically()
|
.sortAlphabetically()
|
||||||
.filterPrefix(args.getString())
|
.filterPrefix(args.getString())
|
||||||
.stream();
|
.stream();
|
||||||
|
} else if (action == Action.RESTORE) {
|
||||||
|
return Stream.empty();
|
||||||
} else {
|
} else {
|
||||||
return args.tabCompleteDatatype(ForWaypoints.INSTANCE);
|
return args.tabCompleteDatatype(ForWaypoints.INSTANCE);
|
||||||
}
|
}
|
||||||
@ -289,15 +359,19 @@ public class WaypointsCommand extends Command {
|
|||||||
"",
|
"",
|
||||||
"Note that the info, delete, and goal commands let you specify a waypoint by tag. If there is more than one waypoint with a certain tag, then they will let you select which waypoint you mean.",
|
"Note that the info, delete, and goal commands let you specify a waypoint by tag. If there is more than one waypoint with a certain tag, then they will let you select which waypoint you mean.",
|
||||||
"",
|
"",
|
||||||
|
"Missing arguments for the save command use the USER tag, creating an unnamed waypoint and your current position as defaults.",
|
||||||
|
"",
|
||||||
"Usage:",
|
"Usage:",
|
||||||
"> wp [l/list] - List all waypoints.",
|
"> wp [l/list] - List all waypoints.",
|
||||||
"> wp <s/save> <tag> - Save your current position as an unnamed waypoint with the specified tag.",
|
"> wp <l/list> <tag> - List all waypoints by tag.",
|
||||||
"> wp <s/save> <tag> <name> - Save the waypoint with the specified name.",
|
"> wp <s/save> - Save an unnamed USER waypoint at your current position",
|
||||||
"> wp <s/save> <tag> <name> <pos> - Save the waypoint with the specified name and position.",
|
"> wp <s/save> [tag] [name] [pos] - Save a waypoint with the specified tag, name and position.",
|
||||||
"> wp <i/info/show> <tag> - Show info on a waypoint by tag.",
|
"> wp <i/info/show> <tag/name> - Show info on a waypoint by tag or name.",
|
||||||
"> wp <d/delete> <tag> - Delete a waypoint by tag.",
|
"> wp <d/delete> <tag/name> - Delete a waypoint by tag or name.",
|
||||||
"> wp <g/goal> <tag> - Set a goal to a waypoint by tag.",
|
"> wp <restore> <n> - Restore the last n deleted waypoints.",
|
||||||
"> wp <goto> <tag> - Set a goal to a waypoint by tag and start pathing."
|
"> wp <c/clear> <tag> - Delete all waypoints with the specified tag.",
|
||||||
|
"> wp <g/goal> <tag/name> - Set a goal to a waypoint by tag or name.",
|
||||||
|
"> wp <goto> <tag/name> - Set a goal to a waypoint by tag or name and start pathing."
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -307,6 +381,7 @@ public class WaypointsCommand extends Command {
|
|||||||
SAVE("save", "s"),
|
SAVE("save", "s"),
|
||||||
INFO("info", "show", "i"),
|
INFO("info", "show", "i"),
|
||||||
DELETE("delete", "d"),
|
DELETE("delete", "d"),
|
||||||
|
RESTORE("restore"),
|
||||||
GOAL("goal", "g"),
|
GOAL("goal", "g"),
|
||||||
GOTO("goto");
|
GOTO("goto");
|
||||||
private final String[] names;
|
private final String[] names;
|
||||||
|
Loading…
Reference in New Issue
Block a user