Plex-FAWE/worldedit-core/src/main/java/com/sk89q/worldedit/world/block/BlockStateHolder.java

74 lines
2.0 KiB
Java
Raw Normal View History

2018-06-18 07:53:33 +00:00
/*
* WorldEdit, a Minecraft world manipulation toolkit
* Copyright (C) sk89q <http://www.sk89q.com>
* Copyright (C) WorldEdit team and contributors
*
* This program is free software: you can redistribute it and/or modify it
* under the terms of the GNU Lesser General Public License as published by the
* Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License
* for more details.
*
* You should have received a copy of the GNU Lesser General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
2018-07-05 08:15:51 +00:00
package com.sk89q.worldedit.world.block;
2018-06-18 07:53:33 +00:00
2018-07-05 23:16:52 +00:00
import com.sk89q.worldedit.registry.state.Property;
2018-06-18 07:53:33 +00:00
import java.util.Map;
public interface BlockStateHolder<T extends BlockStateHolder> {
/**
* Get the block type
*
* @return The type
*/
BlockType getBlockType();
/**
* Returns a BlockState with the given state and value applied.
*
2018-07-05 23:16:52 +00:00
* @param property The state
2018-06-18 07:53:33 +00:00
* @param value The value
* @return The modified state, or same if could not be applied
*/
2018-07-05 23:16:52 +00:00
<V> T with(final Property<V> property, final V value);
2018-06-18 07:53:33 +00:00
/**
* Gets the value at the given state
*
2018-07-05 23:16:52 +00:00
* @param property The state
2018-06-18 07:53:33 +00:00
* @return The value
*/
2018-07-05 23:16:52 +00:00
<V> V getState(Property<V> property);
2018-06-18 07:53:33 +00:00
/**
* Gets an immutable collection of the states.
*
* @return The states
*/
2018-07-05 23:16:52 +00:00
Map<Property<?>, Object> getStates();
2018-06-18 12:51:21 +00:00
/**
* Checks if the type is the same, and if the matched states are the same.
*
* @param o other block
* @return true if equal
*/
boolean equalsFuzzy(BlockStateHolder o);
/**
* Returns an immutable BlockState from this BlockStateHolder.
*
* @return A BlockState
*/
BlockState toImmutableState();
2018-06-18 07:53:33 +00:00
}