mirror of
https://github.com/NoCheatPlus/NoCheatPlus.git
synced 2025-01-04 23:07:44 +01:00
Distinguish solid and ground materials, add diode to gorund (fixes
ticket #280).
This commit is contained in:
parent
f0ba361968
commit
41dd43f0de
@ -253,6 +253,8 @@ public class BlockProperties {
|
|||||||
public static final int F_LAVA = 0x20;
|
public static final int F_LAVA = 0x20;
|
||||||
/** 150% height, like fences.*/
|
/** 150% height, like fences.*/
|
||||||
public static final int F_HEIGHT150 = 0x40;
|
public static final int F_HEIGHT150 = 0x40;
|
||||||
|
/** The player can stand on these, sneaking or not. */
|
||||||
|
public static final int F_GROUND = 0x80;
|
||||||
|
|
||||||
static{
|
static{
|
||||||
init();
|
init();
|
||||||
@ -309,7 +311,9 @@ public class BlockProperties {
|
|||||||
if (block != null){
|
if (block != null){
|
||||||
if (block.material != null){
|
if (block.material != null){
|
||||||
final net.minecraft.server.Material material = block.material;
|
final net.minecraft.server.Material material = block.material;
|
||||||
if (material.isSolid()) blockFlags[i] |= F_SOLID;
|
if (material.isSolid()){
|
||||||
|
blockFlags[i] |= F_SOLID | F_GROUND;
|
||||||
|
}
|
||||||
if (material.isLiquid()) blockFlags[i] |= F_LIQUID;
|
if (material.isLiquid()) blockFlags[i] |= F_LIQUID;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -342,8 +346,9 @@ public class BlockProperties {
|
|||||||
// Workarounds.
|
// Workarounds.
|
||||||
for (final Material mat : new Material[]{
|
for (final Material mat : new Material[]{
|
||||||
Material.WATER_LILY, Material.LADDER,
|
Material.WATER_LILY, Material.LADDER,
|
||||||
|
Material.DIODE_BLOCK_OFF, Material.DIODE_BLOCK_ON,
|
||||||
}){
|
}){
|
||||||
blockFlags[mat.getId()] |= F_SOLID;
|
blockFlags[mat.getId()] |= F_GROUND;
|
||||||
}
|
}
|
||||||
// Ignore for passable.
|
// Ignore for passable.
|
||||||
for (final Material mat : new Material[]{
|
for (final Material mat : new Material[]{
|
||||||
@ -841,6 +846,15 @@ public class BlockProperties {
|
|||||||
return (blockFlags[id] & F_SOLID) != 0;
|
return (blockFlags[id] & F_SOLID) != 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Might hold true for liquids too.
|
||||||
|
* @param id
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
public static final boolean isGround(final int id){
|
||||||
|
return (blockFlags[id] & F_GROUND) != 0;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Just check if a position is not inside of a block that has a bounding box.<br>
|
* Just check if a position is not inside of a block that has a bounding box.<br>
|
||||||
* This is an inaccurate check, it also returns false for doors etc.
|
* This is an inaccurate check, it also returns false for doors etc.
|
||||||
@ -1054,11 +1068,11 @@ public class BlockProperties {
|
|||||||
for (int z = Location.locToBlock(minZ); z <= Location.locToBlock(maxZ); z++){
|
for (int z = Location.locToBlock(minZ); z <= Location.locToBlock(maxZ); z++){
|
||||||
for (int y = Location.locToBlock(minY - 0.5626); y <= Location.locToBlock(maxY); y++){
|
for (int y = Location.locToBlock(minY - 0.5626); y <= Location.locToBlock(maxY); y++){
|
||||||
final int id = access.getTypeId(x, y, z);
|
final int id = access.getTypeId(x, y, z);
|
||||||
if ((BlockProperties.getBLockFlags(id) & F_SOLID) != 0){
|
if ((BlockProperties.getBLockFlags(id) & F_GROUND) != 0){
|
||||||
// Might collide.
|
// Might collide.
|
||||||
if (collidesBlock(access, minX, minY, minZ, maxX, maxY, maxZ, x, y, z, id)){
|
if (collidesBlock(access, minX, minY, minZ, maxX, maxY, maxZ, x, y, z, id)){
|
||||||
final int aboveId = access.getTypeId(x, y + 1, z);
|
final int aboveId = access.getTypeId(x, y + 1, z);
|
||||||
if ((BlockProperties.getBLockFlags(aboveId) & F_SOLID) != 0){
|
if ((BlockProperties.getBLockFlags(aboveId) & F_GROUND) != 0){
|
||||||
// Check against spider type hacks.
|
// Check against spider type hacks.
|
||||||
if (collidesBlock(access, minX, minY, minZ, maxX, Math.max(maxY, 1.49 + y), maxZ, x, y + 1, z, aboveId)){
|
if (collidesBlock(access, minX, minY, minZ, maxX, Math.max(maxY, 1.49 + y), maxZ, x, y + 1, z, aboveId)){
|
||||||
// TODO: This might be seen as a violation for many block types.
|
// TODO: This might be seen as a violation for many block types.
|
||||||
|
Loading…
Reference in New Issue
Block a user