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.behavior;
019
020import baritone.api.utils.Rotation;
021
022/**
023 * @author Brady
024 * @since 9/23/2018
025 */
026public interface ILookBehavior extends IBehavior {
027
028    /**
029     * Updates the current {@link ILookBehavior} target to target
030     * the specified rotations on the next tick. If force is {@code true},
031     * then freeLook will be overriden and angles will be set regardless.
032     * If any sort of block interaction is required, force should be {@code true},
033     * otherwise, it should be {@code false};
034     *
035     * @param rotation The target rotations
036     * @param force    Whether or not to "force" the rotations
037     */
038    void updateTarget(Rotation rotation, boolean force);
039}