001/* 002 * This file is part of Baritone. 003 * 004 * Baritone is free software: you can redistribute it and/or modify 005 * it under the terms of the GNU Lesser General Public License as published by 006 * the Free Software Foundation, either version 3 of the License, or 007 * (at your option) any later version. 008 * 009 * Baritone is distributed in the hope that it will be useful, 010 * but WITHOUT ANY WARRANTY; without even the implied warranty of 011 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 012 * GNU Lesser General Public License for more details. 013 * 014 * You should have received a copy of the GNU Lesser General Public License 015 * along with Baritone. If not, see <https://www.gnu.org/licenses/>. 016 */ 017 018package baritone.api.pathing.goals; 019 020/** 021 * Invert any goal. 022 * <p> 023 * In the old chat control system, #invert just tried to pick a {@link GoalRunAway} that <i>effectively</i> inverted the 024 * current goal. This goal just reverses the heuristic to act as a TRUE invert. Inverting a Y level? Baritone tries to 025 * get away from that Y level. Inverting a GoalBlock? Baritone will try to make distance whether it's in the X, Y or Z 026 * directions. And of course, you can always invert a GoalXZ. 027 * 028 * @author LoganDark 029 */ 030public class GoalInverted implements Goal { 031 032 public final Goal origin; 033 034 public GoalInverted(Goal origin) { 035 this.origin = origin; 036 } 037 038 @Override 039 public boolean isInGoal(int x, int y, int z) { 040 return false; 041 } 042 043 @Override 044 public double heuristic(int x, int y, int z) { 045 return -origin.heuristic(x, y, z); 046 } 047 048 @Override 049 public double heuristic() { 050 return Double.NEGATIVE_INFINITY; 051 } 052 053 @Override 054 public String toString() { 055 return String.format("GoalInverted{%s}", origin.toString()); 056 } 057}