Cleanup some workarounds and warnings (#4735)
* Cleanup thread_local usage in FastRandom * Use constexpr to avoid clang warning * Fix more Wglobal-constructor warnings * Make MSVC happy?
This commit is contained in:
parent
154df6b09d
commit
84289a2ba9
@ -25,18 +25,9 @@ class cBlockIDMap
|
|||||||
typedef std::map<AString, std::pair<short, short>, Comparator> ItemMap;
|
typedef std::map<AString, std::pair<short, short>, Comparator> ItemMap;
|
||||||
|
|
||||||
public:
|
public:
|
||||||
static bool m_bHasRunInit;
|
|
||||||
|
|
||||||
cBlockIDMap(void)
|
cBlockIDMap(void)
|
||||||
{
|
{
|
||||||
// Dont load items.ini on construct, this will search the wrong path when running as a service.
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
void init()
|
|
||||||
{
|
|
||||||
m_bHasRunInit = true;
|
|
||||||
|
|
||||||
cIniFile Ini;
|
cIniFile Ini;
|
||||||
if (!Ini.ReadFile("items.ini"))
|
if (!Ini.ReadFile("items.ini"))
|
||||||
{
|
{
|
||||||
@ -189,8 +180,11 @@ protected:
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
bool cBlockIDMap::m_bHasRunInit = false;
|
static cBlockIDMap & GetBlockIDMap()
|
||||||
static cBlockIDMap gsBlockIDMap;
|
{
|
||||||
|
static cBlockIDMap IDMap;
|
||||||
|
return IDMap;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
@ -224,11 +218,7 @@ int BlockStringToType(const AString & a_BlockTypeString)
|
|||||||
return res;
|
return res;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!gsBlockIDMap.m_bHasRunInit)
|
return GetBlockIDMap().Resolve(TrimString(a_BlockTypeString));
|
||||||
{
|
|
||||||
gsBlockIDMap.init();
|
|
||||||
}
|
|
||||||
return gsBlockIDMap.Resolve(TrimString(a_BlockTypeString));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -243,11 +233,7 @@ bool StringToItem(const AString & a_ItemTypeString, cItem & a_Item)
|
|||||||
ItemName = ItemName.substr(10);
|
ItemName = ItemName.substr(10);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!gsBlockIDMap.m_bHasRunInit)
|
return GetBlockIDMap().ResolveItem(ItemName, a_Item);
|
||||||
{
|
|
||||||
gsBlockIDMap.init();
|
|
||||||
}
|
|
||||||
return gsBlockIDMap.ResolveItem(ItemName, a_Item);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -256,11 +242,7 @@ bool StringToItem(const AString & a_ItemTypeString, cItem & a_Item)
|
|||||||
|
|
||||||
AString ItemToString(const cItem & a_Item)
|
AString ItemToString(const cItem & a_Item)
|
||||||
{
|
{
|
||||||
if (!gsBlockIDMap.m_bHasRunInit)
|
return GetBlockIDMap().Desolve(a_Item.m_ItemType, a_Item.m_ItemDamage);
|
||||||
{
|
|
||||||
gsBlockIDMap.init();
|
|
||||||
}
|
|
||||||
return gsBlockIDMap.Desolve(a_Item.m_ItemType, a_Item.m_ItemDamage);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -269,11 +251,7 @@ AString ItemToString(const cItem & a_Item)
|
|||||||
|
|
||||||
AString ItemTypeToString(short a_ItemType)
|
AString ItemTypeToString(short a_ItemType)
|
||||||
{
|
{
|
||||||
if (!gsBlockIDMap.m_bHasRunInit)
|
return GetBlockIDMap().Desolve(a_ItemType, -1);
|
||||||
{
|
|
||||||
gsBlockIDMap.init();
|
|
||||||
}
|
|
||||||
return gsBlockIDMap.Desolve(a_ItemType, -1);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -177,13 +177,6 @@ include_directories (SYSTEM "${CMAKE_CURRENT_SOURCE_DIR}/../lib/TCLAP/include")
|
|||||||
|
|
||||||
configure_file("BuildInfo.h.cmake" "${CMAKE_BINARY_DIR}/include/BuildInfo.h")
|
configure_file("BuildInfo.h.cmake" "${CMAKE_BINARY_DIR}/include/BuildInfo.h")
|
||||||
|
|
||||||
if("${CMAKE_CXX_COMPILER_ID}" STREQUAL "Clang")
|
|
||||||
set_source_files_properties(BlockType.cpp PROPERTIES COMPILE_FLAGS "-Wno-error=global-constructors")
|
|
||||||
set_source_files_properties(ByteBuffer.cpp PROPERTIES COMPILE_FLAGS "-Wno-error=global-constructors")
|
|
||||||
set_source_files_properties(ClientHandle.cpp PROPERTIES COMPILE_FLAGS "-Wno-error=global-constructors ")
|
|
||||||
set_source_files_properties(Statistics.cpp PROPERTIES COMPILE_FLAGS "-Wno-error=global-constructors")
|
|
||||||
endif()
|
|
||||||
|
|
||||||
if (NOT MSVC)
|
if (NOT MSVC)
|
||||||
# Bindings need to reference other folders, so they are done here instead
|
# Bindings need to reference other folders, so they are done here instead
|
||||||
# lib dependencies are not included
|
# lib dependencies are not included
|
||||||
|
@ -5,38 +5,18 @@
|
|||||||
#include "Globals.h"
|
#include "Globals.h"
|
||||||
#include "FastRandom.h"
|
#include "FastRandom.h"
|
||||||
|
|
||||||
#if defined (__GNUC__)
|
|
||||||
#define ATTRIBUTE_TLS static __thread
|
|
||||||
#elif defined (_MSC_VER)
|
|
||||||
#define ATTRIBUTE_TLS static __declspec(thread)
|
|
||||||
#else
|
|
||||||
#define ATTRIBUTE_TLS thread_local
|
|
||||||
#endif
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
MTRand & GetRandomProvider()
|
MTRand & GetRandomProvider()
|
||||||
{
|
{
|
||||||
// Some compilers don't support thread_local for non-POD types, this is purely a work around for that restriction.
|
thread_local MTRand Random = []
|
||||||
// There should be minimal overhead for the non-initializing case and all thread's instances are deleted properly.
|
|
||||||
ATTRIBUTE_TLS MTRand * LocalPtr = nullptr;
|
|
||||||
if (LocalPtr == nullptr)
|
|
||||||
{
|
{
|
||||||
// This list allows deletion of elements as if they had static storage duration
|
cRandomDeviceSeeder Seeder;
|
||||||
static std::mutex CSDeleteList;
|
return MTRand(Seeder);
|
||||||
static std::list<std::unique_ptr<MTRand>> DeleteList;
|
}();
|
||||||
|
return Random;
|
||||||
cRandomDeviceSeeder seeder;
|
|
||||||
auto NewInstance = cpp14::make_unique<MTRand>(seeder);
|
|
||||||
auto TempPtr = NewInstance.get();
|
|
||||||
|
|
||||||
std::lock_guard<std::mutex> Lock(CSDeleteList);
|
|
||||||
DeleteList.push_front(std::move(NewInstance));
|
|
||||||
LocalPtr = TempPtr; // Set after push_back so LocalPtr won't dangle if it throws
|
|
||||||
}
|
|
||||||
return *LocalPtr;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -45,15 +25,11 @@ MTRand & GetRandomProvider()
|
|||||||
|
|
||||||
UInt32 Detail::GetRandomSeed()
|
UInt32 Detail::GetRandomSeed()
|
||||||
{
|
{
|
||||||
ATTRIBUTE_TLS bool SeedCounterInitialized = false;
|
thread_local UInt32 SeedCounter = []
|
||||||
ATTRIBUTE_TLS UInt32 SeedCounter = 0;
|
|
||||||
|
|
||||||
if (!SeedCounterInitialized)
|
|
||||||
{
|
{
|
||||||
std::random_device rd;
|
std::random_device rd;
|
||||||
std::uniform_int_distribution<UInt32> dist;
|
std::uniform_int_distribution<UInt32> dist;
|
||||||
SeedCounter = dist(rd);
|
return dist(rd);
|
||||||
SeedCounterInitialized = true;
|
}();
|
||||||
}
|
|
||||||
return ++SeedCounter;
|
return ++SeedCounter;
|
||||||
}
|
}
|
||||||
|
@ -67,10 +67,6 @@ SET (HDRS
|
|||||||
VillageGen.h
|
VillageGen.h
|
||||||
)
|
)
|
||||||
|
|
||||||
if("${CMAKE_CXX_COMPILER_ID}" STREQUAL "Clang")
|
|
||||||
set_source_files_properties(CompoGenBiomal.cpp PROPERTIES COMPILE_FLAGS "-Wno-error=global-constructors")
|
|
||||||
endif()
|
|
||||||
|
|
||||||
if(NOT MSVC)
|
if(NOT MSVC)
|
||||||
add_library(Generating ${SRCS} ${HDRS})
|
add_library(Generating ${SRCS} ${HDRS})
|
||||||
target_link_libraries(Generating fmt::fmt OSSupport Blocks Bindings)
|
target_link_libraries(Generating fmt::fmt OSSupport Blocks Bindings)
|
||||||
|
@ -27,30 +27,28 @@ class cPattern
|
|||||||
public:
|
public:
|
||||||
struct BlockInfo
|
struct BlockInfo
|
||||||
{
|
{
|
||||||
BLOCKTYPE m_BlockType;
|
BLOCKTYPE m_BlockType = E_BLOCK_STONE;
|
||||||
NIBBLETYPE m_BlockMeta;
|
NIBBLETYPE m_BlockMeta = 0;
|
||||||
};
|
};
|
||||||
|
|
||||||
cPattern(BlockInfo * a_TopBlocks, size_t a_Count)
|
constexpr cPattern(std::initializer_list<BlockInfo> a_TopBlocks)
|
||||||
{
|
{
|
||||||
|
ASSERT(a_TopBlocks.size() <= cChunkDef::Height);
|
||||||
// Copy the pattern into the top:
|
// Copy the pattern into the top:
|
||||||
for (size_t i = 0; i < a_Count; i++)
|
size_t i = 0;
|
||||||
|
for (const auto & Block : a_TopBlocks)
|
||||||
{
|
{
|
||||||
m_Pattern[i] = a_TopBlocks[i];
|
m_Pattern[i] = Block;
|
||||||
|
++i;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Fill the rest with stone:
|
// The remaining blocks default to stone
|
||||||
static BlockInfo Stone = {E_BLOCK_STONE, 0};
|
|
||||||
for (int i = static_cast<int>(a_Count); i < cChunkDef::Height; i++)
|
|
||||||
{
|
|
||||||
m_Pattern[i] = Stone;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
const BlockInfo * Get(void) const { return m_Pattern; }
|
const BlockInfo * Get(void) const { return m_Pattern; }
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
BlockInfo m_Pattern[cChunkDef::Height];
|
BlockInfo m_Pattern[cChunkDef::Height] = {};
|
||||||
} ;
|
} ;
|
||||||
|
|
||||||
|
|
||||||
@ -58,9 +56,9 @@ protected:
|
|||||||
|
|
||||||
|
|
||||||
////////////////////////////////////////////////////////////////////////////////
|
////////////////////////////////////////////////////////////////////////////////
|
||||||
// The arrays to use for the top block pattern definitions:
|
// Land top block patterns:
|
||||||
|
|
||||||
static cPattern::BlockInfo tbGrass[] =
|
static constexpr cPattern patGrass =
|
||||||
{
|
{
|
||||||
{E_BLOCK_GRASS, 0},
|
{E_BLOCK_GRASS, 0},
|
||||||
{E_BLOCK_DIRT, E_META_DIRT_NORMAL},
|
{E_BLOCK_DIRT, E_META_DIRT_NORMAL},
|
||||||
@ -68,7 +66,7 @@ static cPattern::BlockInfo tbGrass[] =
|
|||||||
{E_BLOCK_DIRT, E_META_DIRT_NORMAL},
|
{E_BLOCK_DIRT, E_META_DIRT_NORMAL},
|
||||||
} ;
|
} ;
|
||||||
|
|
||||||
static cPattern::BlockInfo tbSand[] =
|
static constexpr cPattern patSand =
|
||||||
{
|
{
|
||||||
{ E_BLOCK_SAND, 0},
|
{ E_BLOCK_SAND, 0},
|
||||||
{ E_BLOCK_SAND, 0},
|
{ E_BLOCK_SAND, 0},
|
||||||
@ -76,7 +74,7 @@ static cPattern::BlockInfo tbSand[] =
|
|||||||
{ E_BLOCK_SANDSTONE, 0},
|
{ E_BLOCK_SANDSTONE, 0},
|
||||||
} ;
|
} ;
|
||||||
|
|
||||||
static cPattern::BlockInfo tbDirt[] =
|
static constexpr cPattern patDirt =
|
||||||
{
|
{
|
||||||
{E_BLOCK_DIRT, E_META_DIRT_NORMAL},
|
{E_BLOCK_DIRT, E_META_DIRT_NORMAL},
|
||||||
{E_BLOCK_DIRT, E_META_DIRT_NORMAL},
|
{E_BLOCK_DIRT, E_META_DIRT_NORMAL},
|
||||||
@ -84,7 +82,7 @@ static cPattern::BlockInfo tbDirt[] =
|
|||||||
{E_BLOCK_DIRT, E_META_DIRT_NORMAL},
|
{E_BLOCK_DIRT, E_META_DIRT_NORMAL},
|
||||||
} ;
|
} ;
|
||||||
|
|
||||||
static cPattern::BlockInfo tbPodzol[] =
|
static constexpr cPattern patPodzol =
|
||||||
{
|
{
|
||||||
{E_BLOCK_DIRT, E_META_DIRT_PODZOL},
|
{E_BLOCK_DIRT, E_META_DIRT_PODZOL},
|
||||||
{E_BLOCK_DIRT, E_META_DIRT_NORMAL},
|
{E_BLOCK_DIRT, E_META_DIRT_NORMAL},
|
||||||
@ -92,7 +90,7 @@ static cPattern::BlockInfo tbPodzol[] =
|
|||||||
{E_BLOCK_DIRT, E_META_DIRT_NORMAL},
|
{E_BLOCK_DIRT, E_META_DIRT_NORMAL},
|
||||||
} ;
|
} ;
|
||||||
|
|
||||||
static cPattern::BlockInfo tbGrassLess[] =
|
static constexpr cPattern patGrassLess =
|
||||||
{
|
{
|
||||||
{E_BLOCK_DIRT, E_META_DIRT_GRASSLESS},
|
{E_BLOCK_DIRT, E_META_DIRT_GRASSLESS},
|
||||||
{E_BLOCK_DIRT, E_META_DIRT_NORMAL},
|
{E_BLOCK_DIRT, E_META_DIRT_NORMAL},
|
||||||
@ -100,7 +98,7 @@ static cPattern::BlockInfo tbGrassLess[] =
|
|||||||
{E_BLOCK_DIRT, E_META_DIRT_NORMAL},
|
{E_BLOCK_DIRT, E_META_DIRT_NORMAL},
|
||||||
} ;
|
} ;
|
||||||
|
|
||||||
static cPattern::BlockInfo tbMycelium[] =
|
static constexpr cPattern patMycelium =
|
||||||
{
|
{
|
||||||
{E_BLOCK_MYCELIUM, 0},
|
{E_BLOCK_MYCELIUM, 0},
|
||||||
{E_BLOCK_DIRT, 0},
|
{E_BLOCK_DIRT, 0},
|
||||||
@ -108,7 +106,7 @@ static cPattern::BlockInfo tbMycelium[] =
|
|||||||
{E_BLOCK_DIRT, 0},
|
{E_BLOCK_DIRT, 0},
|
||||||
} ;
|
} ;
|
||||||
|
|
||||||
static cPattern::BlockInfo tbGravel[] =
|
static constexpr cPattern patGravel =
|
||||||
{
|
{
|
||||||
{E_BLOCK_GRAVEL, 0},
|
{E_BLOCK_GRAVEL, 0},
|
||||||
{E_BLOCK_GRAVEL, 0},
|
{E_BLOCK_GRAVEL, 0},
|
||||||
@ -116,7 +114,7 @@ static cPattern::BlockInfo tbGravel[] =
|
|||||||
{E_BLOCK_STONE, 0},
|
{E_BLOCK_STONE, 0},
|
||||||
} ;
|
} ;
|
||||||
|
|
||||||
static cPattern::BlockInfo tbStone[] =
|
static constexpr cPattern patStone =
|
||||||
{
|
{
|
||||||
{E_BLOCK_STONE, 0},
|
{E_BLOCK_STONE, 0},
|
||||||
{E_BLOCK_STONE, 0},
|
{E_BLOCK_STONE, 0},
|
||||||
@ -127,9 +125,9 @@ static cPattern::BlockInfo tbStone[] =
|
|||||||
|
|
||||||
|
|
||||||
////////////////////////////////////////////////////////////////////////////////
|
////////////////////////////////////////////////////////////////////////////////
|
||||||
// Ocean floor pattern top-block definitions:
|
// Ocean floor patterns:
|
||||||
|
|
||||||
static cPattern::BlockInfo tbOFSand[] =
|
static constexpr cPattern patOFSand =
|
||||||
{
|
{
|
||||||
{E_BLOCK_SAND, 0},
|
{E_BLOCK_SAND, 0},
|
||||||
{E_BLOCK_SAND, 0},
|
{E_BLOCK_SAND, 0},
|
||||||
@ -137,7 +135,7 @@ static cPattern::BlockInfo tbOFSand[] =
|
|||||||
{E_BLOCK_SANDSTONE, 0}
|
{E_BLOCK_SANDSTONE, 0}
|
||||||
} ;
|
} ;
|
||||||
|
|
||||||
static cPattern::BlockInfo tbOFClay[] =
|
static constexpr cPattern patOFClay =
|
||||||
{
|
{
|
||||||
{ E_BLOCK_CLAY, 0},
|
{ E_BLOCK_CLAY, 0},
|
||||||
{ E_BLOCK_CLAY, 0},
|
{ E_BLOCK_CLAY, 0},
|
||||||
@ -145,7 +143,7 @@ static cPattern::BlockInfo tbOFClay[] =
|
|||||||
{ E_BLOCK_SAND, 0},
|
{ E_BLOCK_SAND, 0},
|
||||||
} ;
|
} ;
|
||||||
|
|
||||||
static cPattern::BlockInfo tbOFOrangeClay[] =
|
static constexpr cPattern patOFOrangeClay =
|
||||||
{
|
{
|
||||||
{ E_BLOCK_STAINED_CLAY, E_META_STAINED_GLASS_ORANGE},
|
{ E_BLOCK_STAINED_CLAY, E_META_STAINED_GLASS_ORANGE},
|
||||||
{ E_BLOCK_STAINED_CLAY, E_META_STAINED_GLASS_ORANGE},
|
{ E_BLOCK_STAINED_CLAY, E_META_STAINED_GLASS_ORANGE},
|
||||||
@ -156,26 +154,6 @@ static cPattern::BlockInfo tbOFOrangeClay[] =
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
////////////////////////////////////////////////////////////////////////////////
|
|
||||||
// Individual patterns to use:
|
|
||||||
|
|
||||||
static cPattern patGrass (tbGrass, ARRAYCOUNT(tbGrass));
|
|
||||||
static cPattern patSand (tbSand, ARRAYCOUNT(tbSand));
|
|
||||||
static cPattern patDirt (tbDirt, ARRAYCOUNT(tbDirt));
|
|
||||||
static cPattern patPodzol (tbPodzol, ARRAYCOUNT(tbPodzol));
|
|
||||||
static cPattern patGrassLess(tbGrassLess, ARRAYCOUNT(tbGrassLess));
|
|
||||||
static cPattern patMycelium (tbMycelium, ARRAYCOUNT(tbMycelium));
|
|
||||||
static cPattern patGravel (tbGravel, ARRAYCOUNT(tbGravel));
|
|
||||||
static cPattern patStone (tbStone, ARRAYCOUNT(tbStone));
|
|
||||||
|
|
||||||
static cPattern patOFSand (tbOFSand, ARRAYCOUNT(tbOFSand));
|
|
||||||
static cPattern patOFClay (tbOFClay, ARRAYCOUNT(tbOFClay));
|
|
||||||
static cPattern patOFOrangeClay(tbOFOrangeClay, ARRAYCOUNT(tbOFOrangeClay));
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
////////////////////////////////////////////////////////////////////////////////
|
////////////////////////////////////////////////////////////////////////////////
|
||||||
// cCompoGenBiomal:
|
// cCompoGenBiomal:
|
||||||
|
|
||||||
|
@ -40,10 +40,6 @@ SET (HDRS
|
|||||||
WinStackWalker.h
|
WinStackWalker.h
|
||||||
)
|
)
|
||||||
|
|
||||||
if("${CMAKE_CXX_COMPILER_ID}" STREQUAL "Clang")
|
|
||||||
add_flags_cxx("-Wno-error=global-constructors ")
|
|
||||||
endif()
|
|
||||||
|
|
||||||
if(NOT MSVC)
|
if(NOT MSVC)
|
||||||
add_library(OSSupport ${SRCS} ${HDRS})
|
add_library(OSSupport ${SRCS} ${HDRS})
|
||||||
target_link_libraries(OSSupport fmt::fmt)
|
target_link_libraries(OSSupport fmt::fmt)
|
||||||
|
@ -36,12 +36,7 @@
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
#ifdef __clang__
|
static constexpr Vector3i gCrossCoords[] =
|
||||||
#pragma clang diagnostic push
|
|
||||||
#pragma clang diagnostic ignored "-Wglobal-constructors"
|
|
||||||
#endif
|
|
||||||
|
|
||||||
static const Vector3i gCrossCoords[] =
|
|
||||||
{
|
{
|
||||||
{ 1, 0, 0},
|
{ 1, 0, 0},
|
||||||
{-1, 0, 0},
|
{-1, 0, 0},
|
||||||
@ -53,7 +48,7 @@ static const Vector3i gCrossCoords[] =
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
static const Vector3i gNeighborCoords[] =
|
static constexpr Vector3i gNeighborCoords[] =
|
||||||
{
|
{
|
||||||
{ 1, 0, 0},
|
{ 1, 0, 0},
|
||||||
{-1, 0, 0},
|
{-1, 0, 0},
|
||||||
@ -61,11 +56,7 @@ static const Vector3i gNeighborCoords[] =
|
|||||||
{ 0, -1, 0},
|
{ 0, -1, 0},
|
||||||
{ 0, 0, 1},
|
{ 0, 0, 1},
|
||||||
{ 0, 0, -1},
|
{ 0, 0, -1},
|
||||||
} ;
|
};
|
||||||
|
|
||||||
#ifdef __clang__
|
|
||||||
#pragma clang diagnostic pop
|
|
||||||
#endif
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
@ -6,6 +6,10 @@
|
|||||||
#include "Statistics.h"
|
#include "Statistics.h"
|
||||||
|
|
||||||
|
|
||||||
|
#ifdef __clang__
|
||||||
|
#pragma clang diagnostic push
|
||||||
|
#pragma clang diagnostic ignored "-Wglobal-constructors"
|
||||||
|
#endif
|
||||||
|
|
||||||
cStatInfo cStatInfo::ms_Info[statCount] =
|
cStatInfo cStatInfo::ms_Info[statCount] =
|
||||||
{
|
{
|
||||||
@ -76,6 +80,10 @@ cStatInfo cStatInfo::ms_Info[statCount] =
|
|||||||
cStatInfo(statTreasureFished, "stat.treasureFished")
|
cStatInfo(statTreasureFished, "stat.treasureFished")
|
||||||
};
|
};
|
||||||
|
|
||||||
|
#ifdef __clang__
|
||||||
|
#pragma clang diagnostic pop
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
@ -17,8 +17,8 @@ public:
|
|||||||
T x, y, z;
|
T x, y, z;
|
||||||
|
|
||||||
|
|
||||||
inline Vector3(void) : x(0), y(0), z(0) {}
|
constexpr Vector3(void) : x(0), y(0), z(0) {}
|
||||||
inline Vector3(T a_x, T a_y, T a_z) : x(a_x), y(a_y), z(a_z) {}
|
constexpr Vector3(T a_x, T a_y, T a_z) : x(a_x), y(a_y), z(a_z) {}
|
||||||
|
|
||||||
|
|
||||||
#ifdef TOLUA_EXPOSITION // Hardcoded copy constructors (tolua++ does not support function templates .. yet)
|
#ifdef TOLUA_EXPOSITION // Hardcoded copy constructors (tolua++ does not support function templates .. yet)
|
||||||
@ -31,7 +31,12 @@ public:
|
|||||||
// tolua_end
|
// tolua_end
|
||||||
// Conversion constructors where U is not the same as T leaving the copy-constructor implicitly generated
|
// Conversion constructors where U is not the same as T leaving the copy-constructor implicitly generated
|
||||||
template <typename U, typename = typename std::enable_if<!std::is_same<U, T>::value>::type>
|
template <typename U, typename = typename std::enable_if<!std::is_same<U, T>::value>::type>
|
||||||
Vector3(const Vector3<U> & a_Rhs): x(static_cast<T>(a_Rhs.x)), y(static_cast<T>(a_Rhs.y)), z(static_cast<T>(a_Rhs.z)) {}
|
constexpr Vector3(const Vector3<U> & a_Rhs):
|
||||||
|
x(static_cast<T>(a_Rhs.x)),
|
||||||
|
y(static_cast<T>(a_Rhs.y)),
|
||||||
|
z(static_cast<T>(a_Rhs.z))
|
||||||
|
{
|
||||||
|
}
|
||||||
// tolua_begin
|
// tolua_begin
|
||||||
|
|
||||||
inline void Set(T a_x, T a_y, T a_z)
|
inline void Set(T a_x, T a_y, T a_z)
|
||||||
|
Loading…
Reference in New Issue
Block a user