/*
* Copyright 2014 MovingBlocks
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package org.terasology.world.block.structure;
import org.terasology.math.Side;
import org.terasology.math.geom.Vector3i;
import org.terasology.world.block.Block;
import java.util.Map;
public interface BlockStructuralSupport {
/**
* Returns priority of this check. All checks with higher priority (lower number) will be invoked before checks
* with lower priority (higher number).
*
* @return
*/
int getPriority();
/**
* Checks if the block at specified location is sufficiently supported according to this class.
*
* @param location Location of the block to check.
* @param sideChanged Side that has triggered this check.
* @return If the block should be immediately removed.
*/
boolean shouldBeRemovedDueToChange(Vector3i location, Side sideChanged);
/**
* Checks if the block at location is sufficiently supported.
*
* @param location
* @param blockOverrides
* @return
*/
boolean isSufficientlySupported(Vector3i location, Map<Vector3i, Block> blockOverrides);
}