cBlockInfo: Deprecate direct access to variables. (#4184)
This commit is contained in:
parent
7e9695ecb0
commit
cf75d7b2c5
@ -74,7 +74,7 @@ return
|
|||||||
cBlockInfo =
|
cBlockInfo =
|
||||||
{
|
{
|
||||||
Desc = [[
|
Desc = [[
|
||||||
This class is used to query and register block properties.
|
This class is used to query block properties.
|
||||||
]],
|
]],
|
||||||
Functions =
|
Functions =
|
||||||
{
|
{
|
||||||
@ -130,7 +130,7 @@ return
|
|||||||
Type = "cBlockInfo",
|
Type = "cBlockInfo",
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
Notes = "Returns the {{cBlockInfo}} structure for the specified block type.",
|
Notes = "Returns the {{cBlockInfo}} structure for the specified block type. <b>OBSOLETE</b>, use static functions instead",
|
||||||
},
|
},
|
||||||
GetHardness =
|
GetHardness =
|
||||||
{
|
{
|
||||||
@ -372,57 +372,57 @@ return
|
|||||||
m_BlockHeight =
|
m_BlockHeight =
|
||||||
{
|
{
|
||||||
Type = "number",
|
Type = "number",
|
||||||
Notes = "The height of the block, a value between 0.0 and 1.0",
|
Notes = "The height of the block, a value between 0.0 and 1.0. <b>OBSOLETE</b>, use cBlockInfo:GetBlockHeight() instead.",
|
||||||
},
|
},
|
||||||
m_CanBeTerraformed =
|
m_CanBeTerraformed =
|
||||||
{
|
{
|
||||||
Type = "bool",
|
Type = "bool",
|
||||||
Notes = "Is this block suited to be terraformed?",
|
Notes = "Is this block suited to be terraformed? <b>OBSOLETE</b>, use cBlockInfo:CanBeTerraformed() instead.",
|
||||||
},
|
},
|
||||||
m_FullyOccupiesVoxel =
|
m_FullyOccupiesVoxel =
|
||||||
{
|
{
|
||||||
Type = "bool",
|
Type = "bool",
|
||||||
Notes = "Does this block fully occupy its voxel - is it a 'full' block?",
|
Notes = "Does this block fully occupy its voxel - is it a 'full' block? <b>OBSOLETE</b>, use cBlockInfo:FullyOccupiesVoxel() instead.",
|
||||||
},
|
},
|
||||||
m_Hardness =
|
m_Hardness =
|
||||||
{
|
{
|
||||||
Type = "number",
|
Type = "number",
|
||||||
Notes = "The greater the value the longer the player needs to break the block.",
|
Notes = "The greater the value the longer the player needs to break the block. <b>OBSOLETE</b>, use cBlockInfo:GetHardness() instead.",
|
||||||
},
|
},
|
||||||
m_IsSnowable =
|
m_IsSnowable =
|
||||||
{
|
{
|
||||||
Type = "bool",
|
Type = "bool",
|
||||||
Notes = "Can this block hold snow atop?",
|
Notes = "Can this block hold snow atop? <b>OBSOLETE</b>, use cBlockInfo:IsSnowable() instead",
|
||||||
},
|
},
|
||||||
m_IsSolid =
|
m_IsSolid =
|
||||||
{
|
{
|
||||||
Type = "bool",
|
Type = "bool",
|
||||||
Notes = "Is this block solid (player cannot walk through)?",
|
Notes = "Is this block solid (player cannot walk through)? <b>OBSOLETE</b>, use cBlockInfo:IsSolid() instead.",
|
||||||
},
|
},
|
||||||
m_LightValue =
|
m_LightValue =
|
||||||
{
|
{
|
||||||
Type = "number",
|
Type = "number",
|
||||||
Notes = "How much light do the blocks emit on their own?",
|
Notes = "How much light do the blocks emit on their own? <b>OBSOLETE</b>, use cBlockInfo:GetLightValue() instead.",
|
||||||
},
|
},
|
||||||
m_OneHitDig =
|
m_OneHitDig =
|
||||||
{
|
{
|
||||||
Type = "bool",
|
Type = "bool",
|
||||||
Notes = "Is a block destroyed after a single hit?",
|
Notes = "Is a block destroyed after a single hit? <b>OBSOLETE</b>, use cBlockInfo:IsOneHitDig() instead.",
|
||||||
},
|
},
|
||||||
m_PistonBreakable =
|
m_PistonBreakable =
|
||||||
{
|
{
|
||||||
Type = "bool",
|
Type = "bool",
|
||||||
Notes = "Can a piston break this block?",
|
Notes = "Can a piston break this block? <b>OBSOLETE</b>, use cBlockInfo:IsPistonBreakable instead.",
|
||||||
},
|
},
|
||||||
m_SpreadLightFalloff =
|
m_SpreadLightFalloff =
|
||||||
{
|
{
|
||||||
Type = "number",
|
Type = "number",
|
||||||
Notes = "How much light do the blocks consume?",
|
Notes = "How much light do the blocks consume? <b>OBSOLETE</b>, use cBlockInfo:GetSpreadLightFalloff() instead.",
|
||||||
},
|
},
|
||||||
m_Transparent =
|
m_Transparent =
|
||||||
{
|
{
|
||||||
Type = "bool",
|
Type = "bool",
|
||||||
Notes = "Is a block completely transparent? (light doesn't get decreased(?))",
|
Notes = "Is a block completely transparent? (light doesn't get decreased(?)). <b>OBSOLETE</b>, use cBlockInfo:IsTransparent() instead.",
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
@ -291,6 +291,32 @@ tolua_lerror:
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
static int tolua_cBlockInfo_Get(lua_State * tolua_S)
|
||||||
|
{
|
||||||
|
cLuaState L(tolua_S);
|
||||||
|
if (
|
||||||
|
!L.CheckParamStaticSelf("cBlockInfo") ||
|
||||||
|
!L.CheckParamNumber(2)
|
||||||
|
)
|
||||||
|
{
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
BLOCKTYPE BlockType{};
|
||||||
|
L.GetStackValue(2, BlockType);
|
||||||
|
|
||||||
|
LOGWARNING("cBlockInfo:Get() is deprecated, use the static querying functions instead");
|
||||||
|
L.LogStackTrace(0);
|
||||||
|
|
||||||
|
cBlockInfo & BlockInfo = const_cast<cBlockInfo &>(cBlockInfo::Get(BlockType));
|
||||||
|
L.Push(&BlockInfo);
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
static int tolua_cBlockInfo_GetPlaceSound(lua_State * tolua_S)
|
static int tolua_cBlockInfo_GetPlaceSound(lua_State * tolua_S)
|
||||||
{
|
{
|
||||||
cLuaState L(tolua_S);
|
cLuaState L(tolua_S);
|
||||||
@ -347,7 +373,11 @@ static int tolua_set_cBlockInfo_m_PlaceSound(lua_State * tolua_S)
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
static int tolua_get_cBlockInfo_m_IsSnowable(lua_State * tolua_S)
|
/** cBlockInfo variables: access the corresponding getter function instead of the variable.
|
||||||
|
\tparam VariableType The type of the variable being accessed.
|
||||||
|
\tparam GetterFunction The function called to get the value returned to lua. */
|
||||||
|
template <typename VariableType, VariableType (*GetterFunction)(BLOCKTYPE)>
|
||||||
|
static int tolua_get_cBlockInfo(lua_State * tolua_S)
|
||||||
{
|
{
|
||||||
cLuaState L(tolua_S);
|
cLuaState L(tolua_S);
|
||||||
if (!L.CheckParamSelf("const cBlockInfo"))
|
if (!L.CheckParamSelf("const cBlockInfo"))
|
||||||
@ -358,9 +388,10 @@ static int tolua_get_cBlockInfo_m_IsSnowable(lua_State * tolua_S)
|
|||||||
const cBlockInfo * Self = nullptr;
|
const cBlockInfo * Self = nullptr;
|
||||||
L.GetStackValue(1, Self);
|
L.GetStackValue(1, Self);
|
||||||
|
|
||||||
L.Push(cBlockInfo::IsSnowable(Self->m_BlockType));
|
L.Push(GetterFunction(Self->m_BlockType));
|
||||||
LOGWARNING("cBlockInfo.m_IsSnowable is deprecated");
|
LOGWARNING("cBlockInfo variables are deprecated, use the static functions instead.");
|
||||||
L.LogStackTrace(0);
|
L.LogStackTrace(0);
|
||||||
|
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -368,7 +399,8 @@ static int tolua_get_cBlockInfo_m_IsSnowable(lua_State * tolua_S)
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
static int tolua_set_cBlockInfo_m_IsSnowable(lua_State * tolua_S)
|
/** cBlockInfo variables: Print deprecation message on assignment. */
|
||||||
|
static int tolua_set_cBlockInfo(lua_State * tolua_S)
|
||||||
{
|
{
|
||||||
cLuaState L(tolua_S);
|
cLuaState L(tolua_S);
|
||||||
if (!L.CheckParamSelf("cBlockInfo"))
|
if (!L.CheckParamSelf("cBlockInfo"))
|
||||||
@ -376,7 +408,7 @@ static int tolua_set_cBlockInfo_m_IsSnowable(lua_State * tolua_S)
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
LOGWARNING("cBlockInfo.m_IsSnowable is deprecated in favour of cBlockInfo::IsSnowable()");
|
LOGWARNING("cBlockInfo variables are deprecated in favour of the static functions.");
|
||||||
L.LogStackTrace(0);
|
L.LogStackTrace(0);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
@ -417,7 +449,7 @@ static int tolua_set_cItem_m_Lore(lua_State * tolua_S)
|
|||||||
if (
|
if (
|
||||||
!L.CheckParamSelf("cItem") ||
|
!L.CheckParamSelf("cItem") ||
|
||||||
!L.CheckParamString(2)
|
!L.CheckParamString(2)
|
||||||
)
|
)
|
||||||
{
|
{
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
@ -586,9 +618,23 @@ void DeprecatedBindings::Bind(lua_State * tolua_S)
|
|||||||
tolua_function(tolua_S, "StringToMobType", tolua_AllToLua_StringToMobType00);
|
tolua_function(tolua_S, "StringToMobType", tolua_AllToLua_StringToMobType00);
|
||||||
|
|
||||||
tolua_beginmodule(tolua_S, "cBlockInfo");
|
tolua_beginmodule(tolua_S, "cBlockInfo");
|
||||||
tolua_function(tolua_S, "GetPlaceSound", tolua_cBlockInfo_GetPlaceSound);
|
tolua_function(tolua_S, "Get", tolua_cBlockInfo_Get);
|
||||||
tolua_variable(tolua_S, "m_PlaceSound", tolua_get_cBlockInfo_m_PlaceSound, tolua_set_cBlockInfo_m_PlaceSound);
|
tolua_function(tolua_S, "GetPlaceSound", tolua_cBlockInfo_GetPlaceSound);
|
||||||
tolua_variable(tolua_S, "m_IsSnowable", tolua_get_cBlockInfo_m_IsSnowable, tolua_set_cBlockInfo_m_IsSnowable);
|
tolua_variable(tolua_S, "m_PlaceSound", tolua_get_cBlockInfo_m_PlaceSound, tolua_set_cBlockInfo_m_PlaceSound);
|
||||||
|
tolua_variable(tolua_S, "m_LightValue", tolua_get_cBlockInfo<NIBBLETYPE, cBlockInfo::GetLightValue >, tolua_set_cBlockInfo);
|
||||||
|
tolua_variable(tolua_S, "m_SpreadLightFalloff", tolua_get_cBlockInfo<NIBBLETYPE, cBlockInfo::GetSpreadLightFalloff>, tolua_set_cBlockInfo);
|
||||||
|
tolua_variable(tolua_S, "m_Transparent", tolua_get_cBlockInfo<bool, cBlockInfo::IsTransparent >, tolua_set_cBlockInfo);
|
||||||
|
tolua_variable(tolua_S, "m_OneHitDig", tolua_get_cBlockInfo<bool, cBlockInfo::IsOneHitDig >, tolua_set_cBlockInfo);
|
||||||
|
tolua_variable(tolua_S, "m_PistonBreakable", tolua_get_cBlockInfo<bool, cBlockInfo::IsPistonBreakable >, tolua_set_cBlockInfo);
|
||||||
|
tolua_variable(tolua_S, "m_IsRainBlocker", tolua_get_cBlockInfo<bool, cBlockInfo::IsRainBlocker >, tolua_set_cBlockInfo);
|
||||||
|
tolua_variable(tolua_S, "m_IsSkylightDispersant", tolua_get_cBlockInfo<bool, cBlockInfo::IsSkylightDispersant >, tolua_set_cBlockInfo);
|
||||||
|
tolua_variable(tolua_S, "m_IsSnowable", tolua_get_cBlockInfo<bool, cBlockInfo::IsSnowable >, tolua_set_cBlockInfo);
|
||||||
|
tolua_variable(tolua_S, "m_IsSolid", tolua_get_cBlockInfo<bool, cBlockInfo::IsSolid >, tolua_set_cBlockInfo);
|
||||||
|
tolua_variable(tolua_S, "m_UseableBySpectator", tolua_get_cBlockInfo<bool, cBlockInfo::IsUseableBySpectator >, tolua_set_cBlockInfo);
|
||||||
|
tolua_variable(tolua_S, "m_FullyOccupiesVoxel", tolua_get_cBlockInfo<bool, cBlockInfo::FullyOccupiesVoxel >, tolua_set_cBlockInfo);
|
||||||
|
tolua_variable(tolua_S, "m_CanBeTerraformed", tolua_get_cBlockInfo<bool, cBlockInfo::CanBeTerraformed >, tolua_set_cBlockInfo);
|
||||||
|
tolua_variable(tolua_S, "m_BlockHeight", tolua_get_cBlockInfo<float, cBlockInfo::GetBlockHeight >, tolua_set_cBlockInfo);
|
||||||
|
tolua_variable(tolua_S, "m_Hardness", tolua_get_cBlockInfo<float, cBlockInfo::GetHardness >, tolua_set_cBlockInfo);
|
||||||
tolua_endmodule(tolua_S);
|
tolua_endmodule(tolua_S);
|
||||||
|
|
||||||
tolua_beginmodule(tolua_S, "cItem");
|
tolua_beginmodule(tolua_S, "cItem");
|
||||||
|
129
src/BlockInfo.h
129
src/BlockInfo.h
@ -15,12 +15,70 @@ class cBlockHandler;
|
|||||||
class cBlockInfo
|
class cBlockInfo
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
|
// tolua_end
|
||||||
|
|
||||||
/** Returns the associated BlockInfo structure for the specified block type. */
|
/** The block type associated with this cBlockInfo. Needed for DeprecatedBindings.cpp */
|
||||||
|
BLOCKTYPE m_BlockType;
|
||||||
|
|
||||||
/** This accessor makes sure that the cBlockInfo structures are properly initialized exactly once.
|
/** Returns the associated BlockInfo structure for the specified block type.
|
||||||
|
This accessor makes sure that the cBlockInfo structures are properly initialized exactly once.
|
||||||
It does so by using the C++ singleton approximation - storing the actual singleton as the function's static variable. */
|
It does so by using the C++ singleton approximation - storing the actual singleton as the function's static variable. */
|
||||||
static cBlockInfo & Get(BLOCKTYPE a_Type);
|
inline static const cBlockInfo & Get(BLOCKTYPE a_Type);
|
||||||
|
|
||||||
|
// tolua_begin
|
||||||
|
|
||||||
|
inline static NIBBLETYPE GetLightValue (BLOCKTYPE a_Type) { return Get(a_Type).m_LightValue; }
|
||||||
|
inline static NIBBLETYPE GetSpreadLightFalloff(BLOCKTYPE a_Type) { return Get(a_Type).m_SpreadLightFalloff; }
|
||||||
|
inline static bool IsTransparent (BLOCKTYPE a_Type) { return Get(a_Type).m_Transparent; }
|
||||||
|
inline static bool IsOneHitDig (BLOCKTYPE a_Type) { return Get(a_Type).m_OneHitDig; }
|
||||||
|
inline static bool IsPistonBreakable (BLOCKTYPE a_Type) { return Get(a_Type).m_PistonBreakable; }
|
||||||
|
inline static bool IsRainBlocker (BLOCKTYPE a_Type) { return Get(a_Type).m_IsRainBlocker; }
|
||||||
|
inline static bool IsSkylightDispersant (BLOCKTYPE a_Type)
|
||||||
|
{
|
||||||
|
return ((Get(a_Type).m_IsSkylightDispersant) || (Get(a_Type).m_SpreadLightFalloff > 1));
|
||||||
|
}
|
||||||
|
inline static bool IsSnowable (BLOCKTYPE a_Type)
|
||||||
|
{
|
||||||
|
return (
|
||||||
|
(a_Type == E_BLOCK_ICE) ||
|
||||||
|
(a_Type == E_BLOCK_LEAVES) ||
|
||||||
|
(!IsTransparent(a_Type) && (a_Type != E_BLOCK_PACKED_ICE))
|
||||||
|
);
|
||||||
|
}
|
||||||
|
inline static bool IsSolid (BLOCKTYPE a_Type) { return Get(a_Type).m_IsSolid; }
|
||||||
|
inline static bool IsUseableBySpectator (BLOCKTYPE a_Type) { return Get(a_Type).m_UseableBySpectator; }
|
||||||
|
inline static bool FullyOccupiesVoxel (BLOCKTYPE a_Type) { return Get(a_Type).m_FullyOccupiesVoxel; }
|
||||||
|
inline static bool CanBeTerraformed (BLOCKTYPE a_Type) { return Get(a_Type).m_CanBeTerraformed; }
|
||||||
|
inline static float GetBlockHeight (BLOCKTYPE a_Type) { return Get(a_Type).m_BlockHeight; }
|
||||||
|
inline static float GetHardness (BLOCKTYPE a_Type) { return Get(a_Type).m_Hardness; }
|
||||||
|
|
||||||
|
// tolua_end
|
||||||
|
|
||||||
|
inline static cBlockHandler * GetHandler (BLOCKTYPE a_Type) { return Get(a_Type).m_Handler.get(); }
|
||||||
|
|
||||||
|
/** Creates a default BlockInfo structure, initializes all values to their defaults */
|
||||||
|
cBlockInfo():
|
||||||
|
m_BlockType(E_BLOCK_STONE),
|
||||||
|
m_LightValue(0x00),
|
||||||
|
m_SpreadLightFalloff(0x0f),
|
||||||
|
m_Transparent(false),
|
||||||
|
m_OneHitDig(false),
|
||||||
|
m_PistonBreakable(false),
|
||||||
|
m_IsRainBlocker(false),
|
||||||
|
m_IsSkylightDispersant(false),
|
||||||
|
m_IsSolid(true),
|
||||||
|
m_UseableBySpectator(false),
|
||||||
|
m_FullyOccupiesVoxel(false),
|
||||||
|
m_CanBeTerraformed(false),
|
||||||
|
m_BlockHeight(1.0),
|
||||||
|
m_Hardness(0.0f),
|
||||||
|
m_Handler()
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
private:
|
||||||
|
/** Storage for all the BlockInfo structures. */
|
||||||
|
class cBlockInfoArray;
|
||||||
|
|
||||||
/** How much light do the blocks emit on their own? */
|
/** How much light do the blocks emit on their own? */
|
||||||
NIBBLETYPE m_LightValue;
|
NIBBLETYPE m_LightValue;
|
||||||
@ -61,8 +119,6 @@ public:
|
|||||||
/** Block's hardness. The greater the value the longer the player needs to break the block. */
|
/** Block's hardness. The greater the value the longer the player needs to break the block. */
|
||||||
float m_Hardness;
|
float m_Hardness;
|
||||||
|
|
||||||
// tolua_end
|
|
||||||
|
|
||||||
/** Custom deleter allows cBlockHandler to be an incomplete type. */
|
/** Custom deleter allows cBlockHandler to be an incomplete type. */
|
||||||
struct sHandlerDeleter
|
struct sHandlerDeleter
|
||||||
{
|
{
|
||||||
@ -71,63 +127,6 @@ public:
|
|||||||
|
|
||||||
/** Associated block handler. */
|
/** Associated block handler. */
|
||||||
std::unique_ptr<cBlockHandler, sHandlerDeleter> m_Handler;
|
std::unique_ptr<cBlockHandler, sHandlerDeleter> m_Handler;
|
||||||
|
|
||||||
/** The block type associated with this cBlockInfo. Needed for DeprecatedBindings.cpp */
|
|
||||||
BLOCKTYPE m_BlockType;
|
|
||||||
|
|
||||||
// tolua_begin
|
|
||||||
|
|
||||||
inline static NIBBLETYPE GetLightValue (BLOCKTYPE a_Type) { return Get(a_Type).m_LightValue; }
|
|
||||||
inline static NIBBLETYPE GetSpreadLightFalloff(BLOCKTYPE a_Type) { return Get(a_Type).m_SpreadLightFalloff; }
|
|
||||||
inline static bool IsTransparent (BLOCKTYPE a_Type) { return Get(a_Type).m_Transparent; }
|
|
||||||
inline static bool IsOneHitDig (BLOCKTYPE a_Type) { return Get(a_Type).m_OneHitDig; }
|
|
||||||
inline static bool IsPistonBreakable (BLOCKTYPE a_Type) { return Get(a_Type).m_PistonBreakable; }
|
|
||||||
inline static bool IsRainBlocker (BLOCKTYPE a_Type) { return Get(a_Type).m_IsRainBlocker; }
|
|
||||||
inline static bool IsSkylightDispersant (BLOCKTYPE a_Type)
|
|
||||||
{
|
|
||||||
return ((Get(a_Type).m_IsSkylightDispersant) || (Get(a_Type).m_SpreadLightFalloff > 1));
|
|
||||||
}
|
|
||||||
inline static bool IsSnowable (BLOCKTYPE a_Type)
|
|
||||||
{
|
|
||||||
return (
|
|
||||||
(a_Type == E_BLOCK_ICE)
|
|
||||||
|| (a_Type == E_BLOCK_LEAVES)
|
|
||||||
|| (!Get(a_Type).m_Transparent && (a_Type != E_BLOCK_PACKED_ICE))
|
|
||||||
);
|
|
||||||
}
|
|
||||||
inline static bool IsSolid (BLOCKTYPE a_Type) { return Get(a_Type).m_IsSolid; }
|
|
||||||
inline static bool IsUseableBySpectator (BLOCKTYPE a_Type) { return Get(a_Type).m_UseableBySpectator; }
|
|
||||||
inline static bool FullyOccupiesVoxel (BLOCKTYPE a_Type) { return Get(a_Type).m_FullyOccupiesVoxel; }
|
|
||||||
inline static bool CanBeTerraformed (BLOCKTYPE a_Type) { return Get(a_Type).m_CanBeTerraformed; }
|
|
||||||
inline static float GetBlockHeight (BLOCKTYPE a_Type) { return Get(a_Type).m_BlockHeight; }
|
|
||||||
inline static float GetHardness (BLOCKTYPE a_Type) { return Get(a_Type).m_Hardness; }
|
|
||||||
|
|
||||||
// tolua_end
|
|
||||||
|
|
||||||
inline static cBlockHandler * GetHandler (BLOCKTYPE a_Type) { return Get(a_Type).m_Handler.get(); }
|
|
||||||
|
|
||||||
/** Creates a default BlockInfo structure, initializes all values to their defaults */
|
|
||||||
cBlockInfo()
|
|
||||||
: m_LightValue(0x00)
|
|
||||||
, m_SpreadLightFalloff(0x0f)
|
|
||||||
, m_Transparent(false)
|
|
||||||
, m_OneHitDig(false)
|
|
||||||
, m_PistonBreakable(false)
|
|
||||||
, m_IsRainBlocker(false)
|
|
||||||
, m_IsSkylightDispersant(false)
|
|
||||||
, m_IsSolid(true)
|
|
||||||
, m_UseableBySpectator(false)
|
|
||||||
, m_FullyOccupiesVoxel(false)
|
|
||||||
, m_CanBeTerraformed(false)
|
|
||||||
, m_BlockHeight(1.0)
|
|
||||||
, m_Hardness(0.0f)
|
|
||||||
, m_Handler()
|
|
||||||
, m_BlockType(E_BLOCK_AIR)
|
|
||||||
{}
|
|
||||||
|
|
||||||
private:
|
|
||||||
/** Storage for all the BlockInfo structures. */
|
|
||||||
class cBlockInfoArray;
|
|
||||||
}; // tolua_export
|
}; // tolua_export
|
||||||
|
|
||||||
|
|
||||||
@ -146,9 +145,9 @@ public:
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
inline cBlockInfo & cBlockInfo::Get(BLOCKTYPE a_Type)
|
inline const cBlockInfo & cBlockInfo::Get(BLOCKTYPE a_Type)
|
||||||
{
|
{
|
||||||
static cBlockInfoArray ms_Info;
|
static const cBlockInfoArray ms_Info;
|
||||||
return ms_Info[a_Type];
|
return ms_Info[a_Type];
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -159,5 +158,5 @@ inline cBlockInfo & cBlockInfo::Get(BLOCKTYPE a_Type)
|
|||||||
// Shortcut to get the blockhandler for a specific block
|
// Shortcut to get the blockhandler for a specific block
|
||||||
inline cBlockHandler * BlockHandler(BLOCKTYPE a_BlockType)
|
inline cBlockHandler * BlockHandler(BLOCKTYPE a_BlockType)
|
||||||
{
|
{
|
||||||
return cBlockInfo::Get(a_BlockType).m_Handler.get();
|
return cBlockInfo::GetHandler(a_BlockType);
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user