Enable some more clang-tidy linter checks (#4738)
* Avoid inefficient AString -> c_str() -> AString round trip * Avoid redundant string init expressions * Avoid unnecessary return, continue, etc. * Add .clang-format to help with clang-tidy fix-its * Avoid unnecessary passing by value * Avoid unnecessary local copying * Avoid copying in range-for loops * Avoid over-complicated boolean expressions * Some violations missed by my local clang-tidy * Allow unnecessary continue statements * Add brackets * Another expression missed locally * Move BindingsProcessor call into clang-tidy.sh and add space * Fix pushd not found error * Different grouping of CheckBlockInteractionRate
This commit is contained in:
parent
edb548f9d6
commit
13144a08e4
@ -26,7 +26,6 @@ jobs:
|
|||||||
docker: *cube_docker
|
docker: *cube_docker
|
||||||
steps:
|
steps:
|
||||||
- attach_workspace: { at: ~/ }
|
- attach_workspace: { at: ~/ }
|
||||||
- run: (cd src/Bindings && lua BindingsProcessor.lua)
|
|
||||||
- run: ./clang-tidy.sh -j 2
|
- run: ./clang-tidy.sh -j 2
|
||||||
|
|
||||||
workflows:
|
workflows:
|
||||||
|
39
.clang-format
Normal file
39
.clang-format
Normal file
@ -0,0 +1,39 @@
|
|||||||
|
# Not the exact style guide but enough for basic clang-tidy fix-its
|
||||||
|
Language: Cpp
|
||||||
|
BasedOnStyle: LLVM
|
||||||
|
|
||||||
|
AlignAfterOpenBracket: AlwaysBreak
|
||||||
|
BreakConstructorInitializers: AfterColon
|
||||||
|
ConstructorInitializerAllOnOneLineOrOnePerLine: true
|
||||||
|
PointerAlignment: Middle
|
||||||
|
SortIncludes: false
|
||||||
|
SpacesBeforeTrailingComments: 2
|
||||||
|
UseTab: Always
|
||||||
|
MaxEmptyLinesToKeep: 5
|
||||||
|
|
||||||
|
TabWidth: 4
|
||||||
|
ConstructorInitializerIndentWidth: 4
|
||||||
|
ContinuationIndentWidth: 4
|
||||||
|
IndentWidth: 4
|
||||||
|
IndentCaseLabels: true
|
||||||
|
|
||||||
|
BreakBeforeBraces: Custom
|
||||||
|
BraceWrapping:
|
||||||
|
AfterClass: true
|
||||||
|
AfterControlStatement: true
|
||||||
|
AfterEnum: true
|
||||||
|
AfterExternBlock: true
|
||||||
|
AfterFunction: true
|
||||||
|
AfterNamespace: true
|
||||||
|
AfterStruct: true
|
||||||
|
AfterUnion: true
|
||||||
|
BeforeCatch: true
|
||||||
|
BeforeElse: true
|
||||||
|
IndentBraces: false
|
||||||
|
SplitEmptyFunction: true
|
||||||
|
SplitEmptyRecord: true
|
||||||
|
|
||||||
|
# Always include globals first
|
||||||
|
IncludeCategories:
|
||||||
|
- Regex: 'Globals.h'
|
||||||
|
Priority: -1
|
15
.clang-tidy
15
.clang-tidy
@ -1,4 +1,13 @@
|
|||||||
Checks: '-*,readability-identifier-naming'
|
Checks: >-
|
||||||
|
-*,
|
||||||
|
readability-identifier-naming,
|
||||||
|
readability-redundant-string-cstr,
|
||||||
|
readability-redundant-string-init,
|
||||||
|
readability-simplify-boolean-expr,
|
||||||
|
performance-unnecessary-value-param,
|
||||||
|
performance-unnecessary-copy-initialization,
|
||||||
|
performance-for-range-copy,
|
||||||
|
performance-implicit-conversion-in-loop,
|
||||||
CheckOptions:
|
CheckOptions:
|
||||||
- key: readability-identifier-naming.PrivateMemberPrefix
|
- key: readability-identifier-naming.PrivateMemberPrefix
|
||||||
value: 'm_'
|
value: 'm_'
|
||||||
@ -13,5 +22,9 @@ CheckOptions:
|
|||||||
# value: CamelCase
|
# value: CamelCase
|
||||||
#- key: readability-identifier-naming.EnumCase
|
#- key: readability-identifier-naming.EnumCase
|
||||||
# value: camelBack
|
# value: camelBack
|
||||||
|
|
||||||
|
- key: performance-unnecessary-value-param.AllowedTypes
|
||||||
|
value: 'cEntityEffect;cNoise'
|
||||||
WarningsAsErrors: '*'
|
WarningsAsErrors: '*'
|
||||||
HeaderFilterRegex: '/cuberite/src/\.?[^\.]'
|
HeaderFilterRegex: '/cuberite/src/\.?[^\.]'
|
||||||
|
FormatStyle: 'file'
|
||||||
|
@ -6,10 +6,14 @@ FIXES_FILE="tidy-fixes.yaml"
|
|||||||
REGEX="/cuberite/src/\.?[^\.]"
|
REGEX="/cuberite/src/\.?[^\.]"
|
||||||
ARGS="-header-filter $REGEX -quiet -export-fixes $FIXES_FILE "$@" $REGEX"
|
ARGS="-header-filter $REGEX -quiet -export-fixes $FIXES_FILE "$@" $REGEX"
|
||||||
|
|
||||||
|
# Generate the compilation database
|
||||||
mkdir -p tidy-build
|
mkdir -p tidy-build
|
||||||
cd tidy-build
|
cd tidy-build
|
||||||
cmake --target Cuberite -DCMAKE_EXPORT_COMPILE_COMMANDS=ON ..
|
cmake --target Cuberite -DCMAKE_EXPORT_COMPILE_COMMANDS=ON ..
|
||||||
|
|
||||||
|
# Ensure LuaState_Typedefs.inc has been generated
|
||||||
|
(cd ../src/Bindings && lua BindingsProcessor.lua)
|
||||||
|
|
||||||
if run-clang-tidy $ARGS; then
|
if run-clang-tidy $ARGS; then
|
||||||
echo "clang-tidy: No violations found"
|
echo "clang-tidy: No violations found"
|
||||||
else
|
else
|
||||||
|
@ -36,8 +36,8 @@ void cLuaServerHandle::SetServerHandle(cServerHandlePtr a_ServerHandle, cLuaServ
|
|||||||
{
|
{
|
||||||
ASSERT(m_ServerHandle == nullptr); // The handle can be set only once
|
ASSERT(m_ServerHandle == nullptr); // The handle can be set only once
|
||||||
|
|
||||||
m_ServerHandle = a_ServerHandle;
|
m_ServerHandle = std::move(a_ServerHandle);
|
||||||
m_Self = a_Self;
|
m_Self = std::move(a_Self);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -2014,7 +2014,7 @@ bool cLuaState::CheckParamStaticSelf(const char * a_SelfClassName)
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
bool cLuaState::IsParamUserType(int a_ParamIdx, AString a_UserType)
|
bool cLuaState::IsParamUserType(int a_ParamIdx, const AString & a_UserType)
|
||||||
{
|
{
|
||||||
ASSERT(IsValid());
|
ASSERT(IsValid());
|
||||||
|
|
||||||
|
@ -815,7 +815,7 @@ public:
|
|||||||
bool CheckParamStaticSelf(const char * a_SelfClassName);
|
bool CheckParamStaticSelf(const char * a_SelfClassName);
|
||||||
|
|
||||||
/** Returns true if the specified parameter is of the specified class. */
|
/** Returns true if the specified parameter is of the specified class. */
|
||||||
bool IsParamUserType(int a_ParamIdx, AString a_UserType);
|
bool IsParamUserType(int a_ParamIdx, const AString & a_UserType);
|
||||||
|
|
||||||
/** Returns true if the specified parameter is a number. */
|
/** Returns true if the specified parameter is a number. */
|
||||||
bool IsParamNumber(int a_ParamIdx);
|
bool IsParamNumber(int a_ParamIdx);
|
||||||
|
@ -40,7 +40,7 @@ bool cLuaUDPEndpoint::Open(UInt16 a_Port, cLuaUDPEndpointPtr a_Self)
|
|||||||
ASSERT(m_Self == nullptr); // Must not be opened yet
|
ASSERT(m_Self == nullptr); // Must not be opened yet
|
||||||
ASSERT(m_Endpoint == nullptr);
|
ASSERT(m_Endpoint == nullptr);
|
||||||
|
|
||||||
m_Self = a_Self;
|
m_Self = std::move(a_Self);
|
||||||
m_Endpoint = cNetwork::CreateUDPEndpoint(a_Port, *this);
|
m_Endpoint = cNetwork::CreateUDPEndpoint(a_Port, *this);
|
||||||
return m_Endpoint->IsOpen();
|
return m_Endpoint->IsOpen();
|
||||||
}
|
}
|
||||||
|
@ -409,7 +409,7 @@ static int tolua_LOG(lua_State * tolua_S)
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Log the message:
|
// Log the message:
|
||||||
cLogger::GetInstance().LogSimple(GetLogMessage(tolua_S).c_str(), LogLevel);
|
cLogger::GetInstance().LogSimple(GetLogMessage(tolua_S), LogLevel);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -427,7 +427,7 @@ static int tolua_LOGINFO(lua_State * tolua_S)
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
cLogger::GetInstance().LogSimple(GetLogMessage(tolua_S).c_str(), cLogger::llInfo);
|
cLogger::GetInstance().LogSimple(GetLogMessage(tolua_S), cLogger::llInfo);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -445,7 +445,7 @@ static int tolua_LOGWARN(lua_State * tolua_S)
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
cLogger::GetInstance().LogSimple(GetLogMessage(tolua_S).c_str(), cLogger::llWarning);
|
cLogger::GetInstance().LogSimple(GetLogMessage(tolua_S), cLogger::llWarning);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -463,7 +463,7 @@ static int tolua_LOGERROR(lua_State * tolua_S)
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
cLogger::GetInstance().LogSimple(GetLogMessage(tolua_S).c_str(), cLogger::llError);
|
cLogger::GetInstance().LogSimple(GetLogMessage(tolua_S), cLogger::llError);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -108,7 +108,7 @@ bool cPluginLua::Load(void)
|
|||||||
std::string PluginPath = GetLocalFolder() + "/";
|
std::string PluginPath = GetLocalFolder() + "/";
|
||||||
|
|
||||||
// List all Lua files for this plugin. Info.lua has a special handling - make it the last to load:
|
// List all Lua files for this plugin. Info.lua has a special handling - make it the last to load:
|
||||||
AStringVector Files = cFile::GetFolderContents(PluginPath.c_str());
|
AStringVector Files = cFile::GetFolderContents(PluginPath);
|
||||||
AStringVector LuaFiles;
|
AStringVector LuaFiles;
|
||||||
bool HasInfoLua = false;
|
bool HasInfoLua = false;
|
||||||
for (AStringVector::const_iterator itr = Files.begin(), end = Files.end(); itr != end; ++itr)
|
for (AStringVector::const_iterator itr = Files.begin(), end = Files.end(); itr != end; ++itr)
|
||||||
|
@ -57,7 +57,7 @@ void cPluginManager::RefreshPluginList(void)
|
|||||||
{
|
{
|
||||||
// Get a list of currently available folders:
|
// Get a list of currently available folders:
|
||||||
AString PluginsPath = GetPluginsPath() + "/";
|
AString PluginsPath = GetPluginsPath() + "/";
|
||||||
AStringVector Contents = cFile::GetFolderContents(PluginsPath.c_str());
|
AStringVector Contents = cFile::GetFolderContents(PluginsPath);
|
||||||
AStringVector Folders;
|
AStringVector Folders;
|
||||||
for (auto & item: Contents)
|
for (auto & item: Contents)
|
||||||
{
|
{
|
||||||
@ -1401,7 +1401,7 @@ bool cPluginManager::BindCommand(
|
|||||||
|
|
||||||
auto & reg = m_Commands[a_Command];
|
auto & reg = m_Commands[a_Command];
|
||||||
reg.m_Plugin = a_Plugin;
|
reg.m_Plugin = a_Plugin;
|
||||||
reg.m_Handler = a_Handler;
|
reg.m_Handler = std::move(a_Handler);
|
||||||
reg.m_Permission = a_Permission;
|
reg.m_Permission = a_Permission;
|
||||||
reg.m_HelpString = a_HelpString;
|
reg.m_HelpString = a_HelpString;
|
||||||
return true;
|
return true;
|
||||||
@ -1508,7 +1508,7 @@ bool cPluginManager::BindConsoleCommand(
|
|||||||
|
|
||||||
auto & reg = m_ConsoleCommands[a_Command];
|
auto & reg = m_ConsoleCommands[a_Command];
|
||||||
reg.m_Plugin = a_Plugin;
|
reg.m_Plugin = a_Plugin;
|
||||||
reg.m_Handler = a_Handler;
|
reg.m_Handler = std::move(a_Handler);
|
||||||
reg.m_Permission = "";
|
reg.m_Permission = "";
|
||||||
reg.m_HelpString = a_HelpString;
|
reg.m_HelpString = a_HelpString;
|
||||||
return true;
|
return true;
|
||||||
@ -1739,7 +1739,7 @@ AStringVector cPluginManager::GetFoldersToLoad(cSettingsRepositoryInterface & a_
|
|||||||
// Get the old format plugin list, and migrate it.
|
// Get the old format plugin list, and migrate it.
|
||||||
// Upgrade path added on 2020-03-27
|
// Upgrade path added on 2020-03-27
|
||||||
auto OldValues = a_Settings.GetValues("Plugins");
|
auto OldValues = a_Settings.GetValues("Plugins");
|
||||||
for (auto NameValue : OldValues)
|
for (const auto & NameValue : OldValues)
|
||||||
{
|
{
|
||||||
AString ValueName = NameValue.first;
|
AString ValueName = NameValue.first;
|
||||||
if (ValueName.compare("Plugin") == 0)
|
if (ValueName.compare("Plugin") == 0)
|
||||||
@ -1759,7 +1759,7 @@ AStringVector cPluginManager::GetFoldersToLoad(cSettingsRepositoryInterface & a_
|
|||||||
|
|
||||||
// Get the list of plugins to load:
|
// Get the list of plugins to load:
|
||||||
auto Values = a_Settings.GetValues("Plugins");
|
auto Values = a_Settings.GetValues("Plugins");
|
||||||
for (auto NameValue : Values)
|
for (const auto & NameValue : Values)
|
||||||
{
|
{
|
||||||
AString Enabled = NameValue.second;
|
AString Enabled = NameValue.second;
|
||||||
if (Enabled == "1")
|
if (Enabled == "1")
|
||||||
|
@ -51,7 +51,6 @@ void cDropSpenserEntity::AddDropSpenserDir(Vector3i & a_RelCoord, NIBBLETYPE a_D
|
|||||||
case E_META_DROPSPENSER_FACING_XP: a_RelCoord.x++; return;
|
case E_META_DROPSPENSER_FACING_XP: a_RelCoord.x++; return;
|
||||||
}
|
}
|
||||||
LOGWARNING("%s: Unhandled direction: %d", __FUNCTION__, a_Direction);
|
LOGWARNING("%s: Unhandled direction: %d", __FUNCTION__, a_Direction);
|
||||||
return;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -575,11 +575,7 @@ bool cHopperEntity::MoveItemsToChest(cChunk & a_Chunk, Vector3i a_Coords)
|
|||||||
FLOGWARNING("{0}: A chest entity was not found where expected, at {1} ({2}, {3}})", __FUNCTION__, a_Coords + ofs, ofs.x, ofs.z);
|
FLOGWARNING("{0}: A chest entity was not found where expected, at {1} ({2}, {3}})", __FUNCTION__, a_Coords + ofs, ofs.x, ofs.z);
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
if (MoveItemsToGrid(*chest))
|
return MoveItemsToGrid(*chest);
|
||||||
{
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
return false;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// The chest was single and nothing could be moved
|
// The chest was single and nothing could be moved
|
||||||
|
@ -76,14 +76,7 @@ bool cMobSpawnerEntity::UsedBy(cPlayer * a_Player)
|
|||||||
|
|
||||||
void cMobSpawnerEntity::UpdateActiveState(void)
|
void cMobSpawnerEntity::UpdateActiveState(void)
|
||||||
{
|
{
|
||||||
if (GetNearbyPlayersNum() > 0)
|
m_IsActive = (GetNearbyPlayersNum() > 0);
|
||||||
{
|
|
||||||
m_IsActive = true;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
m_IsActive = false;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -17,7 +17,7 @@ BlockInfo::BlockInfo(
|
|||||||
):
|
):
|
||||||
m_PluginName(aPluginName),
|
m_PluginName(aPluginName),
|
||||||
m_BlockTypeName(aBlockTypeName),
|
m_BlockTypeName(aBlockTypeName),
|
||||||
m_Handler(aHandler),
|
m_Handler(std::move(aHandler)),
|
||||||
m_Hints(aHints),
|
m_Hints(aHints),
|
||||||
m_HintCallbacks(aHintCallbacks)
|
m_HintCallbacks(aHintCallbacks)
|
||||||
{
|
{
|
||||||
@ -94,7 +94,9 @@ void BlockTypeRegistry::registerBlockType(
|
|||||||
const std::map<AString, BlockInfo::HintCallback> & aHintCallbacks
|
const std::map<AString, BlockInfo::HintCallback> & aHintCallbacks
|
||||||
)
|
)
|
||||||
{
|
{
|
||||||
auto blockInfo = std::make_shared<BlockInfo>(aPluginName, aBlockTypeName, aHandler, aHints, aHintCallbacks);
|
auto blockInfo = std::make_shared<BlockInfo>(
|
||||||
|
aPluginName, aBlockTypeName, std::move(aHandler), aHints, aHintCallbacks
|
||||||
|
);
|
||||||
|
|
||||||
// Check previous registrations:
|
// Check previous registrations:
|
||||||
cCSLock lock(m_CSRegistry);
|
cCSLock lock(m_CSRegistry);
|
||||||
@ -191,8 +193,8 @@ void BlockTypeRegistry::removeBlockTypeHint(
|
|||||||
// BlockTypeRegistry::AlreadyRegisteredException:
|
// BlockTypeRegistry::AlreadyRegisteredException:
|
||||||
|
|
||||||
BlockTypeRegistry::AlreadyRegisteredException::AlreadyRegisteredException(
|
BlockTypeRegistry::AlreadyRegisteredException::AlreadyRegisteredException(
|
||||||
std::shared_ptr<BlockInfo> aPreviousRegistration,
|
const std::shared_ptr<BlockInfo> & aPreviousRegistration,
|
||||||
std::shared_ptr<BlockInfo> aNewRegistration
|
const std::shared_ptr<BlockInfo> & aNewRegistration
|
||||||
) :
|
) :
|
||||||
Super(message(aPreviousRegistration, aNewRegistration)),
|
Super(message(aPreviousRegistration, aNewRegistration)),
|
||||||
m_PreviousRegistration(aPreviousRegistration),
|
m_PreviousRegistration(aPreviousRegistration),
|
||||||
@ -205,8 +207,8 @@ BlockTypeRegistry::AlreadyRegisteredException::AlreadyRegisteredException(
|
|||||||
|
|
||||||
|
|
||||||
AString BlockTypeRegistry::AlreadyRegisteredException::message(
|
AString BlockTypeRegistry::AlreadyRegisteredException::message(
|
||||||
std::shared_ptr<BlockInfo> aPreviousRegistration,
|
const std::shared_ptr<BlockInfo> & aPreviousRegistration,
|
||||||
std::shared_ptr<BlockInfo> aNewRegistration
|
const std::shared_ptr<BlockInfo> & aNewRegistration
|
||||||
)
|
)
|
||||||
{
|
{
|
||||||
return Printf("Attempting to register BlockTypeName %s from plugin %s, while it is already registered in plugin %s",
|
return Printf("Attempting to register BlockTypeName %s from plugin %s, while it is already registered in plugin %s",
|
||||||
|
@ -164,8 +164,8 @@ public:
|
|||||||
/** Creates a new instance of the exception that provides info on both the original registration and the newly attempted
|
/** Creates a new instance of the exception that provides info on both the original registration and the newly attempted
|
||||||
registration that caused the failure. */
|
registration that caused the failure. */
|
||||||
AlreadyRegisteredException(
|
AlreadyRegisteredException(
|
||||||
std::shared_ptr<BlockInfo> aPreviousRegistration,
|
const std::shared_ptr<BlockInfo> & aPreviousRegistration,
|
||||||
std::shared_ptr<BlockInfo> aNewRegistration
|
const std::shared_ptr<BlockInfo> & aNewRegistration
|
||||||
);
|
);
|
||||||
|
|
||||||
// Simple getters:
|
// Simple getters:
|
||||||
@ -182,8 +182,8 @@ private:
|
|||||||
/** Returns the general exception message formatted by the two registrations.
|
/** Returns the general exception message formatted by the two registrations.
|
||||||
The output is used when logging. */
|
The output is used when logging. */
|
||||||
static AString message(
|
static AString message(
|
||||||
std::shared_ptr<BlockInfo> aPreviousRegistration,
|
const std::shared_ptr<BlockInfo> & aPreviousRegistration,
|
||||||
std::shared_ptr<BlockInfo> aNewRegistration
|
const std::shared_ptr<BlockInfo> & aNewRegistration
|
||||||
);
|
);
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -128,11 +128,7 @@ bool cBlockBedHandler::OnUse(
|
|||||||
// Fast-forward the time if all players in the world are in their beds:
|
// Fast-forward the time if all players in the world are in their beds:
|
||||||
auto TimeFastForwardTester = [](cPlayer & a_OtherPlayer)
|
auto TimeFastForwardTester = [](cPlayer & a_OtherPlayer)
|
||||||
{
|
{
|
||||||
if (!a_OtherPlayer.IsInBed())
|
return !a_OtherPlayer.IsInBed();
|
||||||
{
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
return false;
|
|
||||||
};
|
};
|
||||||
if (a_WorldInterface.ForEachPlayer(TimeFastForwardTester))
|
if (a_WorldInterface.ForEachPlayer(TimeFastForwardTester))
|
||||||
{
|
{
|
||||||
|
@ -167,8 +167,6 @@ public:
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/** Evaluates if coordinates are a portal going XP / XM; returns true if so, and writes boundaries to variable
|
/** Evaluates if coordinates are a portal going XP / XM; returns true if so, and writes boundaries to variable
|
||||||
|
@ -285,11 +285,7 @@ bool cBoundingBox::Intersect(const cBoundingBox & a_Other, cBoundingBox & a_Inte
|
|||||||
}
|
}
|
||||||
a_Intersection.m_Min.z = std::max(m_Min.z, a_Other.m_Min.z);
|
a_Intersection.m_Min.z = std::max(m_Min.z, a_Other.m_Min.z);
|
||||||
a_Intersection.m_Max.z = std::min(m_Max.z, a_Other.m_Max.z);
|
a_Intersection.m_Max.z = std::min(m_Max.z, a_Other.m_Max.z);
|
||||||
if (a_Intersection.m_Min.z >= a_Intersection.m_Max.z)
|
return (a_Intersection.m_Min.z < a_Intersection.m_Max.z);
|
||||||
{
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
return true;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -75,7 +75,7 @@ void cBrewingRecipes::AddRecipeFromLine(AString a_Line, unsigned int a_LineNum)
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
const AStringVector & IngredientAndOutput = StringSplit(InputAndIngredient[1].c_str(), "=");
|
const AStringVector & IngredientAndOutput = StringSplit(InputAndIngredient[1], "=");
|
||||||
if (IngredientAndOutput.size() != 2)
|
if (IngredientAndOutput.size() != 2)
|
||||||
{
|
{
|
||||||
LOGWARNING("brewing.txt: line %d: A line with '=' was expected", a_LineNum);
|
LOGWARNING("brewing.txt: line %d: A line with '=' was expected", a_LineNum);
|
||||||
|
@ -1749,8 +1749,6 @@ void cChunk::RemoveClient(cClientHandle * a_Client)
|
|||||||
a_Client->SendDestroyEntity(*Entity);
|
a_Client->SendDestroyEntity(*Entity);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -213,7 +213,10 @@ void cClientHandle::GenerateOfflineUUID(void)
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
AString cClientHandle::FormatChatPrefix(bool ShouldAppendChatPrefixes, AString a_ChatPrefixS, AString m_Color1, AString m_Color2)
|
AString cClientHandle::FormatChatPrefix(
|
||||||
|
bool ShouldAppendChatPrefixes, const AString & a_ChatPrefixS,
|
||||||
|
const AString & m_Color1, const AString & m_Color2
|
||||||
|
)
|
||||||
{
|
{
|
||||||
if (ShouldAppendChatPrefixes)
|
if (ShouldAppendChatPrefixes)
|
||||||
{
|
{
|
||||||
@ -2075,12 +2078,12 @@ bool cClientHandle::CheckBlockInteractionsRate(void)
|
|||||||
ASSERT(m_Player != nullptr);
|
ASSERT(m_Player != nullptr);
|
||||||
ASSERT(m_Player->GetWorld() != nullptr);
|
ASSERT(m_Player->GetWorld() != nullptr);
|
||||||
|
|
||||||
if ((cRoot::Get()->GetServer()->ShouldLimitPlayerBlockChanges()) && (m_NumBlockChangeInteractionsThisTick > MAX_BLOCK_CHANGE_INTERACTIONS))
|
if (!cRoot::Get()->GetServer()->ShouldLimitPlayerBlockChanges())
|
||||||
{
|
{
|
||||||
return false;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
return true;
|
return (m_NumBlockChangeInteractionsThisTick <= MAX_BLOCK_CHANGE_INTERACTIONS);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -3310,7 +3313,7 @@ void cClientHandle::SocketClosed(void)
|
|||||||
void cClientHandle::SetSelf(cClientHandlePtr a_Self)
|
void cClientHandle::SetSelf(cClientHandlePtr a_Self)
|
||||||
{
|
{
|
||||||
ASSERT(m_Self == nullptr);
|
ASSERT(m_Self == nullptr);
|
||||||
m_Self = a_Self;
|
m_Self = std::move(a_Self);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -107,7 +107,10 @@ public: // tolua_export
|
|||||||
/** Formats the type of message with the proper color and prefix for sending to the client. */
|
/** Formats the type of message with the proper color and prefix for sending to the client. */
|
||||||
static AString FormatMessageType(bool ShouldAppendChatPrefixes, eMessageType a_ChatPrefix, const AString & a_AdditionalData);
|
static AString FormatMessageType(bool ShouldAppendChatPrefixes, eMessageType a_ChatPrefix, const AString & a_AdditionalData);
|
||||||
|
|
||||||
static AString FormatChatPrefix(bool ShouldAppendChatPrefixes, AString a_ChatPrefixS, AString m_Color1, AString m_Color2);
|
static AString FormatChatPrefix(
|
||||||
|
bool ShouldAppendChatPrefixes, const AString & a_ChatPrefixS,
|
||||||
|
const AString & m_Color1, const AString & m_Color2
|
||||||
|
);
|
||||||
|
|
||||||
void Kick(const AString & a_Reason); // tolua_export
|
void Kick(const AString & a_Reason); // tolua_export
|
||||||
|
|
||||||
|
@ -400,7 +400,7 @@ void cCraftingRecipes::AddRecipeLine(int a_LineNum, const AString & a_RecipeLine
|
|||||||
}
|
}
|
||||||
if (ResultSplit.size() > 1)
|
if (ResultSplit.size() > 1)
|
||||||
{
|
{
|
||||||
if (!StringToInteger<char>(ResultSplit[1].c_str(), Recipe->m_Result.m_ItemCount))
|
if (!StringToInteger<char>(ResultSplit[1], Recipe->m_Result.m_ItemCount))
|
||||||
{
|
{
|
||||||
LOGWARNING("crafting.txt: line %d: Cannot parse result count, ignoring the recipe.", a_LineNum);
|
LOGWARNING("crafting.txt: line %d: Cannot parse result count, ignoring the recipe.", a_LineNum);
|
||||||
LOGINFO("Offending line: \"%s\"", a_RecipeLine.c_str());
|
LOGINFO("Offending line: \"%s\"", a_RecipeLine.c_str());
|
||||||
@ -452,7 +452,7 @@ bool cCraftingRecipes::ParseItem(const AString & a_String, cItem & a_Item)
|
|||||||
if (Split.size() > 1)
|
if (Split.size() > 1)
|
||||||
{
|
{
|
||||||
AString Damage = TrimString(Split[1]);
|
AString Damage = TrimString(Split[1]);
|
||||||
if (!StringToInteger<short>(Damage.c_str(), a_Item.m_ItemDamage))
|
if (!StringToInteger<short>(Damage, a_Item.m_ItemDamage))
|
||||||
{
|
{
|
||||||
// Parsing the number failed
|
// Parsing the number failed
|
||||||
return false;
|
return false;
|
||||||
@ -893,7 +893,7 @@ void cCraftingRecipes::HandleDyedLeather(const cItem * a_CraftingGrid, cCrafting
|
|||||||
for (int y = 0; y < a_GridHeight; ++y)
|
for (int y = 0; y < a_GridHeight; ++y)
|
||||||
{
|
{
|
||||||
int GridIdx = x + a_GridStride * y;
|
int GridIdx = x + a_GridStride * y;
|
||||||
if ((a_CraftingGrid[GridIdx].m_ItemType == result_type) && (found == false))
|
if ((a_CraftingGrid[GridIdx].m_ItemType == result_type) && !found)
|
||||||
{
|
{
|
||||||
found = true;
|
found = true;
|
||||||
temp = a_CraftingGrid[GridIdx].CopyOne();
|
temp = a_CraftingGrid[GridIdx].CopyOne();
|
||||||
|
@ -160,17 +160,10 @@ AString BlockFaceToString(eBlockFace a_BlockFace)
|
|||||||
|
|
||||||
bool IsValidBlock(int a_BlockType)
|
bool IsValidBlock(int a_BlockType)
|
||||||
{
|
{
|
||||||
if (
|
return (
|
||||||
(
|
((a_BlockType > -1) && (a_BlockType <= E_BLOCK_MAX_TYPE_ID)) ||
|
||||||
(a_BlockType > -1) &&
|
|
||||||
(a_BlockType <= E_BLOCK_MAX_TYPE_ID)
|
|
||||||
) ||
|
|
||||||
(a_BlockType == 255) // the blocks 253-254 don't exist yet -> https://minecraft.gamepedia.com/Data_values#Block_IDs
|
(a_BlockType == 255) // the blocks 253-254 don't exist yet -> https://minecraft.gamepedia.com/Data_values#Block_IDs
|
||||||
)
|
);
|
||||||
{
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
return false;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -304,7 +304,7 @@ bool cEnchantments::CanAddEnchantment(int a_EnchantmentID) const
|
|||||||
// {enchInfinity, enchMending}
|
// {enchInfinity, enchMending}
|
||||||
};
|
};
|
||||||
|
|
||||||
for (auto excl: IncompatibleEnchantments)
|
for (const auto & excl: IncompatibleEnchantments)
|
||||||
{
|
{
|
||||||
if (excl.count(a_EnchantmentID) != 0)
|
if (excl.count(a_EnchantmentID) != 0)
|
||||||
{
|
{
|
||||||
@ -1112,7 +1112,9 @@ void cEnchantments::RemoveEnchantmentWeightFromVector(cWeightedEnchantments & a_
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
void cEnchantments::CheckEnchantmentConflictsFromVector(cWeightedEnchantments & a_Enchantments, cEnchantments a_FirstEnchantment)
|
void cEnchantments::CheckEnchantmentConflictsFromVector(
|
||||||
|
cWeightedEnchantments & a_Enchantments, const cEnchantments & a_FirstEnchantment
|
||||||
|
)
|
||||||
{
|
{
|
||||||
if (a_FirstEnchantment.GetLevel(cEnchantments::enchProtection) > 0)
|
if (a_FirstEnchantment.GetLevel(cEnchantments::enchProtection) > 0)
|
||||||
{
|
{
|
||||||
|
@ -137,7 +137,7 @@ public:
|
|||||||
static void RemoveEnchantmentWeightFromVector(cWeightedEnchantments & a_Enchantments, const cEnchantments & a_Enchantment);
|
static void RemoveEnchantmentWeightFromVector(cWeightedEnchantments & a_Enchantments, const cEnchantments & a_Enchantment);
|
||||||
|
|
||||||
/** Check enchantment conflicts from enchantments from the vector */
|
/** Check enchantment conflicts from enchantments from the vector */
|
||||||
static void CheckEnchantmentConflictsFromVector(cWeightedEnchantments & a_Enchantments, cEnchantments a_FirstEnchantment);
|
static void CheckEnchantmentConflictsFromVector(cWeightedEnchantments & a_Enchantments, const cEnchantments & a_FirstEnchantment);
|
||||||
|
|
||||||
/** Gets random enchantment from Vector and returns it */
|
/** Gets random enchantment from Vector and returns it */
|
||||||
static cEnchantments GetRandomEnchantmentFromVector(cWeightedEnchantments & a_Enchantments);
|
static cEnchantments GetRandomEnchantmentFromVector(cWeightedEnchantments & a_Enchantments);
|
||||||
|
@ -617,7 +617,6 @@ int cEntity::GetRawDamageAgainst(const cEntity & a_Receiver)
|
|||||||
void cEntity::ApplyArmorDamage(int DamageBlocked)
|
void cEntity::ApplyArmorDamage(int DamageBlocked)
|
||||||
{
|
{
|
||||||
// cEntities don't necessarily have armor to damage.
|
// cEntities don't necessarily have armor to damage.
|
||||||
return;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -2041,11 +2040,10 @@ bool cEntity::IsA(const char * a_ClassName) const
|
|||||||
|
|
||||||
bool cEntity::IsAttachedTo(const cEntity * a_Entity) const
|
bool cEntity::IsAttachedTo(const cEntity * a_Entity) const
|
||||||
{
|
{
|
||||||
if ((m_AttachedTo != nullptr) && (a_Entity->GetUniqueID() == m_AttachedTo->GetUniqueID()))
|
return (
|
||||||
{
|
(m_AttachedTo != nullptr) &&
|
||||||
return true;
|
(a_Entity->GetUniqueID() == m_AttachedTo->GetUniqueID())
|
||||||
}
|
);
|
||||||
return false;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -85,7 +85,6 @@ void cLeashKnot::KilledBy(TakeDamageInfo & a_TDI)
|
|||||||
Super::KilledBy(a_TDI);
|
Super::KilledBy(a_TDI);
|
||||||
m_World->BroadcastSoundEffect("entity.leashknot.break", GetPosition(), 1, 1);
|
m_World->BroadcastSoundEffect("entity.leashknot.break", GetPosition(), 1, 1);
|
||||||
Destroy();
|
Destroy();
|
||||||
return;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -86,7 +86,7 @@ const int cPlayer::EATING_TICKS = 30;
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
cPlayer::cPlayer(cClientHandlePtr a_Client, const AString & a_PlayerName) :
|
cPlayer::cPlayer(const cClientHandlePtr & a_Client, const AString & a_PlayerName) :
|
||||||
Super(etPlayer, 0.6, 1.8),
|
Super(etPlayer, 0.6, 1.8),
|
||||||
m_bVisible(true),
|
m_bVisible(true),
|
||||||
m_FoodLevel(MAX_FOOD_LEVEL),
|
m_FoodLevel(MAX_FOOD_LEVEL),
|
||||||
@ -1869,14 +1869,8 @@ bool cPlayer::PermissionMatches(const AStringVector & a_Permission, const AStrin
|
|||||||
}
|
}
|
||||||
|
|
||||||
// So far all the sub-items have matched
|
// So far all the sub-items have matched
|
||||||
// If the sub-item count is the same, then the permission matches:
|
// If the sub-item count is the same, then the permission matches
|
||||||
if (lenP == lenT)
|
return (lenP == lenT);
|
||||||
{
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
// There are more sub-items in either the permission or the template, not a match:
|
|
||||||
return false;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -48,7 +48,7 @@ public:
|
|||||||
CLASS_PROTODEF(cPlayer)
|
CLASS_PROTODEF(cPlayer)
|
||||||
|
|
||||||
|
|
||||||
cPlayer(cClientHandlePtr a_Client, const AString & a_PlayerName);
|
cPlayer(const cClientHandlePtr & a_Client, const AString & a_PlayerName);
|
||||||
|
|
||||||
virtual bool Initialize(OwnedEntity a_Self, cWorld & a_World) override;
|
virtual bool Initialize(OwnedEntity a_Self, cWorld & a_World) override;
|
||||||
|
|
||||||
|
@ -233,7 +233,7 @@ bool cFurnaceRecipe::ParseItem(const AString & a_String, cItem & a_Item)
|
|||||||
|
|
||||||
if (SplitAmount.size() > 1)
|
if (SplitAmount.size() > 1)
|
||||||
{
|
{
|
||||||
if (!StringToInteger<char>(SplitAmount[1].c_str(), a_Item.m_ItemCount))
|
if (!StringToInteger<char>(SplitAmount[1], a_Item.m_ItemCount))
|
||||||
{
|
{
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
@ -241,7 +241,7 @@ bool cFurnaceRecipe::ParseItem(const AString & a_String, cItem & a_Item)
|
|||||||
|
|
||||||
if (SplitMeta.size() > 1)
|
if (SplitMeta.size() > 1)
|
||||||
{
|
{
|
||||||
if (!StringToInteger<short>(SplitMeta[1].c_str(), a_Item.m_ItemDamage))
|
if (!StringToInteger<short>(SplitMeta[1], a_Item.m_ItemDamage))
|
||||||
{
|
{
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
@ -58,7 +58,7 @@ void cBioGenConstant::InitializeBiomeGen(cIniFile & a_IniFile)
|
|||||||
// cBioGenCache:
|
// cBioGenCache:
|
||||||
|
|
||||||
cBioGenCache::cBioGenCache(cBiomeGenPtr a_BioGenToCache, size_t a_CacheSize) :
|
cBioGenCache::cBioGenCache(cBiomeGenPtr a_BioGenToCache, size_t a_CacheSize) :
|
||||||
m_BioGenToCache(a_BioGenToCache),
|
m_BioGenToCache(std::move(a_BioGenToCache)),
|
||||||
m_CacheSize(a_CacheSize),
|
m_CacheSize(a_CacheSize),
|
||||||
m_NumHits(0),
|
m_NumHits(0),
|
||||||
m_NumMisses(0),
|
m_NumMisses(0),
|
||||||
@ -139,7 +139,7 @@ void cBioGenCache::InitializeBiomeGen(cIniFile & a_IniFile)
|
|||||||
////////////////////////////////////////////////////////////////////////////////
|
////////////////////////////////////////////////////////////////////////////////
|
||||||
// cBioGenMulticache:
|
// cBioGenMulticache:
|
||||||
|
|
||||||
cBioGenMulticache::cBioGenMulticache(cBiomeGenPtr a_BioGenToCache, size_t a_SubCacheSize, size_t a_NumSubCaches) :
|
cBioGenMulticache::cBioGenMulticache(const cBiomeGenPtr & a_BioGenToCache, size_t a_SubCacheSize, size_t a_NumSubCaches) :
|
||||||
m_NumSubCaches(a_NumSubCaches)
|
m_NumSubCaches(a_NumSubCaches)
|
||||||
{
|
{
|
||||||
m_Caches.reserve(a_NumSubCaches);
|
m_Caches.reserve(a_NumSubCaches);
|
||||||
@ -167,7 +167,7 @@ void cBioGenMulticache::GenBiomes(cChunkCoords a_ChunkCoords, cChunkDef::BiomeMa
|
|||||||
|
|
||||||
void cBioGenMulticache::InitializeBiomeGen(cIniFile & a_IniFile)
|
void cBioGenMulticache::InitializeBiomeGen(cIniFile & a_IniFile)
|
||||||
{
|
{
|
||||||
for (auto itr : m_Caches)
|
for (const auto & itr : m_Caches)
|
||||||
{
|
{
|
||||||
itr->InitializeBiomeGen(a_IniFile);
|
itr->InitializeBiomeGen(a_IniFile);
|
||||||
}
|
}
|
||||||
|
@ -97,7 +97,7 @@ public:
|
|||||||
This allows us to use shorter cache depths with faster lookups for more covered area. (#381)
|
This allows us to use shorter cache depths with faster lookups for more covered area. (#381)
|
||||||
a_SubCacheSize defines the size of each sub-cache
|
a_SubCacheSize defines the size of each sub-cache
|
||||||
a_NumSubCaches defines how many sub-caches are used for the multicache. */
|
a_NumSubCaches defines how many sub-caches are used for the multicache. */
|
||||||
cBioGenMulticache(cBiomeGenPtr a_BioGenToCache, size_t a_SubCacheSize, size_t a_NumSubCaches);
|
cBioGenMulticache(const cBiomeGenPtr & a_BioGenToCache, size_t a_SubCacheSize, size_t a_NumSubCaches);
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
typedef std::vector<cBiomeGenPtr> cBiomeGenPtrs;
|
typedef std::vector<cBiomeGenPtr> cBiomeGenPtrs;
|
||||||
|
@ -330,7 +330,7 @@ void cCompoGenNether::InitializeCompoGen(cIniFile & a_IniFile)
|
|||||||
// cCompoGenCache:
|
// cCompoGenCache:
|
||||||
|
|
||||||
cCompoGenCache::cCompoGenCache(cTerrainCompositionGenPtr a_Underlying, int a_CacheSize) :
|
cCompoGenCache::cCompoGenCache(cTerrainCompositionGenPtr a_Underlying, int a_CacheSize) :
|
||||||
m_Underlying(a_Underlying),
|
m_Underlying(std::move(a_Underlying)),
|
||||||
m_CacheSize(a_CacheSize),
|
m_CacheSize(a_CacheSize),
|
||||||
m_CacheOrder(new int[ToUnsigned(a_CacheSize)]),
|
m_CacheOrder(new int[ToUnsigned(a_CacheSize)]),
|
||||||
m_CacheData(new sCacheData[ToUnsigned(a_CacheSize)]),
|
m_CacheData(new sCacheData[ToUnsigned(a_CacheSize)]),
|
||||||
|
@ -39,8 +39,8 @@
|
|||||||
|
|
||||||
cTerrainCompositionGenPtr cTerrainCompositionGen::CreateCompositionGen(
|
cTerrainCompositionGenPtr cTerrainCompositionGen::CreateCompositionGen(
|
||||||
cIniFile & a_IniFile,
|
cIniFile & a_IniFile,
|
||||||
cBiomeGenPtr a_BiomeGen,
|
const cBiomeGenPtr & a_BiomeGen,
|
||||||
cTerrainShapeGenPtr a_ShapeGen,
|
const cTerrainShapeGenPtr & a_ShapeGen,
|
||||||
int a_Seed
|
int a_Seed
|
||||||
)
|
)
|
||||||
{
|
{
|
||||||
|
@ -98,7 +98,7 @@ public:
|
|||||||
*/
|
*/
|
||||||
static cTerrainShapeGenPtr CreateShapeGen(
|
static cTerrainShapeGenPtr CreateShapeGen(
|
||||||
cIniFile & a_IniFile,
|
cIniFile & a_IniFile,
|
||||||
cBiomeGenPtr a_BiomeGen,
|
const cBiomeGenPtr & a_BiomeGen,
|
||||||
int a_Seed,
|
int a_Seed,
|
||||||
bool & a_CacheOffByDefault
|
bool & a_CacheOffByDefault
|
||||||
);
|
);
|
||||||
@ -137,7 +137,7 @@ public:
|
|||||||
/** Creates a cTerrainHeightGen descendant based on the INI file settings. */
|
/** Creates a cTerrainHeightGen descendant based on the INI file settings. */
|
||||||
static cTerrainHeightGenPtr CreateHeightGen(
|
static cTerrainHeightGenPtr CreateHeightGen(
|
||||||
cIniFile & a_IniFile,
|
cIniFile & a_IniFile,
|
||||||
cBiomeGenPtr a_BiomeGen,
|
const cBiomeGenPtr & a_BiomeGen,
|
||||||
int a_Seed,
|
int a_Seed,
|
||||||
bool & a_CacheOffByDefault
|
bool & a_CacheOffByDefault
|
||||||
);
|
);
|
||||||
@ -169,8 +169,8 @@ public:
|
|||||||
a_ShapeGen is the underlying shape generator, some composition generators may depend on it providing additional shape around the chunk. */
|
a_ShapeGen is the underlying shape generator, some composition generators may depend on it providing additional shape around the chunk. */
|
||||||
static cTerrainCompositionGenPtr CreateCompositionGen(
|
static cTerrainCompositionGenPtr CreateCompositionGen(
|
||||||
cIniFile & a_IniFile,
|
cIniFile & a_IniFile,
|
||||||
cBiomeGenPtr a_BiomeGen,
|
const cBiomeGenPtr & a_BiomeGen,
|
||||||
cTerrainShapeGenPtr a_ShapeGen,
|
const cTerrainShapeGenPtr & a_ShapeGen,
|
||||||
int a_Seed
|
int a_Seed
|
||||||
);
|
);
|
||||||
} ;
|
} ;
|
||||||
|
@ -21,9 +21,9 @@ class cCompositedHeiGen:
|
|||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
cCompositedHeiGen(cBiomeGenPtr a_BiomeGen, cTerrainShapeGenPtr a_ShapeGen, cTerrainCompositionGenPtr a_CompositionGen):
|
cCompositedHeiGen(cBiomeGenPtr a_BiomeGen, cTerrainShapeGenPtr a_ShapeGen, cTerrainCompositionGenPtr a_CompositionGen):
|
||||||
m_BiomeGen(a_BiomeGen),
|
m_BiomeGen(std::move(a_BiomeGen)),
|
||||||
m_ShapeGen(a_ShapeGen),
|
m_ShapeGen(std::move(a_ShapeGen)),
|
||||||
m_CompositionGen(a_CompositionGen)
|
m_CompositionGen(std::move(a_CompositionGen))
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -118,7 +118,7 @@ const cDistortedHeightmap::sGenParam cDistortedHeightmap::m_GenParam[256] =
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
cDistortedHeightmap::cDistortedHeightmap(int a_Seed, cBiomeGenPtr a_BiomeGen) :
|
cDistortedHeightmap::cDistortedHeightmap(int a_Seed, const cBiomeGenPtr & a_BiomeGen) :
|
||||||
m_NoiseDistortX(a_Seed + 1000),
|
m_NoiseDistortX(a_Seed + 1000),
|
||||||
m_NoiseDistortZ(a_Seed + 2000),
|
m_NoiseDistortZ(a_Seed + 2000),
|
||||||
m_CurChunkCoords(0x7fffffff, 0x7fffffff), // Set impossible coords for the chunk so that it's always considered stale
|
m_CurChunkCoords(0x7fffffff, 0x7fffffff), // Set impossible coords for the chunk so that it's always considered stale
|
||||||
|
@ -26,7 +26,7 @@ class cDistortedHeightmap :
|
|||||||
public cTerrainShapeGen
|
public cTerrainShapeGen
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
cDistortedHeightmap(int a_Seed, cBiomeGenPtr a_BiomeGen);
|
cDistortedHeightmap(int a_Seed, const cBiomeGenPtr & a_BiomeGen);
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
typedef cChunkDef::BiomeMap BiomeNeighbors[3][3];
|
typedef cChunkDef::BiomeMap BiomeNeighbors[3][3];
|
||||||
|
@ -289,7 +289,7 @@ protected:
|
|||||||
|
|
||||||
cDungeonRoomsFinisher::cDungeonRoomsFinisher(cTerrainShapeGenPtr a_ShapeGen, int a_Seed, int a_GridSize, int a_MaxSize, int a_MinSize, const AString & a_HeightDistrib) :
|
cDungeonRoomsFinisher::cDungeonRoomsFinisher(cTerrainShapeGenPtr a_ShapeGen, int a_Seed, int a_GridSize, int a_MaxSize, int a_MinSize, const AString & a_HeightDistrib) :
|
||||||
Super(a_Seed + 100, a_GridSize, a_GridSize, a_GridSize, a_GridSize, a_MaxSize, a_MaxSize, 1024),
|
Super(a_Seed + 100, a_GridSize, a_GridSize, a_GridSize, a_GridSize, a_MaxSize, a_MaxSize, 1024),
|
||||||
m_ShapeGen(a_ShapeGen),
|
m_ShapeGen(std::move(a_ShapeGen)),
|
||||||
m_MaxHalfSize((a_MaxSize + 1) / 2),
|
m_MaxHalfSize((a_MaxSize + 1) / 2),
|
||||||
m_MinHalfSize((a_MinSize + 1) / 2),
|
m_MinHalfSize((a_MinSize + 1) / 2),
|
||||||
m_HeightProbability(cChunkDef::Height)
|
m_HeightProbability(cChunkDef::Height)
|
||||||
|
@ -275,7 +275,7 @@ void cFinishGenClumpTopBlock::TryPlaceFoliageClump(cChunkDesc & a_ChunkDesc, int
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
void cFinishGenClumpTopBlock::ParseConfigurationString(AString a_RawClumpInfo, std::vector<BiomeInfo> & a_Output)
|
void cFinishGenClumpTopBlock::ParseConfigurationString(const AString & a_RawClumpInfo, std::vector<BiomeInfo> & a_Output)
|
||||||
{
|
{
|
||||||
// Initialize the vector for all biomes.
|
// Initialize the vector for all biomes.
|
||||||
for (int i = static_cast<int>(a_Output.size()); i < static_cast<int>(biMaxVariantBiome); i++)
|
for (int i = static_cast<int>(a_Output.size()); i < static_cast<int>(biMaxVariantBiome); i++)
|
||||||
|
@ -104,7 +104,7 @@ public:
|
|||||||
BiomeInfo(int a_MinNumClumpsPerChunk, int a_MaxNumClumpsPerChunk, std::vector<FoliageInfo> a_Blocks) :
|
BiomeInfo(int a_MinNumClumpsPerChunk, int a_MaxNumClumpsPerChunk, std::vector<FoliageInfo> a_Blocks) :
|
||||||
m_MinNumClumpsPerChunk(a_MinNumClumpsPerChunk),
|
m_MinNumClumpsPerChunk(a_MinNumClumpsPerChunk),
|
||||||
m_MaxNumClumpsPerChunk(a_MaxNumClumpsPerChunk),
|
m_MaxNumClumpsPerChunk(a_MaxNumClumpsPerChunk),
|
||||||
m_Blocks(a_Blocks)
|
m_Blocks(std::move(a_Blocks))
|
||||||
{}
|
{}
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -118,7 +118,7 @@ public:
|
|||||||
|
|
||||||
/** Parses a string and puts a vector with a length of biMaxVariantBiome in a_Output.
|
/** Parses a string and puts a vector with a length of biMaxVariantBiome in a_Output.
|
||||||
The format of the string is "<Biomes separated with a comma>;<Blocks separated with a comma>". This can also be repeated with a | */
|
The format of the string is "<Biomes separated with a comma>;<Blocks separated with a comma>". This can also be repeated with a | */
|
||||||
static void ParseConfigurationString(AString a_String, std::vector<BiomeInfo> & a_Output);
|
static void ParseConfigurationString(const AString & a_String, std::vector<BiomeInfo> & a_Output);
|
||||||
|
|
||||||
/** Parses an inifile in search for all clumps */
|
/** Parses an inifile in search for all clumps */
|
||||||
static std::vector<BiomeInfo> ParseIniFile(cIniFile & a_IniFile, AString a_ClumpPrefix);
|
static std::vector<BiomeInfo> ParseIniFile(cIniFile & a_IniFile, AString a_ClumpPrefix);
|
||||||
|
@ -107,7 +107,7 @@ void cHeiGenFlat::InitializeHeightGen(cIniFile & a_IniFile)
|
|||||||
// cHeiGenCache:
|
// cHeiGenCache:
|
||||||
|
|
||||||
cHeiGenCache::cHeiGenCache(cTerrainHeightGenPtr a_HeiGenToCache, size_t a_CacheSize) :
|
cHeiGenCache::cHeiGenCache(cTerrainHeightGenPtr a_HeiGenToCache, size_t a_CacheSize) :
|
||||||
m_HeiGenToCache(a_HeiGenToCache),
|
m_HeiGenToCache(std::move(a_HeiGenToCache)),
|
||||||
m_CacheSize(a_CacheSize),
|
m_CacheSize(a_CacheSize),
|
||||||
m_NumHits(0),
|
m_NumHits(0),
|
||||||
m_NumMisses(0),
|
m_NumMisses(0),
|
||||||
@ -219,7 +219,7 @@ bool cHeiGenCache::GetHeightAt(int a_ChunkX, int a_ChunkZ, int a_RelX, int a_Rel
|
|||||||
////////////////////////////////////////////////////////////////////////////////
|
////////////////////////////////////////////////////////////////////////////////
|
||||||
// cHeiGenMultiCache:
|
// cHeiGenMultiCache:
|
||||||
|
|
||||||
cHeiGenMultiCache::cHeiGenMultiCache(cTerrainHeightGenPtr a_HeiGenToCache, size_t a_SubCacheSize, size_t a_NumSubCaches):
|
cHeiGenMultiCache::cHeiGenMultiCache(const cTerrainHeightGenPtr & a_HeiGenToCache, size_t a_SubCacheSize, size_t a_NumSubCaches):
|
||||||
m_NumSubCaches(a_NumSubCaches)
|
m_NumSubCaches(a_NumSubCaches)
|
||||||
{
|
{
|
||||||
// Create the individual sub-caches:
|
// Create the individual sub-caches:
|
||||||
@ -638,7 +638,7 @@ public:
|
|||||||
|
|
||||||
cHeiGenMinMax(int a_Seed, cBiomeGenPtr a_BiomeGen):
|
cHeiGenMinMax(int a_Seed, cBiomeGenPtr a_BiomeGen):
|
||||||
m_Noise(a_Seed),
|
m_Noise(a_Seed),
|
||||||
m_BiomeGen(a_BiomeGen),
|
m_BiomeGen(std::move(a_BiomeGen)),
|
||||||
m_TotalWeight(0)
|
m_TotalWeight(0)
|
||||||
{
|
{
|
||||||
// Initialize the weights:
|
// Initialize the weights:
|
||||||
@ -831,7 +831,7 @@ protected:
|
|||||||
////////////////////////////////////////////////////////////////////////////////
|
////////////////////////////////////////////////////////////////////////////////
|
||||||
// cTerrainHeightGen:
|
// cTerrainHeightGen:
|
||||||
|
|
||||||
cTerrainHeightGenPtr cTerrainHeightGen::CreateHeightGen(cIniFile & a_IniFile, cBiomeGenPtr a_BiomeGen, int a_Seed, bool & a_CacheOffByDefault)
|
cTerrainHeightGenPtr cTerrainHeightGen::CreateHeightGen(cIniFile & a_IniFile, const cBiomeGenPtr & a_BiomeGen, int a_Seed, bool & a_CacheOffByDefault)
|
||||||
{
|
{
|
||||||
AString HeightGenName = a_IniFile.GetValueSet("Generator", "HeightGen", "");
|
AString HeightGenName = a_IniFile.GetValueSet("Generator", "HeightGen", "");
|
||||||
if (HeightGenName.empty())
|
if (HeightGenName.empty())
|
||||||
|
@ -73,7 +73,7 @@ class cHeiGenMultiCache:
|
|||||||
public cTerrainHeightGen
|
public cTerrainHeightGen
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
cHeiGenMultiCache(cTerrainHeightGenPtr a_HeightGenToCache, size_t a_SubCacheSize, size_t a_NumSubCaches);
|
cHeiGenMultiCache(const cTerrainHeightGenPtr & a_HeightGenToCache, size_t a_SubCacheSize, size_t a_NumSubCaches);
|
||||||
|
|
||||||
// cTerrainHeightGen overrides:
|
// cTerrainHeightGen overrides:
|
||||||
virtual void GenHeightMap(cChunkCoords a_ChunkCoords, cChunkDef::HeightMap & a_HeightMap) override;
|
virtual void GenHeightMap(cChunkCoords a_ChunkCoords, cChunkDef::HeightMap & a_HeightMap) override;
|
||||||
@ -176,7 +176,7 @@ public:
|
|||||||
|
|
||||||
cHeiGenBiomal(int a_Seed, cBiomeGenPtr a_BiomeGen):
|
cHeiGenBiomal(int a_Seed, cBiomeGenPtr a_BiomeGen):
|
||||||
m_Noise(a_Seed),
|
m_Noise(a_Seed),
|
||||||
m_BiomeGen(a_BiomeGen)
|
m_BiomeGen(std::move(a_BiomeGen))
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -511,7 +511,7 @@ cBiomalNoise3DComposable::cBiomalNoise3DComposable(int a_Seed, cBiomeGenPtr a_Bi
|
|||||||
m_DensityNoiseA(a_Seed + 1),
|
m_DensityNoiseA(a_Seed + 1),
|
||||||
m_DensityNoiseB(a_Seed + 2),
|
m_DensityNoiseB(a_Seed + 2),
|
||||||
m_BaseNoise(a_Seed + 3),
|
m_BaseNoise(a_Seed + 3),
|
||||||
m_BiomeGen(a_BiomeGen),
|
m_BiomeGen(std::move(a_BiomeGen)),
|
||||||
m_LastChunkCoords(0x7fffffff, 0x7fffffff) // Set impossible coords for the chunk so that it's always considered stale
|
m_LastChunkCoords(0x7fffffff, 0x7fffffff) // Set impossible coords for the chunk so that it's always considered stale
|
||||||
{
|
{
|
||||||
// Generate the weight distribution for summing up neighboring biomes:
|
// Generate the weight distribution for summing up neighboring biomes:
|
||||||
|
@ -183,7 +183,7 @@ public:
|
|||||||
|
|
||||||
void SetVerticalStrategy(cVerticalStrategyPtr a_VerticalStrategy)
|
void SetVerticalStrategy(cVerticalStrategyPtr a_VerticalStrategy)
|
||||||
{
|
{
|
||||||
m_VerticalStrategy = a_VerticalStrategy;
|
m_VerticalStrategy = std::move(a_VerticalStrategy);
|
||||||
}
|
}
|
||||||
|
|
||||||
cVerticalStrategyPtr GetVerticalStrategy(void) const
|
cVerticalStrategyPtr GetVerticalStrategy(void) const
|
||||||
|
@ -23,8 +23,8 @@ public:
|
|||||||
|
|
||||||
cGen(int a_Seed, cBiomeGenPtr a_BiomeGen, cTerrainHeightGenPtr a_HeightGen, int a_SeaLevel, const AString & a_Name):
|
cGen(int a_Seed, cBiomeGenPtr a_BiomeGen, cTerrainHeightGenPtr a_HeightGen, int a_SeaLevel, const AString & a_Name):
|
||||||
Super(a_Seed),
|
Super(a_Seed),
|
||||||
m_BiomeGen(a_BiomeGen),
|
m_BiomeGen(std::move(a_BiomeGen)),
|
||||||
m_HeightGen(a_HeightGen),
|
m_HeightGen(std::move(a_HeightGen)),
|
||||||
m_SeaLevel(a_SeaLevel),
|
m_SeaLevel(a_SeaLevel),
|
||||||
m_Name(a_Name),
|
m_Name(a_Name),
|
||||||
m_MaxDepth(5)
|
m_MaxDepth(5)
|
||||||
@ -131,7 +131,7 @@ cPieceStructuresGen::cPieceStructuresGen(int a_Seed):
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
bool cPieceStructuresGen::Initialize(const AString & a_Prefabs, int a_SeaLevel, cBiomeGenPtr a_BiomeGen, cTerrainHeightGenPtr a_HeightGen)
|
bool cPieceStructuresGen::Initialize(const AString & a_Prefabs, int a_SeaLevel, const cBiomeGenPtr & a_BiomeGen, const cTerrainHeightGenPtr & a_HeightGen)
|
||||||
{
|
{
|
||||||
// Load each piecepool:
|
// Load each piecepool:
|
||||||
auto structures = StringSplitAndTrim(a_Prefabs, "|");
|
auto structures = StringSplitAndTrim(a_Prefabs, "|");
|
||||||
|
@ -34,7 +34,7 @@ public:
|
|||||||
a_Prefabs contains the list of prefab sets that should be activated, "|"-separated.
|
a_Prefabs contains the list of prefab sets that should be activated, "|"-separated.
|
||||||
All problems are logged to the console and the generator skips over them.
|
All problems are logged to the console and the generator skips over them.
|
||||||
Returns true if at least one prefab set is valid (the generator should be kept). */
|
Returns true if at least one prefab set is valid (the generator should be kept). */
|
||||||
bool Initialize(const AString & a_Prefabs, int a_SeaLevel, cBiomeGenPtr a_BiomeGen, cTerrainHeightGenPtr a_HeightGen);
|
bool Initialize(const AString & a_Prefabs, int a_SeaLevel, const cBiomeGenPtr & a_BiomeGen, const cTerrainHeightGenPtr & a_HeightGen);
|
||||||
|
|
||||||
// cFinishGen override:
|
// cFinishGen override:
|
||||||
virtual void GenFinish(cChunkDesc & a_ChunkDesc) override;
|
virtual void GenFinish(cChunkDesc & a_ChunkDesc) override;
|
||||||
|
@ -19,7 +19,7 @@ cPrefabStructure::cPrefabStructure(
|
|||||||
):
|
):
|
||||||
Super(a_GridX, a_GridZ, a_OriginX, a_OriginZ),
|
Super(a_GridX, a_GridZ, a_OriginX, a_OriginZ),
|
||||||
m_Pieces(std::move(a_Pieces)),
|
m_Pieces(std::move(a_Pieces)),
|
||||||
m_HeightGen(a_HeightGen)
|
m_HeightGen(std::move(a_HeightGen))
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -198,7 +198,7 @@ public:
|
|||||||
|
|
||||||
cProtIntGenZoom(int a_Seed, Underlying a_UnderlyingGen):
|
cProtIntGenZoom(int a_Seed, Underlying a_UnderlyingGen):
|
||||||
Super(a_Seed),
|
Super(a_Seed),
|
||||||
m_UnderlyingGen(a_UnderlyingGen)
|
m_UnderlyingGen(std::move(a_UnderlyingGen))
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -269,7 +269,7 @@ public:
|
|||||||
|
|
||||||
cProtIntGenSmooth(int a_Seed, Underlying a_Underlying):
|
cProtIntGenSmooth(int a_Seed, Underlying a_Underlying):
|
||||||
Super(a_Seed),
|
Super(a_Seed),
|
||||||
m_Underlying(a_Underlying)
|
m_Underlying(std::move(a_Underlying))
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -342,7 +342,7 @@ class cProtIntGenAvgValues:
|
|||||||
public:
|
public:
|
||||||
|
|
||||||
cProtIntGenAvgValues(Underlying a_Underlying):
|
cProtIntGenAvgValues(Underlying a_Underlying):
|
||||||
m_Underlying(a_Underlying)
|
m_Underlying(std::move(a_Underlying))
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -387,7 +387,7 @@ class cProtIntGenAvg4Values:
|
|||||||
public:
|
public:
|
||||||
|
|
||||||
cProtIntGenAvg4Values(Underlying a_Underlying):
|
cProtIntGenAvg4Values(Underlying a_Underlying):
|
||||||
m_Underlying(a_Underlying)
|
m_Underlying(std::move(a_Underlying))
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -438,7 +438,7 @@ class cProtIntGenWeightAvg:
|
|||||||
public:
|
public:
|
||||||
|
|
||||||
cProtIntGenWeightAvg(Underlying a_Underlying):
|
cProtIntGenWeightAvg(Underlying a_Underlying):
|
||||||
m_Underlying(a_Underlying)
|
m_Underlying(std::move(a_Underlying))
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -490,7 +490,7 @@ public:
|
|||||||
m_ChancePct(a_ChancePct),
|
m_ChancePct(a_ChancePct),
|
||||||
m_Min(a_Min),
|
m_Min(a_Min),
|
||||||
m_Range(a_Range),
|
m_Range(a_Range),
|
||||||
m_Underlying(a_Underlying)
|
m_Underlying(std::move(a_Underlying))
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -537,7 +537,7 @@ public:
|
|||||||
Super(a_Seed),
|
Super(a_Seed),
|
||||||
m_Range(a_HalfRange * 2 + 1),
|
m_Range(a_HalfRange * 2 + 1),
|
||||||
m_HalfRange(a_HalfRange),
|
m_HalfRange(a_HalfRange),
|
||||||
m_Underlying(a_Underlying)
|
m_Underlying(std::move(a_Underlying))
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -580,7 +580,7 @@ public:
|
|||||||
cProtIntGenRndAvg(int a_Seed, int a_AvgChancePct, Underlying a_Underlying):
|
cProtIntGenRndAvg(int a_Seed, int a_AvgChancePct, Underlying a_Underlying):
|
||||||
Super(a_Seed),
|
Super(a_Seed),
|
||||||
m_AvgChancePct(a_AvgChancePct),
|
m_AvgChancePct(a_AvgChancePct),
|
||||||
m_Underlying(a_Underlying)
|
m_Underlying(std::move(a_Underlying))
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -638,7 +638,7 @@ public:
|
|||||||
cProtIntGenRndBetween(int a_Seed, int a_AvgChancePct, Underlying a_Underlying):
|
cProtIntGenRndBetween(int a_Seed, int a_AvgChancePct, Underlying a_Underlying):
|
||||||
Super(a_Seed),
|
Super(a_Seed),
|
||||||
m_AvgChancePct(a_AvgChancePct),
|
m_AvgChancePct(a_AvgChancePct),
|
||||||
m_Underlying(a_Underlying)
|
m_Underlying(std::move(a_Underlying))
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -693,7 +693,7 @@ class cProtIntGenBeaches:
|
|||||||
public:
|
public:
|
||||||
|
|
||||||
cProtIntGenBeaches(Underlying a_Underlying):
|
cProtIntGenBeaches(Underlying a_Underlying):
|
||||||
m_Underlying(a_Underlying)
|
m_Underlying(std::move(a_Underlying))
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -798,7 +798,7 @@ public:
|
|||||||
cProtIntGenAddIslands(int a_Seed, int a_Chance, Underlying a_Underlying):
|
cProtIntGenAddIslands(int a_Seed, int a_Chance, Underlying a_Underlying):
|
||||||
Super(a_Seed),
|
Super(a_Seed),
|
||||||
m_Chance(a_Chance),
|
m_Chance(a_Chance),
|
||||||
m_Underlying(a_Underlying)
|
m_Underlying(std::move(a_Underlying))
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -842,7 +842,7 @@ class cProtIntGenBiomeGroupEdges:
|
|||||||
public:
|
public:
|
||||||
|
|
||||||
cProtIntGenBiomeGroupEdges(Underlying a_Underlying):
|
cProtIntGenBiomeGroupEdges(Underlying a_Underlying):
|
||||||
m_Underlying(a_Underlying)
|
m_Underlying(std::move(a_Underlying))
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -941,7 +941,7 @@ public:
|
|||||||
|
|
||||||
cProtIntGenBiomes(int a_Seed, Underlying a_Underlying):
|
cProtIntGenBiomes(int a_Seed, Underlying a_Underlying):
|
||||||
Super(a_Seed),
|
Super(a_Seed),
|
||||||
m_Underlying(a_Underlying)
|
m_Underlying(std::move(a_Underlying))
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1072,7 +1072,7 @@ public:
|
|||||||
m_From(a_From),
|
m_From(a_From),
|
||||||
m_To(a_To),
|
m_To(a_To),
|
||||||
m_Chance(a_Chance),
|
m_Chance(a_Chance),
|
||||||
m_Underlying(a_Underlying)
|
m_Underlying(std::move(a_Underlying))
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1131,8 +1131,8 @@ class cProtIntGenMixRivers:
|
|||||||
public:
|
public:
|
||||||
|
|
||||||
cProtIntGenMixRivers(Underlying a_Biomes, Underlying a_Rivers):
|
cProtIntGenMixRivers(Underlying a_Biomes, Underlying a_Rivers):
|
||||||
m_Biomes(a_Biomes),
|
m_Biomes(std::move(a_Biomes)),
|
||||||
m_Rivers(a_Rivers)
|
m_Rivers(std::move(a_Rivers))
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1197,7 +1197,7 @@ public:
|
|||||||
|
|
||||||
cProtIntGenRiver(int a_Seed, Underlying a_Underlying):
|
cProtIntGenRiver(int a_Seed, Underlying a_Underlying):
|
||||||
Super(a_Seed),
|
Super(a_Seed),
|
||||||
m_Underlying(a_Underlying)
|
m_Underlying(std::move(a_Underlying))
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1256,7 +1256,7 @@ public:
|
|||||||
Super(a_Seed),
|
Super(a_Seed),
|
||||||
m_Chance(a_Chance),
|
m_Chance(a_Chance),
|
||||||
m_ToValue(a_ToValue),
|
m_ToValue(a_ToValue),
|
||||||
m_Underlying(a_Underlying)
|
m_Underlying(std::move(a_Underlying))
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1347,7 +1347,7 @@ public:
|
|||||||
Super(a_Seed),
|
Super(a_Seed),
|
||||||
m_Chance(a_Chance),
|
m_Chance(a_Chance),
|
||||||
m_ToValue(a_ToValue),
|
m_ToValue(a_ToValue),
|
||||||
m_Underlying(a_Underlying)
|
m_Underlying(std::move(a_Underlying))
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1396,7 +1396,7 @@ public:
|
|||||||
cProtIntGenRareBiomeGroups(int a_Seed, int a_Chance, Underlying a_Underlying):
|
cProtIntGenRareBiomeGroups(int a_Seed, int a_Chance, Underlying a_Underlying):
|
||||||
Super(a_Seed),
|
Super(a_Seed),
|
||||||
m_Chance(a_Chance),
|
m_Chance(a_Chance),
|
||||||
m_Underlying(a_Underlying)
|
m_Underlying(std::move(a_Underlying))
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1444,8 +1444,8 @@ public:
|
|||||||
|
|
||||||
cProtIntGenAlternateBiomes(int a_Seed, Underlying a_Alterations, Underlying a_BaseBiomes):
|
cProtIntGenAlternateBiomes(int a_Seed, Underlying a_Alterations, Underlying a_BaseBiomes):
|
||||||
Super(a_Seed),
|
Super(a_Seed),
|
||||||
m_Alterations(a_Alterations),
|
m_Alterations(std::move(a_Alterations)),
|
||||||
m_BaseBiomes(a_BaseBiomes)
|
m_BaseBiomes(std::move(a_BaseBiomes))
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1510,7 +1510,7 @@ public:
|
|||||||
|
|
||||||
cProtIntGenBiomeEdges(int a_Seed, Underlying a_Underlying):
|
cProtIntGenBiomeEdges(int a_Seed, Underlying a_Underlying):
|
||||||
Super(a_Seed),
|
Super(a_Seed),
|
||||||
m_Underlying(a_Underlying)
|
m_Underlying(std::move(a_Underlying))
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1670,8 +1670,8 @@ public:
|
|||||||
|
|
||||||
cProtIntGenMBiomes(int a_Seed, Underlying a_Alteration, Underlying a_Underlying):
|
cProtIntGenMBiomes(int a_Seed, Underlying a_Alteration, Underlying a_Underlying):
|
||||||
Super(a_Seed),
|
Super(a_Seed),
|
||||||
m_Underlying(a_Underlying),
|
m_Underlying(std::move(a_Underlying)),
|
||||||
m_Alteration(a_Alteration)
|
m_Alteration(std::move(a_Alteration))
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -24,7 +24,7 @@ class cTerrainHeightToShapeGen:
|
|||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
cTerrainHeightToShapeGen(cTerrainHeightGenPtr a_HeightGen):
|
cTerrainHeightToShapeGen(cTerrainHeightGenPtr a_HeightGen):
|
||||||
m_HeightGen(a_HeightGen)
|
m_HeightGen(std::move(a_HeightGen))
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -77,7 +77,7 @@ typedef std::shared_ptr<cTerrainHeightToShapeGen> cTerrainHeightToShapeGenPtr;
|
|||||||
|
|
||||||
cTerrainShapeGenPtr cTerrainShapeGen::CreateShapeGen(
|
cTerrainShapeGenPtr cTerrainShapeGen::CreateShapeGen(
|
||||||
cIniFile & a_IniFile,
|
cIniFile & a_IniFile,
|
||||||
cBiomeGenPtr a_BiomeGen,
|
const cBiomeGenPtr & a_BiomeGen,
|
||||||
int a_Seed,
|
int a_Seed,
|
||||||
bool & a_CacheOffByDefault
|
bool & a_CacheOffByDefault
|
||||||
)
|
)
|
||||||
|
@ -25,9 +25,9 @@ public:
|
|||||||
cStructGenTrees(int a_Seed, cBiomeGenPtr a_BiomeGen, cTerrainShapeGenPtr a_ShapeGen, cTerrainCompositionGenPtr a_CompositionGen) :
|
cStructGenTrees(int a_Seed, cBiomeGenPtr a_BiomeGen, cTerrainShapeGenPtr a_ShapeGen, cTerrainCompositionGenPtr a_CompositionGen) :
|
||||||
m_Seed(a_Seed),
|
m_Seed(a_Seed),
|
||||||
m_Noise(a_Seed),
|
m_Noise(a_Seed),
|
||||||
m_BiomeGen(a_BiomeGen),
|
m_BiomeGen(std::move(a_BiomeGen)),
|
||||||
m_ShapeGen(a_ShapeGen),
|
m_ShapeGen(std::move(a_ShapeGen)),
|
||||||
m_CompositionGen(a_CompositionGen)
|
m_CompositionGen(std::move(a_CompositionGen))
|
||||||
{}
|
{}
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
@ -82,7 +82,7 @@ public:
|
|||||||
m_Noise(a_Seed),
|
m_Noise(a_Seed),
|
||||||
m_Seed(a_Seed),
|
m_Seed(a_Seed),
|
||||||
m_Fluid(a_Fluid),
|
m_Fluid(a_Fluid),
|
||||||
m_ShapeGen(a_ShapeGen),
|
m_ShapeGen(std::move(a_ShapeGen)),
|
||||||
m_Probability(a_Probability)
|
m_Probability(a_Probability)
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
@ -615,7 +615,7 @@ void GetAcaciaTreeImage(Vector3i a_BlockPos, cNoise & a_Noise, int a_Seq, sSetBl
|
|||||||
a_OtherBlocks.push_back(sSetBlock(BranchPos.x, BranchPos.y + 1, BranchPos.z, E_BLOCK_NEW_LEAVES, E_META_NEWLEAVES_ACACIA));
|
a_OtherBlocks.push_back(sSetBlock(BranchPos.x, BranchPos.y + 1, BranchPos.z, E_BLOCK_NEW_LEAVES, E_META_NEWLEAVES_ACACIA));
|
||||||
|
|
||||||
// Choose if we have to add another branch
|
// Choose if we have to add another branch
|
||||||
bool TwoTop = (a_Noise.IntNoise3D(a_BlockPos) < 0 ? true : false);
|
bool TwoTop = (a_Noise.IntNoise3D(a_BlockPos) < 0);
|
||||||
if (!TwoTop)
|
if (!TwoTop)
|
||||||
{
|
{
|
||||||
return;
|
return;
|
||||||
|
@ -21,7 +21,7 @@ class cTwoHeights:
|
|||||||
|
|
||||||
public:
|
public:
|
||||||
|
|
||||||
cTwoHeights(int a_Seed, cBiomeGenPtr a_BiomeGen):
|
cTwoHeights(int a_Seed, const cBiomeGenPtr & a_BiomeGen):
|
||||||
m_Seed(a_Seed),
|
m_Seed(a_Seed),
|
||||||
m_Choice(a_Seed),
|
m_Choice(a_Seed),
|
||||||
m_HeightA(a_Seed + 1, a_BiomeGen),
|
m_HeightA(a_Seed + 1, a_BiomeGen),
|
||||||
@ -113,7 +113,7 @@ protected:
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
cTerrainShapeGenPtr CreateShapeGenTwoHeights(int a_Seed, cBiomeGenPtr a_BiomeGen)
|
cTerrainShapeGenPtr CreateShapeGenTwoHeights(int a_Seed, const cBiomeGenPtr & a_BiomeGen)
|
||||||
{
|
{
|
||||||
return std::make_shared<cTwoHeights>(a_Seed, a_BiomeGen);
|
return std::make_shared<cTwoHeights>(a_Seed, a_BiomeGen);
|
||||||
}
|
}
|
||||||
|
@ -16,7 +16,7 @@
|
|||||||
|
|
||||||
/** Creates and returns a new instance of the cTwoHeights terrain shape generator.
|
/** Creates and returns a new instance of the cTwoHeights terrain shape generator.
|
||||||
The instance must be Initialize()-d before it is used. */
|
The instance must be Initialize()-d before it is used. */
|
||||||
extern cTerrainShapeGenPtr CreateShapeGenTwoHeights(int a_Seed, cBiomeGenPtr a_BiomeGen);
|
extern cTerrainShapeGenPtr CreateShapeGenTwoHeights(int a_Seed, const cBiomeGenPtr & a_BiomeGen);
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
@ -137,7 +137,7 @@ public:
|
|||||||
{a_OriginX + a_MaxSize, cChunkDef::Height - 1, a_OriginZ + a_MaxSize}
|
{a_OriginX + a_MaxSize, cChunkDef::Height - 1, a_OriginZ + a_MaxSize}
|
||||||
),
|
),
|
||||||
m_Prefabs(a_Prefabs),
|
m_Prefabs(a_Prefabs),
|
||||||
m_HeightGen(a_HeightGen)
|
m_HeightGen(std::move(a_HeightGen))
|
||||||
{
|
{
|
||||||
// Generate the pieces for this village; don't care about the Y coord:
|
// Generate the pieces for this village; don't care about the Y coord:
|
||||||
cPieceGeneratorBFSTree pg(*this, a_Seed);
|
cPieceGeneratorBFSTree pg(*this, a_Seed);
|
||||||
@ -348,8 +348,8 @@ cVillageGen::cVillageGen(
|
|||||||
m_MaxSize(a_MaxSize),
|
m_MaxSize(a_MaxSize),
|
||||||
m_MinDensity(a_MinDensity),
|
m_MinDensity(a_MinDensity),
|
||||||
m_MaxDensity(a_MaxDensity),
|
m_MaxDensity(a_MaxDensity),
|
||||||
m_BiomeGen(a_BiomeGen),
|
m_BiomeGen(std::move(a_BiomeGen)),
|
||||||
m_HeightGen(a_HeightGen)
|
m_HeightGen(std::move(a_HeightGen))
|
||||||
{
|
{
|
||||||
for (const auto & toLoad: a_PrefabsToLoad)
|
for (const auto & toLoad: a_PrefabsToLoad)
|
||||||
{
|
{
|
||||||
|
@ -126,7 +126,7 @@ public:
|
|||||||
bool DoesAllowKeepAlive(void) const { return m_AllowKeepAlive; }
|
bool DoesAllowKeepAlive(void) const { return m_AllowKeepAlive; }
|
||||||
|
|
||||||
/** Attaches any kind of data to this request, to be later retrieved by GetUserData(). */
|
/** Attaches any kind of data to this request, to be later retrieved by GetUserData(). */
|
||||||
void SetUserData(cUserDataPtr a_UserData) { m_UserData = a_UserData; }
|
void SetUserData(cUserDataPtr a_UserData) { m_UserData = std::move(a_UserData); }
|
||||||
|
|
||||||
/** Returns the data attached to this request by the class client. */
|
/** Returns the data attached to this request by the class client. */
|
||||||
cUserDataPtr GetUserData(void) { return m_UserData; }
|
cUserDataPtr GetUserData(void) { return m_UserData; }
|
||||||
|
@ -137,7 +137,7 @@ bool cHTTPServer::Start(cCallbacks & a_Callbacks, const AStringVector & a_Ports)
|
|||||||
|
|
||||||
// Open up requested ports:
|
// Open up requested ports:
|
||||||
AStringVector ports;
|
AStringVector ports;
|
||||||
for (auto port : a_Ports)
|
for (const auto & port : a_Ports)
|
||||||
{
|
{
|
||||||
UInt16 PortNum;
|
UInt16 PortNum;
|
||||||
if (!StringToInteger(port, PortNum))
|
if (!StringToInteger(port, PortNum))
|
||||||
@ -175,7 +175,7 @@ bool cHTTPServer::Start(cCallbacks & a_Callbacks, const AStringVector & a_Ports)
|
|||||||
|
|
||||||
void cHTTPServer::Stop(void)
|
void cHTTPServer::Stop(void)
|
||||||
{
|
{
|
||||||
for (auto handle : m_ServerHandles)
|
for (const auto & handle : m_ServerHandles)
|
||||||
{
|
{
|
||||||
handle->Close();
|
handle->Close();
|
||||||
}
|
}
|
||||||
|
@ -11,7 +11,9 @@
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
cSslHTTPServerConnection::cSslHTTPServerConnection(cHTTPServer & a_HTTPServer, std::shared_ptr<const cSslConfig> a_Config):
|
cSslHTTPServerConnection::cSslHTTPServerConnection(
|
||||||
|
cHTTPServer & a_HTTPServer, const std::shared_ptr<const cSslConfig> & a_Config
|
||||||
|
):
|
||||||
Super(a_HTTPServer),
|
Super(a_HTTPServer),
|
||||||
m_Ssl(64000)
|
m_Ssl(64000)
|
||||||
{
|
{
|
||||||
|
@ -25,7 +25,7 @@ public:
|
|||||||
|
|
||||||
/** Creates a new connection on the specified server.
|
/** Creates a new connection on the specified server.
|
||||||
Sends the specified cert as the server certificate, uses the private key for decryption. */
|
Sends the specified cert as the server certificate, uses the private key for decryption. */
|
||||||
cSslHTTPServerConnection(cHTTPServer & a_HTTPServer, std::shared_ptr<const cSslConfig> a_Config);
|
cSslHTTPServerConnection(cHTTPServer & a_HTTPServer, const std::shared_ptr<const cSslConfig> & a_Config);
|
||||||
|
|
||||||
virtual ~cSslHTTPServerConnection() override;
|
virtual ~cSslHTTPServerConnection() override;
|
||||||
|
|
||||||
|
@ -159,7 +159,7 @@ protected:
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
std::pair<bool, AString> DoRequest(std::shared_ptr<cUrlClientRequest> a_Self);
|
std::pair<bool, AString> DoRequest(const std::shared_ptr<cUrlClientRequest> & a_Self);
|
||||||
|
|
||||||
|
|
||||||
// cNetwork::cConnectCallbacks override: TCP link connected:
|
// cNetwork::cConnectCallbacks override: TCP link connected:
|
||||||
@ -572,7 +572,7 @@ void cUrlClientRequest::OnRemoteClosed()
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
std::pair<bool, AString> cUrlClientRequest::DoRequest(std::shared_ptr<cUrlClientRequest> a_Self)
|
std::pair<bool, AString> cUrlClientRequest::DoRequest(const std::shared_ptr<cUrlClientRequest> & a_Self)
|
||||||
{
|
{
|
||||||
// We need a shared pointer to self, care must be taken not to pass any other ptr:
|
// We need a shared pointer to self, care must be taken not to pass any other ptr:
|
||||||
ASSERT(a_Self.get() == this);
|
ASSERT(a_Self.get() == this);
|
||||||
@ -630,7 +630,7 @@ std::pair<bool, AString> cUrlClient::Get(
|
|||||||
const AString & a_URL,
|
const AString & a_URL,
|
||||||
cCallbacksPtr && a_Callbacks,
|
cCallbacksPtr && a_Callbacks,
|
||||||
AStringMap a_Headers,
|
AStringMap a_Headers,
|
||||||
AString a_Body,
|
const AString & a_Body,
|
||||||
AStringMap a_Options
|
AStringMap a_Options
|
||||||
)
|
)
|
||||||
{
|
{
|
||||||
|
@ -124,7 +124,7 @@ public:
|
|||||||
const AString & a_URL,
|
const AString & a_URL,
|
||||||
cCallbacksPtr && a_Callbacks,
|
cCallbacksPtr && a_Callbacks,
|
||||||
AStringMap a_Headers = AStringMap(),
|
AStringMap a_Headers = AStringMap(),
|
||||||
AString a_Body = AString(),
|
const AString & a_Body = AString(),
|
||||||
AStringMap a_Options = AStringMap()
|
AStringMap a_Options = AStringMap()
|
||||||
);
|
);
|
||||||
|
|
||||||
|
@ -934,7 +934,7 @@ AStringVector ReadUpgradeIniPorts(
|
|||||||
|
|
||||||
AStringVector Ports;
|
AStringVector Ports;
|
||||||
|
|
||||||
for (auto pair : a_Settings.GetValues(a_KeyName))
|
for (const auto & pair : a_Settings.GetValues(a_KeyName))
|
||||||
{
|
{
|
||||||
if (pair.first != a_PortsValueName)
|
if (pair.first != a_PortsValueName)
|
||||||
{
|
{
|
||||||
|
@ -772,7 +772,7 @@ void cItems::Set(int a_Idx, short a_ItemType, char a_ItemCount, short a_ItemDama
|
|||||||
|
|
||||||
bool cItems::Contains(const cItem & a_Item)
|
bool cItems::Contains(const cItem & a_Item)
|
||||||
{
|
{
|
||||||
for (auto itr : *this)
|
for (const auto & itr : *this)
|
||||||
{
|
{
|
||||||
if (a_Item.IsEqual(itr))
|
if (a_Item.IsEqual(itr))
|
||||||
{
|
{
|
||||||
@ -788,7 +788,7 @@ bool cItems::Contains(const cItem & a_Item)
|
|||||||
|
|
||||||
bool cItems::ContainsType(const cItem & a_Item)
|
bool cItems::ContainsType(const cItem & a_Item)
|
||||||
{
|
{
|
||||||
for (auto itr : *this)
|
for (const auto & itr : *this)
|
||||||
{
|
{
|
||||||
if (a_Item.IsSameType(itr))
|
if (a_Item.IsSameType(itr))
|
||||||
{
|
{
|
||||||
|
@ -30,7 +30,7 @@ void cLogger::InitiateMultithreading()
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
void cLogger::LogSimple(AString a_Message, eLogLevel a_LogLevel)
|
void cLogger::LogSimple(const AString & a_Message, eLogLevel a_LogLevel)
|
||||||
{
|
{
|
||||||
time_t rawtime;
|
time_t rawtime;
|
||||||
time(&rawtime);
|
time(&rawtime);
|
||||||
|
@ -75,7 +75,7 @@ public:
|
|||||||
}
|
}
|
||||||
|
|
||||||
/** Logs the simple text message at the specified log level. */
|
/** Logs the simple text message at the specified log level. */
|
||||||
void LogSimple(AString a_Message, eLogLevel a_LogLevel = llRegular);
|
void LogSimple(const AString & a_Message, eLogLevel a_LogLevel = llRegular);
|
||||||
|
|
||||||
cAttachment AttachListener(std::unique_ptr<cListener> a_Listener);
|
cAttachment AttachListener(std::unique_ptr<cListener> a_Listener);
|
||||||
|
|
||||||
|
@ -23,11 +23,7 @@ bool cMemorySettingsRepository::HasValue(const AString & a_KeyName, const AStrin
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
auto iter = outerIter->second.find(a_ValueName);
|
auto iter = outerIter->second.find(a_ValueName);
|
||||||
if (iter == outerIter->second.end())
|
return (iter != outerIter->second.end());
|
||||||
{
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
return true;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -110,7 +106,7 @@ void cMemorySettingsRepository::AddValue (const AString & a_KeyName, const AStri
|
|||||||
std::vector<std::pair<AString, AString>> cMemorySettingsRepository::GetValues(AString a_keyName)
|
std::vector<std::pair<AString, AString>> cMemorySettingsRepository::GetValues(AString a_keyName)
|
||||||
{
|
{
|
||||||
std::vector<std::pair<AString, AString>> ret;
|
std::vector<std::pair<AString, AString>> ret;
|
||||||
for (auto pair : m_Map[a_keyName])
|
for (const auto & pair : m_Map[a_keyName])
|
||||||
{
|
{
|
||||||
ret.emplace_back(pair.first, pair.second.getStringValue());
|
ret.emplace_back(pair.first, pair.second.getStringValue());
|
||||||
}
|
}
|
||||||
|
@ -57,7 +57,7 @@ private:
|
|||||||
#ifdef _DEBUG
|
#ifdef _DEBUG
|
||||||
m_Type(eType::String),
|
m_Type(eType::String),
|
||||||
#endif
|
#endif
|
||||||
m_stringValue (value)
|
m_stringValue (std::move(value))
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -22,11 +22,8 @@ bool cMobCensus::IsCapped(cMonster::eFamily a_MobFamily)
|
|||||||
const int ratio = 319; // This should be 256 as we are only supposed to take account from chunks that are in 17 x 17 from a player
|
const int ratio = 319; // This should be 256 as we are only supposed to take account from chunks that are in 17 x 17 from a player
|
||||||
// but for now, we use all chunks loaded by players. that means 19 x 19 chunks. That's why we use 256 * (19 * 19) / (17 * 17) = 319
|
// but for now, we use all chunks loaded by players. that means 19 x 19 chunks. That's why we use 256 * (19 * 19) / (17 * 17) = 319
|
||||||
// MG TODO : code the correct count
|
// MG TODO : code the correct count
|
||||||
if ((GetCapMultiplier(a_MobFamily) * GetNumChunks()) / ratio >= m_MobFamilyCollecter.GetNumberOfCollectedMobs(a_MobFamily))
|
const auto MobCap = ((GetCapMultiplier(a_MobFamily) * GetNumChunks()) / ratio);
|
||||||
{
|
return (MobCap < m_MobFamilyCollecter.GetNumberOfCollectedMobs(a_MobFamily));
|
||||||
return false;
|
|
||||||
}
|
|
||||||
return true;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -83,11 +83,10 @@ void cCreeper::GetDrops(cItems & a_Drops, cEntity * a_Killer)
|
|||||||
{
|
{
|
||||||
auto ProjectileCreatorCallback = [](cEntity & a_Entity)
|
auto ProjectileCreatorCallback = [](cEntity & a_Entity)
|
||||||
{
|
{
|
||||||
if (a_Entity.IsMob() && ((static_cast<cMonster &>(a_Entity)).GetMobType() == mtSkeleton))
|
return (
|
||||||
{
|
a_Entity.IsMob() &&
|
||||||
return true;
|
((static_cast<cMonster &>(a_Entity)).GetMobType() == mtSkeleton)
|
||||||
}
|
);
|
||||||
return false;
|
|
||||||
};
|
};
|
||||||
|
|
||||||
if (GetWorld()->DoWithEntityByID(static_cast<cProjectileEntity *>(a_Killer)->GetCreatorUniqueID(), ProjectileCreatorCallback))
|
if (GetWorld()->DoWithEntityByID(static_cast<cProjectileEntity *>(a_Killer)->GetCreatorUniqueID(), ProjectileCreatorCallback))
|
||||||
|
@ -19,7 +19,7 @@ cEnderDragon::cEnderDragon(void) :
|
|||||||
|
|
||||||
void cEnderDragon::GetDrops(cItems & a_Drops, cEntity * a_Killer)
|
void cEnderDragon::GetDrops(cItems & a_Drops, cEntity * a_Killer)
|
||||||
{
|
{
|
||||||
return;
|
// No drops
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -325,7 +325,7 @@ void cMonster::Tick(std::chrono::milliseconds a_Dt, cChunk & a_Chunk)
|
|||||||
else
|
else
|
||||||
{
|
{
|
||||||
// Note that m_NextWayPointPosition is actually returned by GetNextWayPoint)
|
// Note that m_NextWayPointPosition is actually returned by GetNextWayPoint)
|
||||||
switch (m_PathFinder.GetNextWayPoint(*Chunk, GetPosition(), &m_FinalDestination, &m_NextWayPointPosition, m_EMState == IDLE ? true : false))
|
switch (m_PathFinder.GetNextWayPoint(*Chunk, GetPosition(), &m_FinalDestination, &m_NextWayPointPosition, m_EMState == IDLE))
|
||||||
{
|
{
|
||||||
case ePathFinderStatus::PATH_FOUND:
|
case ePathFinderStatus::PATH_FOUND:
|
||||||
{
|
{
|
||||||
|
@ -138,7 +138,7 @@ void cPassiveMonster::Tick(std::chrono::milliseconds a_Dt, cChunk & a_Chunk)
|
|||||||
{
|
{
|
||||||
m_World->DoWithNearestPlayer(GetPosition(), static_cast<float>(m_SightDistance), [&](cPlayer & a_Player) -> bool
|
m_World->DoWithNearestPlayer(GetPosition(), static_cast<float>(m_SightDistance), [&](cPlayer & a_Player) -> bool
|
||||||
{
|
{
|
||||||
cItem EquippedItem = a_Player.GetEquippedItem();
|
const cItem & EquippedItem = a_Player.GetEquippedItem();
|
||||||
if (FollowedItems.ContainsType(EquippedItem))
|
if (FollowedItems.ContainsType(EquippedItem))
|
||||||
{
|
{
|
||||||
Vector3d PlayerPos = a_Player.GetPosition();
|
Vector3d PlayerPos = a_Player.GetPosition();
|
||||||
|
@ -639,15 +639,8 @@ bool cPath::SpecialIsSolidFromThisDirection(BLOCKTYPE a_Type, NIBBLETYPE a_Meta,
|
|||||||
// If there is a nonsolid above a fence
|
// If there is a nonsolid above a fence
|
||||||
if (!cBlockInfo::IsSolid(a_Type))
|
if (!cBlockInfo::IsSolid(a_Type))
|
||||||
{
|
{
|
||||||
// If we're coming from below
|
// Only treat as solid when we're coming from below
|
||||||
if (a_Direction.y > 0)
|
return (a_Direction.y > 0);
|
||||||
{
|
|
||||||
return true; // treat the nonsolid as solid
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
return false; // Treat it as a nonsolid because we are not coming from below
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/* switch (a_Type)
|
/* switch (a_Type)
|
||||||
|
@ -278,9 +278,6 @@ bool cPathFinder::PathIsTooOld() const
|
|||||||
{
|
{
|
||||||
acceptableDeviation = 1;
|
acceptableDeviation = 1;
|
||||||
}
|
}
|
||||||
if ((m_FinalDestination - m_DeviationOrigin).SqrLength() > acceptableDeviation * acceptableDeviation)
|
const auto DeviationSqr = (m_FinalDestination - m_DeviationOrigin).SqrLength();
|
||||||
{
|
return (DeviationSqr > (acceptableDeviation * acceptableDeviation));
|
||||||
return true;
|
|
||||||
}
|
|
||||||
return false;
|
|
||||||
}
|
}
|
||||||
|
@ -16,7 +16,7 @@
|
|||||||
// cHostnameLookup:
|
// cHostnameLookup:
|
||||||
|
|
||||||
cHostnameLookup::cHostnameLookup(const AString & a_Hostname, cNetwork::cResolveNameCallbacksPtr a_Callbacks):
|
cHostnameLookup::cHostnameLookup(const AString & a_Hostname, cNetwork::cResolveNameCallbacksPtr a_Callbacks):
|
||||||
m_Callbacks(a_Callbacks),
|
m_Callbacks(std::move(a_Callbacks)),
|
||||||
m_Hostname(a_Hostname)
|
m_Hostname(a_Hostname)
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
@ -17,10 +17,10 @@
|
|||||||
// cIPLookup:
|
// cIPLookup:
|
||||||
|
|
||||||
cIPLookup::cIPLookup(const AString & a_IP, cNetwork::cResolveNameCallbacksPtr a_Callbacks):
|
cIPLookup::cIPLookup(const AString & a_IP, cNetwork::cResolveNameCallbacksPtr a_Callbacks):
|
||||||
m_Callbacks(a_Callbacks),
|
m_Callbacks(std::move(a_Callbacks)),
|
||||||
m_IP(a_IP)
|
m_IP(a_IP)
|
||||||
{
|
{
|
||||||
ASSERT(a_Callbacks != nullptr);
|
ASSERT(m_Callbacks != nullptr);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -132,7 +132,7 @@ protected:
|
|||||||
|
|
||||||
/** Creates a new link, with the specified callbacks. */
|
/** Creates a new link, with the specified callbacks. */
|
||||||
cTCPLink(cCallbacksPtr a_Callbacks):
|
cTCPLink(cCallbacksPtr a_Callbacks):
|
||||||
m_Callbacks(a_Callbacks)
|
m_Callbacks(std::move(a_Callbacks))
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
@ -182,7 +182,7 @@ void cNetworkSingleton::SignalizeStartup(evutil_socket_t a_Socket, short a_Event
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
void cNetworkSingleton::AddLink(cTCPLinkPtr a_Link)
|
void cNetworkSingleton::AddLink(const cTCPLinkPtr & a_Link)
|
||||||
{
|
{
|
||||||
ASSERT(!m_HasTerminated);
|
ASSERT(!m_HasTerminated);
|
||||||
cCSLock Lock(m_CS);
|
cCSLock Lock(m_CS);
|
||||||
@ -211,7 +211,7 @@ void cNetworkSingleton::RemoveLink(const cTCPLink * a_Link)
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
void cNetworkSingleton::AddServer(cServerHandlePtr a_Server)
|
void cNetworkSingleton::AddServer(const cServerHandlePtr & a_Server)
|
||||||
{
|
{
|
||||||
ASSERT(!m_HasTerminated);
|
ASSERT(!m_HasTerminated);
|
||||||
cCSLock Lock(m_CS);
|
cCSLock Lock(m_CS);
|
||||||
|
@ -61,7 +61,7 @@ public:
|
|||||||
|
|
||||||
/** Adds the specified link to m_Connections.
|
/** Adds the specified link to m_Connections.
|
||||||
Used by the underlying link implementation when a new link is created. */
|
Used by the underlying link implementation when a new link is created. */
|
||||||
void AddLink(cTCPLinkPtr a_Link);
|
void AddLink(const cTCPLinkPtr & a_Link);
|
||||||
|
|
||||||
/** Removes the specified link from m_Connections.
|
/** Removes the specified link from m_Connections.
|
||||||
Used by the underlying link implementation when the link is closed / errored. */
|
Used by the underlying link implementation when the link is closed / errored. */
|
||||||
@ -70,7 +70,7 @@ public:
|
|||||||
/** Adds the specified link to m_Servers.
|
/** Adds the specified link to m_Servers.
|
||||||
Used by the underlying server handle implementation when a new listening server is created.
|
Used by the underlying server handle implementation when a new listening server is created.
|
||||||
Only servers that succeed in listening are added. */
|
Only servers that succeed in listening are added. */
|
||||||
void AddServer(cServerHandlePtr a_Server);
|
void AddServer(const cServerHandlePtr & a_Server);
|
||||||
|
|
||||||
/** Removes the specified server from m_Servers.
|
/** Removes the specified server from m_Servers.
|
||||||
Used by the underlying server handle implementation when the server is closed. */
|
Used by the underlying server handle implementation when the server is closed. */
|
||||||
|
@ -32,7 +32,7 @@ static bool IsValidSocket(evutil_socket_t a_Socket)
|
|||||||
// cServerHandleImpl:
|
// cServerHandleImpl:
|
||||||
|
|
||||||
cServerHandleImpl::cServerHandleImpl(cNetwork::cListenCallbacksPtr a_ListenCallbacks):
|
cServerHandleImpl::cServerHandleImpl(cNetwork::cListenCallbacksPtr a_ListenCallbacks):
|
||||||
m_ListenCallbacks(a_ListenCallbacks),
|
m_ListenCallbacks(std::move(a_ListenCallbacks)),
|
||||||
m_ConnListener(nullptr),
|
m_ConnListener(nullptr),
|
||||||
m_SecondaryConnListener(nullptr),
|
m_SecondaryConnListener(nullptr),
|
||||||
m_IsListening(false),
|
m_IsListening(false),
|
||||||
@ -79,7 +79,7 @@ void cServerHandleImpl::Close(void)
|
|||||||
cCSLock Lock(m_CS);
|
cCSLock Lock(m_CS);
|
||||||
std::swap(Conns, m_Connections);
|
std::swap(Conns, m_Connections);
|
||||||
}
|
}
|
||||||
for (auto conn: Conns)
|
for (const auto & conn: Conns)
|
||||||
{
|
{
|
||||||
conn->Shutdown();
|
conn->Shutdown();
|
||||||
}
|
}
|
||||||
@ -100,7 +100,7 @@ cServerHandleImplPtr cServerHandleImpl::Listen(
|
|||||||
cNetwork::cListenCallbacksPtr a_ListenCallbacks
|
cNetwork::cListenCallbacksPtr a_ListenCallbacks
|
||||||
)
|
)
|
||||||
{
|
{
|
||||||
cServerHandleImplPtr res = cServerHandleImplPtr{new cServerHandleImpl(a_ListenCallbacks)};
|
cServerHandleImplPtr res{new cServerHandleImpl(std::move(a_ListenCallbacks))};
|
||||||
res->m_SelfPtr = res;
|
res->m_SelfPtr = res;
|
||||||
if (res->Listen(a_Port))
|
if (res->Listen(a_Port))
|
||||||
{
|
{
|
||||||
@ -108,7 +108,7 @@ cServerHandleImplPtr cServerHandleImpl::Listen(
|
|||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
a_ListenCallbacks->OnError(res->m_ErrorCode, res->m_ErrorMsg);
|
res->m_ListenCallbacks->OnError(res->m_ErrorCode, res->m_ErrorMsg);
|
||||||
res->m_SelfPtr.reset();
|
res->m_SelfPtr.reset();
|
||||||
}
|
}
|
||||||
return res;
|
return res;
|
||||||
@ -363,7 +363,7 @@ cServerHandlePtr cNetwork::Listen(
|
|||||||
cNetwork::cListenCallbacksPtr a_ListenCallbacks
|
cNetwork::cListenCallbacksPtr a_ListenCallbacks
|
||||||
)
|
)
|
||||||
{
|
{
|
||||||
return cServerHandleImpl::Listen(a_Port, a_ListenCallbacks);
|
return cServerHandleImpl::Listen(a_Port, std::move(a_ListenCallbacks));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -18,7 +18,7 @@
|
|||||||
// cTCPLinkImpl:
|
// cTCPLinkImpl:
|
||||||
|
|
||||||
cTCPLinkImpl::cTCPLinkImpl(cTCPLink::cCallbacksPtr a_LinkCallbacks):
|
cTCPLinkImpl::cTCPLinkImpl(cTCPLink::cCallbacksPtr a_LinkCallbacks):
|
||||||
Super(a_LinkCallbacks),
|
Super(std::move(a_LinkCallbacks)),
|
||||||
m_BufferEvent(bufferevent_socket_new(cNetworkSingleton::Get().GetEventBase(), -1, BEV_OPT_CLOSE_ON_FREE | BEV_OPT_THREADSAFE | BEV_OPT_DEFER_CALLBACKS | BEV_OPT_UNLOCK_CALLBACKS)),
|
m_BufferEvent(bufferevent_socket_new(cNetworkSingleton::Get().GetEventBase(), -1, BEV_OPT_CLOSE_ON_FREE | BEV_OPT_THREADSAFE | BEV_OPT_DEFER_CALLBACKS | BEV_OPT_UNLOCK_CALLBACKS)),
|
||||||
m_LocalPort(0),
|
m_LocalPort(0),
|
||||||
m_RemotePort(0),
|
m_RemotePort(0),
|
||||||
@ -31,9 +31,9 @@ cTCPLinkImpl::cTCPLinkImpl(cTCPLink::cCallbacksPtr a_LinkCallbacks):
|
|||||||
|
|
||||||
|
|
||||||
cTCPLinkImpl::cTCPLinkImpl(evutil_socket_t a_Socket, cTCPLink::cCallbacksPtr a_LinkCallbacks, cServerHandleImplPtr a_Server, const sockaddr * a_Address, socklen_t a_AddrLen):
|
cTCPLinkImpl::cTCPLinkImpl(evutil_socket_t a_Socket, cTCPLink::cCallbacksPtr a_LinkCallbacks, cServerHandleImplPtr a_Server, const sockaddr * a_Address, socklen_t a_AddrLen):
|
||||||
Super(a_LinkCallbacks),
|
Super(std::move(a_LinkCallbacks)),
|
||||||
m_BufferEvent(bufferevent_socket_new(cNetworkSingleton::Get().GetEventBase(), a_Socket, BEV_OPT_CLOSE_ON_FREE | BEV_OPT_THREADSAFE | BEV_OPT_DEFER_CALLBACKS | BEV_OPT_UNLOCK_CALLBACKS)),
|
m_BufferEvent(bufferevent_socket_new(cNetworkSingleton::Get().GetEventBase(), a_Socket, BEV_OPT_CLOSE_ON_FREE | BEV_OPT_THREADSAFE | BEV_OPT_DEFER_CALLBACKS | BEV_OPT_UNLOCK_CALLBACKS)),
|
||||||
m_Server(a_Server),
|
m_Server(std::move(a_Server)),
|
||||||
m_LocalPort(0),
|
m_LocalPort(0),
|
||||||
m_RemotePort(0),
|
m_RemotePort(0),
|
||||||
m_ShouldShutdown(false)
|
m_ShouldShutdown(false)
|
||||||
@ -65,8 +65,8 @@ cTCPLinkImplPtr cTCPLinkImpl::Connect(const AString & a_Host, UInt16 a_Port, cTC
|
|||||||
ASSERT(a_ConnectCallbacks != nullptr);
|
ASSERT(a_ConnectCallbacks != nullptr);
|
||||||
|
|
||||||
// Create a new link:
|
// Create a new link:
|
||||||
cTCPLinkImplPtr res{new cTCPLinkImpl(a_LinkCallbacks)}; // Cannot use std::make_shared here, constructor is not accessible
|
cTCPLinkImplPtr res{new cTCPLinkImpl(std::move(a_LinkCallbacks))}; // Cannot use std::make_shared here, constructor is not accessible
|
||||||
res->m_ConnectCallbacks = a_ConnectCallbacks;
|
res->m_ConnectCallbacks = std::move(a_ConnectCallbacks);
|
||||||
cNetworkSingleton::Get().AddLink(res);
|
cNetworkSingleton::Get().AddLink(res);
|
||||||
res->m_Callbacks->OnLinkCreated(res);
|
res->m_Callbacks->OnLinkCreated(res);
|
||||||
res->Enable(res);
|
res->Enable(res);
|
||||||
@ -149,7 +149,7 @@ cTCPLinkImplPtr cTCPLinkImpl::Connect(const AString & a_Host, UInt16 a_Port, cTC
|
|||||||
void cTCPLinkImpl::Enable(cTCPLinkImplPtr a_Self)
|
void cTCPLinkImpl::Enable(cTCPLinkImplPtr a_Self)
|
||||||
{
|
{
|
||||||
// Take hold of a shared copy of self, to keep as long as the callbacks are coming:
|
// Take hold of a shared copy of self, to keep as long as the callbacks are coming:
|
||||||
m_Self = a_Self;
|
m_Self = std::move(a_Self);
|
||||||
|
|
||||||
// Set the LibEvent callbacks and enable processing:
|
// Set the LibEvent callbacks and enable processing:
|
||||||
bufferevent_setcb(m_BufferEvent, ReadCallback, WriteCallback, EventCallback, this);
|
bufferevent_setcb(m_BufferEvent, ReadCallback, WriteCallback, EventCallback, this);
|
||||||
@ -550,7 +550,7 @@ cTCPLinkImpl::cLinkTlsContext::cLinkTlsContext(cTCPLinkImpl & a_Link):
|
|||||||
|
|
||||||
void cTCPLinkImpl::cLinkTlsContext::SetSelf(cLinkTlsContextWPtr a_Self)
|
void cTCPLinkImpl::cLinkTlsContext::SetSelf(cLinkTlsContextWPtr a_Self)
|
||||||
{
|
{
|
||||||
m_Self = a_Self;
|
m_Self = std::move(a_Self);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -700,7 +700,7 @@ bool cNetwork::Connect(
|
|||||||
)
|
)
|
||||||
{
|
{
|
||||||
// Add a connection request to the queue:
|
// Add a connection request to the queue:
|
||||||
cTCPLinkImplPtr Conn = cTCPLinkImpl::Connect(a_Host, a_Port, a_LinkCallbacks, a_ConnectCallbacks);
|
cTCPLinkImplPtr Conn = cTCPLinkImpl::Connect(a_Host, a_Port, std::move(a_LinkCallbacks), std::move(a_ConnectCallbacks));
|
||||||
return (Conn != nullptr);
|
return (Conn != nullptr);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -112,7 +112,7 @@ std::vector<std::pair<AString, AString>> cOverridesSettingsRepository::GetValues
|
|||||||
|
|
||||||
auto ret = overrides;
|
auto ret = overrides;
|
||||||
|
|
||||||
for (auto mainpair : main)
|
for (const auto & mainpair : main)
|
||||||
{
|
{
|
||||||
bool found = false;
|
bool found = false;
|
||||||
for (const auto & overridepair : overrides)
|
for (const auto & overridepair : overrides)
|
||||||
@ -123,7 +123,7 @@ std::vector<std::pair<AString, AString>> cOverridesSettingsRepository::GetValues
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (found == false)
|
if (!found)
|
||||||
{
|
{
|
||||||
ret.push_back(mainpair);
|
ret.push_back(mainpair);
|
||||||
}
|
}
|
||||||
|
@ -618,7 +618,7 @@ void cProtocol_1_10_0::WriteBlockEntity(cPacketizer & a_Pkt, const cBlockEntity
|
|||||||
Writer.AddInt("x", CommandBlockEntity.GetPosX());
|
Writer.AddInt("x", CommandBlockEntity.GetPosX());
|
||||||
Writer.AddInt("y", CommandBlockEntity.GetPosY());
|
Writer.AddInt("y", CommandBlockEntity.GetPosY());
|
||||||
Writer.AddInt("z", CommandBlockEntity.GetPosZ());
|
Writer.AddInt("z", CommandBlockEntity.GetPosZ());
|
||||||
Writer.AddString("Command", CommandBlockEntity.GetCommand().c_str());
|
Writer.AddString("Command", CommandBlockEntity.GetCommand());
|
||||||
// You can set custom names for windows in Vanilla
|
// You can set custom names for windows in Vanilla
|
||||||
// For a command block, this would be the 'name' prepended to anything it outputs into global chat
|
// For a command block, this would be the 'name' prepended to anything it outputs into global chat
|
||||||
// MCS doesn't have this, so just leave it @ '@'. (geddit?)
|
// MCS doesn't have this, so just leave it @ '@'. (geddit?)
|
||||||
|
@ -446,7 +446,7 @@ void cProtocol_1_11_0::WriteBlockEntity(cPacketizer & a_Pkt, const cBlockEntity
|
|||||||
Writer.AddInt("x", CommandBlockEntity.GetPosX());
|
Writer.AddInt("x", CommandBlockEntity.GetPosX());
|
||||||
Writer.AddInt("y", CommandBlockEntity.GetPosY());
|
Writer.AddInt("y", CommandBlockEntity.GetPosY());
|
||||||
Writer.AddInt("z", CommandBlockEntity.GetPosZ());
|
Writer.AddInt("z", CommandBlockEntity.GetPosZ());
|
||||||
Writer.AddString("Command", CommandBlockEntity.GetCommand().c_str());
|
Writer.AddString("Command", CommandBlockEntity.GetCommand());
|
||||||
// You can set custom names for windows in Vanilla
|
// You can set custom names for windows in Vanilla
|
||||||
// For a command block, this would be the 'name' prepended to anything it outputs into global chat
|
// For a command block, this would be the 'name' prepended to anything it outputs into global chat
|
||||||
// MCS doesn't have this, so just leave it @ '@'. (geddit?)
|
// MCS doesn't have this, so just leave it @ '@'. (geddit?)
|
||||||
|
@ -831,7 +831,7 @@ void cProtocol_1_8_0::SendPaintingSpawn(const cPainting & a_Painting)
|
|||||||
|
|
||||||
cPacketizer Pkt(*this, pktSpawnPainting);
|
cPacketizer Pkt(*this, pktSpawnPainting);
|
||||||
Pkt.WriteVarInt32(a_Painting.GetUniqueID());
|
Pkt.WriteVarInt32(a_Painting.GetUniqueID());
|
||||||
Pkt.WriteString(a_Painting.GetName().c_str());
|
Pkt.WriteString(a_Painting.GetName());
|
||||||
Pkt.WritePosition64(static_cast<Int32>(PosX), static_cast<Int32>(PosY), static_cast<Int32>(PosZ));
|
Pkt.WritePosition64(static_cast<Int32>(PosX), static_cast<Int32>(PosY), static_cast<Int32>(PosZ));
|
||||||
Pkt.WriteBEInt8(static_cast<Int8>(a_Painting.GetProtocolFacing()));
|
Pkt.WriteBEInt8(static_cast<Int8>(a_Painting.GetProtocolFacing()));
|
||||||
}
|
}
|
||||||
@ -3266,7 +3266,7 @@ void cProtocol_1_8_0::WriteItem(cPacketizer & a_Pkt, const cItem & a_Item)
|
|||||||
|
|
||||||
if (!a_Item.IsCustomNameEmpty())
|
if (!a_Item.IsCustomNameEmpty())
|
||||||
{
|
{
|
||||||
Writer.AddString("Name", a_Item.m_CustomName.c_str());
|
Writer.AddString("Name", a_Item.m_CustomName);
|
||||||
}
|
}
|
||||||
if (!a_Item.IsLoreEmpty())
|
if (!a_Item.IsLoreEmpty())
|
||||||
{
|
{
|
||||||
@ -3327,7 +3327,7 @@ void cProtocol_1_8_0::WriteBlockEntity(cPacketizer & a_Pkt, const cBlockEntity &
|
|||||||
Writer.AddInt("x", CommandBlockEntity.GetPosX());
|
Writer.AddInt("x", CommandBlockEntity.GetPosX());
|
||||||
Writer.AddInt("y", CommandBlockEntity.GetPosY());
|
Writer.AddInt("y", CommandBlockEntity.GetPosY());
|
||||||
Writer.AddInt("z", CommandBlockEntity.GetPosZ());
|
Writer.AddInt("z", CommandBlockEntity.GetPosZ());
|
||||||
Writer.AddString("Command", CommandBlockEntity.GetCommand().c_str());
|
Writer.AddString("Command", CommandBlockEntity.GetCommand());
|
||||||
// You can set custom names for windows in Vanilla
|
// You can set custom names for windows in Vanilla
|
||||||
// For a command block, this would be the 'name' prepended to anything it outputs into global chat
|
// For a command block, this would be the 'name' prepended to anything it outputs into global chat
|
||||||
// MCS doesn't have this, so just leave it @ '@'. (geddit?)
|
// MCS doesn't have this, so just leave it @ '@'. (geddit?)
|
||||||
|
@ -302,7 +302,7 @@ void cProtocol_1_9_0::SendPaintingSpawn(const cPainting & a_Painting)
|
|||||||
// TODO: Bad way to write a UUID, and it's not a true UUID, but this is functional for now.
|
// TODO: Bad way to write a UUID, and it's not a true UUID, but this is functional for now.
|
||||||
Pkt.WriteBEUInt64(0);
|
Pkt.WriteBEUInt64(0);
|
||||||
Pkt.WriteBEUInt64(a_Painting.GetUniqueID());
|
Pkt.WriteBEUInt64(a_Painting.GetUniqueID());
|
||||||
Pkt.WriteString(a_Painting.GetName().c_str());
|
Pkt.WriteString(a_Painting.GetName());
|
||||||
Pkt.WritePosition64(static_cast<Int32>(PosX), static_cast<Int32>(PosY), static_cast<Int32>(PosZ));
|
Pkt.WritePosition64(static_cast<Int32>(PosX), static_cast<Int32>(PosY), static_cast<Int32>(PosZ));
|
||||||
Pkt.WriteBEInt8(static_cast<Int8>(a_Painting.GetProtocolFacing()));
|
Pkt.WriteBEInt8(static_cast<Int8>(a_Painting.GetProtocolFacing()));
|
||||||
}
|
}
|
||||||
@ -1413,7 +1413,7 @@ void cProtocol_1_9_0::WriteItem(cPacketizer & a_Pkt, const cItem & a_Item)
|
|||||||
|
|
||||||
if (!a_Item.IsCustomNameEmpty())
|
if (!a_Item.IsCustomNameEmpty())
|
||||||
{
|
{
|
||||||
Writer.AddString("Name", a_Item.m_CustomName.c_str());
|
Writer.AddString("Name", a_Item.m_CustomName);
|
||||||
}
|
}
|
||||||
if (!a_Item.IsLoreEmpty())
|
if (!a_Item.IsLoreEmpty())
|
||||||
{
|
{
|
||||||
@ -1489,7 +1489,7 @@ void cProtocol_1_9_0::WriteItem(cPacketizer & a_Pkt, const cItem & a_Item)
|
|||||||
|
|
||||||
PotionID = "minecraft:" + PotionID;
|
PotionID = "minecraft:" + PotionID;
|
||||||
|
|
||||||
Writer.AddString("Potion", PotionID.c_str());
|
Writer.AddString("Potion", PotionID);
|
||||||
}
|
}
|
||||||
if (a_Item.m_ItemType == E_ITEM_SPAWN_EGG)
|
if (a_Item.m_ItemType == E_ITEM_SPAWN_EGG)
|
||||||
{
|
{
|
||||||
@ -1545,7 +1545,7 @@ void cProtocol_1_9_0::WriteBlockEntity(cPacketizer & a_Pkt, const cBlockEntity &
|
|||||||
Writer.AddInt("x", CommandBlockEntity.GetPosX());
|
Writer.AddInt("x", CommandBlockEntity.GetPosX());
|
||||||
Writer.AddInt("y", CommandBlockEntity.GetPosY());
|
Writer.AddInt("y", CommandBlockEntity.GetPosY());
|
||||||
Writer.AddInt("z", CommandBlockEntity.GetPosZ());
|
Writer.AddInt("z", CommandBlockEntity.GetPosZ());
|
||||||
Writer.AddString("Command", CommandBlockEntity.GetCommand().c_str());
|
Writer.AddString("Command", CommandBlockEntity.GetCommand());
|
||||||
// You can set custom names for windows in Vanilla
|
// You can set custom names for windows in Vanilla
|
||||||
// For a command block, this would be the 'name' prepended to anything it outputs into global chat
|
// For a command block, this would be the 'name' prepended to anything it outputs into global chat
|
||||||
// MCS doesn't have this, so just leave it @ '@'. (geddit?)
|
// MCS doesn't have this, so just leave it @ '@'. (geddit?)
|
||||||
|
@ -124,7 +124,7 @@ cRCONServer::cRCONServer(cServer & a_Server) :
|
|||||||
|
|
||||||
cRCONServer::~cRCONServer()
|
cRCONServer::~cRCONServer()
|
||||||
{
|
{
|
||||||
for (auto srv: m_ListenServers)
|
for (const auto & srv: m_ListenServers)
|
||||||
{
|
{
|
||||||
srv->Close();
|
srv->Close();
|
||||||
}
|
}
|
||||||
@ -153,7 +153,7 @@ void cRCONServer::Initialize(cSettingsRepositoryInterface & a_Settings)
|
|||||||
AStringVector Ports = ReadUpgradeIniPorts(a_Settings, "RCON", "Ports", "PortsIPv4", "PortsIPv6", "25575");
|
AStringVector Ports = ReadUpgradeIniPorts(a_Settings, "RCON", "Ports", "PortsIPv4", "PortsIPv6", "25575");
|
||||||
|
|
||||||
// Start listening on each specified port:
|
// Start listening on each specified port:
|
||||||
for (auto port: Ports)
|
for (const auto & port: Ports)
|
||||||
{
|
{
|
||||||
UInt16 PortNum;
|
UInt16 PortNum;
|
||||||
if (!StringToInteger(port, PortNum))
|
if (!StringToInteger(port, PortNum))
|
||||||
|
14
src/Root.cpp
14
src/Root.cpp
@ -473,7 +473,7 @@ void cRoot::LoadWorlds(cDeadlockDetect & a_dd, cSettingsRepositoryInterface & a_
|
|||||||
// Get the default world
|
// Get the default world
|
||||||
AString DefaultWorldName = a_Settings.GetValueSet("Worlds", "DefaultWorld", "world");
|
AString DefaultWorldName = a_Settings.GetValueSet("Worlds", "DefaultWorld", "world");
|
||||||
AString DefaultWorldPath = a_Settings.GetValueSet("WorldPaths", DefaultWorldName, DefaultWorldName);
|
AString DefaultWorldPath = a_Settings.GetValueSet("WorldPaths", DefaultWorldName, DefaultWorldName);
|
||||||
m_pDefaultWorld = new cWorld(DefaultWorldName.c_str(), DefaultWorldPath.c_str(), a_dd, WorldNames);
|
m_pDefaultWorld = new cWorld(DefaultWorldName, DefaultWorldPath, a_dd, WorldNames);
|
||||||
m_WorldsByName[ DefaultWorldName ] = m_pDefaultWorld;
|
m_WorldsByName[ DefaultWorldName ] = m_pDefaultWorld;
|
||||||
|
|
||||||
// Then load the other worlds
|
// Then load the other worlds
|
||||||
@ -505,7 +505,7 @@ void cRoot::LoadWorlds(cDeadlockDetect & a_dd, cSettingsRepositoryInterface & a_
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
bool FoundAdditionalWorlds = false;
|
bool FoundAdditionalWorlds = false;
|
||||||
for (auto WorldNameValue : Worlds)
|
for (const auto & WorldNameValue : Worlds)
|
||||||
{
|
{
|
||||||
AString ValueName = WorldNameValue.first;
|
AString ValueName = WorldNameValue.first;
|
||||||
if (ValueName.compare("World") != 0)
|
if (ValueName.compare("World") != 0)
|
||||||
@ -527,7 +527,7 @@ void cRoot::LoadWorlds(cDeadlockDetect & a_dd, cSettingsRepositoryInterface & a_
|
|||||||
|
|
||||||
// The default world is an overworld with no links
|
// The default world is an overworld with no links
|
||||||
eDimension Dimension = dimOverworld;
|
eDimension Dimension = dimOverworld;
|
||||||
AString LinkTo = "";
|
AString LinkTo;
|
||||||
|
|
||||||
// if the world is called x_nether
|
// if the world is called x_nether
|
||||||
if ((LowercaseName.size() > NetherAppend.size()) && (LowercaseName.substr(LowercaseName.size() - NetherAppend.size()) == NetherAppend))
|
if ((LowercaseName.size() > NetherAppend.size()) && (LowercaseName.substr(LowercaseName.size() - NetherAppend.size()) == NetherAppend))
|
||||||
@ -571,7 +571,7 @@ void cRoot::LoadWorlds(cDeadlockDetect & a_dd, cSettingsRepositoryInterface & a_
|
|||||||
}
|
}
|
||||||
Dimension = dimEnd;
|
Dimension = dimEnd;
|
||||||
}
|
}
|
||||||
NewWorld = new cWorld(WorldName.c_str(), WorldPath.c_str(), a_dd, WorldNames, Dimension, LinkTo);
|
NewWorld = new cWorld(WorldName, WorldPath, a_dd, WorldNames, Dimension, LinkTo);
|
||||||
m_WorldsByName[WorldName] = NewWorld;
|
m_WorldsByName[WorldName] = NewWorld;
|
||||||
} // for i - Worlds
|
} // for i - Worlds
|
||||||
|
|
||||||
@ -891,11 +891,7 @@ bool cRoot::FindAndDoWithPlayer(const AString & a_PlayerName, cPlayerListCallbac
|
|||||||
m_BestRating = Rating;
|
m_BestRating = Rating;
|
||||||
++m_NumMatches;
|
++m_NumMatches;
|
||||||
}
|
}
|
||||||
if (Rating == m_NameLength) // Perfect match
|
return (Rating == m_NameLength); // Perfect match
|
||||||
{
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
return false;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
cCallback (const AString & a_CBPlayerName) :
|
cCallback (const AString & a_CBPlayerName) :
|
||||||
|
@ -289,10 +289,10 @@ const AStringMap & cServer::GetRegisteredForgeMods(const UInt32 a_Protocol)
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
bool cServer::IsPlayerInQueue(AString a_Username)
|
bool cServer::IsPlayerInQueue(const AString & a_Username)
|
||||||
{
|
{
|
||||||
cCSLock Lock(m_CSClients);
|
cCSLock Lock(m_CSClients);
|
||||||
for (auto client : m_Clients)
|
for (const auto & client : m_Clients)
|
||||||
{
|
{
|
||||||
if ((client->GetUsername()).compare(a_Username) == 0)
|
if ((client->GetUsername()).compare(a_Username) == 0)
|
||||||
{
|
{
|
||||||
@ -403,7 +403,7 @@ void cServer::TickClients(float a_Dt)
|
|||||||
|
|
||||||
bool cServer::Start(void)
|
bool cServer::Start(void)
|
||||||
{
|
{
|
||||||
for (auto port: m_Ports)
|
for (const auto & port: m_Ports)
|
||||||
{
|
{
|
||||||
UInt16 PortNum;
|
UInt16 PortNum;
|
||||||
if (!StringToInteger(port, PortNum))
|
if (!StringToInteger(port, PortNum))
|
||||||
@ -422,11 +422,7 @@ bool cServer::Start(void)
|
|||||||
LOGERROR("Couldn't open any ports. Aborting the server");
|
LOGERROR("Couldn't open any ports. Aborting the server");
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
if (!m_TickThread.Start())
|
return m_TickThread.Start();
|
||||||
{
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
return true;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -636,7 +632,7 @@ void cServer::BindBuiltInConsoleCommands(void)
|
|||||||
void cServer::Shutdown(void)
|
void cServer::Shutdown(void)
|
||||||
{
|
{
|
||||||
// Stop listening on all sockets:
|
// Stop listening on all sockets:
|
||||||
for (auto srv: m_ServerHandles)
|
for (const auto & srv: m_ServerHandles)
|
||||||
{
|
{
|
||||||
srv->Close();
|
srv->Close();
|
||||||
}
|
}
|
||||||
|
@ -83,7 +83,7 @@ public:
|
|||||||
|
|
||||||
/** Check if the player is queued to be transferred to a World.
|
/** Check if the player is queued to be transferred to a World.
|
||||||
Returns true is Player is found in queue. */
|
Returns true is Player is found in queue. */
|
||||||
bool IsPlayerInQueue(AString a_Username);
|
bool IsPlayerInQueue(const AString & a_Username);
|
||||||
|
|
||||||
/** Can login more than once with same username.
|
/** Can login more than once with same username.
|
||||||
Returns false if it is not allowed, true otherwise. */
|
Returns false if it is not allowed, true otherwise. */
|
||||||
|
@ -527,11 +527,7 @@ static bool isLegalUTF8(const unsigned char * source, int length)
|
|||||||
}
|
}
|
||||||
case 1: if ((*source >= 0x80) && (*source < 0xc2)) return false;
|
case 1: if ((*source >= 0x80) && (*source < 0xc2)) return false;
|
||||||
}
|
}
|
||||||
if (*source > 0xf4)
|
return (*source <= 0xf4);
|
||||||
{
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
return true;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -1052,7 +1048,7 @@ AStringVector MergeStringVectors(const AStringVector & a_Strings1, const AString
|
|||||||
AStringVector res = a_Strings1;
|
AStringVector res = a_Strings1;
|
||||||
|
|
||||||
// Add each item from strings2 that is not already present:
|
// Add each item from strings2 that is not already present:
|
||||||
for (auto item : a_Strings2)
|
for (const auto & item : a_Strings2)
|
||||||
{
|
{
|
||||||
if (std::find(res.begin(), res.end(), item) == res.end())
|
if (std::find(res.begin(), res.end(), item) == res.end())
|
||||||
{
|
{
|
||||||
@ -1094,11 +1090,7 @@ bool StringToFloat(const AString & a_String, float & a_Num)
|
|||||||
{
|
{
|
||||||
char *err;
|
char *err;
|
||||||
a_Num = strtof(a_String.c_str(), &err);
|
a_Num = strtof(a_String.c_str(), &err);
|
||||||
if (*err != 0)
|
return (*err == 0);
|
||||||
{
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
return true;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -2297,7 +2297,6 @@ void cSlotAreaInventoryBase::Clicked(cPlayer & a_Player, int a_SlotNum, eClickAc
|
|||||||
|
|
||||||
// Survival inventory and all other windows' inventory has the same handling as normal slot areas
|
// Survival inventory and all other windows' inventory has the same handling as normal slot areas
|
||||||
Super::Clicked(a_Player, a_SlotNum, a_ClickAction, a_ClickedItem);
|
Super::Clicked(a_Player, a_SlotNum, a_ClickAction, a_ClickedItem);
|
||||||
return;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -167,7 +167,7 @@ bool cWebAdmin::LoadLoginPage(void)
|
|||||||
void cWebAdmin::RemoveAllPluginWebTabs(const AString & a_PluginName)
|
void cWebAdmin::RemoveAllPluginWebTabs(const AString & a_PluginName)
|
||||||
{
|
{
|
||||||
cCSLock lock(m_CS);
|
cCSLock lock(m_CS);
|
||||||
m_WebTabs.erase(std::remove_if(m_WebTabs.begin(), m_WebTabs.end(), [=](cWebTabPtr a_CBWebTab)
|
m_WebTabs.erase(std::remove_if(m_WebTabs.begin(), m_WebTabs.end(), [=](const cWebTabPtr & a_CBWebTab)
|
||||||
{
|
{
|
||||||
return (a_CBWebTab->m_PluginName == a_PluginName);
|
return (a_CBWebTab->m_PluginName == a_PluginName);
|
||||||
}),
|
}),
|
||||||
@ -519,7 +519,7 @@ void cWebAdmin::AddWebTab(
|
|||||||
)
|
)
|
||||||
{
|
{
|
||||||
cCSLock lock(m_CS);
|
cCSLock lock(m_CS);
|
||||||
m_WebTabs.emplace_back(std::make_shared<cWebTab>(a_Title, a_UrlPath, a_PluginName, a_Callback));
|
m_WebTabs.emplace_back(std::make_shared<cWebTab>(a_Title, a_UrlPath, a_PluginName, std::move(a_Callback)));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -140,7 +140,7 @@ public:
|
|||||||
m_Title(a_Title),
|
m_Title(a_Title),
|
||||||
m_UrlPath(a_UrlPath),
|
m_UrlPath(a_UrlPath),
|
||||||
m_PluginName(a_PluginName),
|
m_PluginName(a_PluginName),
|
||||||
m_Callback(a_Callback)
|
m_Callback(std::move(a_Callback))
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
@ -1206,11 +1206,8 @@ void cWorld::TickQueuedTasks(void)
|
|||||||
// Partition everything to be executed by returning false to move to end of list if time reached
|
// Partition everything to be executed by returning false to move to end of list if time reached
|
||||||
auto MoveBeginIterator = std::partition(m_Tasks.begin(), m_Tasks.end(), [this](const decltype(m_Tasks)::value_type & a_Task)
|
auto MoveBeginIterator = std::partition(m_Tasks.begin(), m_Tasks.end(), [this](const decltype(m_Tasks)::value_type & a_Task)
|
||||||
{
|
{
|
||||||
if (a_Task.first < std::chrono::duration_cast<cTickTimeLong>(m_WorldAge).count())
|
const auto WorldAgeTicks = std::chrono::duration_cast<cTickTimeLong>(m_WorldAge).count();
|
||||||
{
|
return (a_Task.first >= WorldAgeTicks);
|
||||||
return false;
|
|
||||||
}
|
|
||||||
return true;
|
|
||||||
}
|
}
|
||||||
);
|
);
|
||||||
|
|
||||||
@ -3061,7 +3058,7 @@ void cWorld::QueueSaveAllChunks(void)
|
|||||||
void cWorld::QueueTask(std::function<void(cWorld &)> a_Task)
|
void cWorld::QueueTask(std::function<void(cWorld &)> a_Task)
|
||||||
{
|
{
|
||||||
cCSLock Lock(m_CSTasks);
|
cCSLock Lock(m_CSTasks);
|
||||||
m_Tasks.emplace_back(0, a_Task);
|
m_Tasks.emplace_back(0, std::move(a_Task));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -3075,7 +3072,7 @@ void cWorld::ScheduleTask(int a_DelayTicks, std::function<void (cWorld &)> a_Tas
|
|||||||
// Insert the task into the list of scheduled tasks
|
// Insert the task into the list of scheduled tasks
|
||||||
{
|
{
|
||||||
cCSLock Lock(m_CSTasks);
|
cCSLock Lock(m_CSTasks);
|
||||||
m_Tasks.emplace_back(TargetTick, a_Task);
|
m_Tasks.emplace_back(TargetTick, std::move(a_Task));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2496,7 +2496,7 @@ void cWSSAnvil::LoadOcelotFromNBT(cEntityList & a_Entities, const cParsedNBT & a
|
|||||||
int SittingIdx = a_NBT.FindChildByName(a_TagIdx, "Sitting");
|
int SittingIdx = a_NBT.FindChildByName(a_TagIdx, "Sitting");
|
||||||
if ((SittingIdx > 0) && (a_NBT.GetType(SittingIdx) == TAG_Byte))
|
if ((SittingIdx > 0) && (a_NBT.GetType(SittingIdx) == TAG_Byte))
|
||||||
{
|
{
|
||||||
bool Sitting = ((a_NBT.GetByte(SittingIdx) == 1) ? true : false);
|
bool Sitting = (a_NBT.GetByte(SittingIdx) == 1);
|
||||||
Monster->SetIsSitting(Sitting);
|
Monster->SetIsSitting(Sitting);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -2915,13 +2915,13 @@ void cWSSAnvil::LoadWolfFromNBT(cEntityList & a_Entities, const cParsedNBT & a_N
|
|||||||
int SittingIdx = a_NBT.FindChildByName(a_TagIdx, "Sitting");
|
int SittingIdx = a_NBT.FindChildByName(a_TagIdx, "Sitting");
|
||||||
if ((SittingIdx > 0) && (a_NBT.GetType(SittingIdx) == TAG_Byte))
|
if ((SittingIdx > 0) && (a_NBT.GetType(SittingIdx) == TAG_Byte))
|
||||||
{
|
{
|
||||||
bool Sitting = ((a_NBT.GetByte(SittingIdx) == 1) ? true : false);
|
bool Sitting = (a_NBT.GetByte(SittingIdx) == 1);
|
||||||
Monster->SetIsSitting(Sitting);
|
Monster->SetIsSitting(Sitting);
|
||||||
}
|
}
|
||||||
int AngryIdx = a_NBT.FindChildByName(a_TagIdx, "Angry");
|
int AngryIdx = a_NBT.FindChildByName(a_TagIdx, "Angry");
|
||||||
if ((AngryIdx > 0) && (a_NBT.GetType(AngryIdx) == TAG_Byte))
|
if ((AngryIdx > 0) && (a_NBT.GetType(AngryIdx) == TAG_Byte))
|
||||||
{
|
{
|
||||||
bool Angry = ((a_NBT.GetByte(AngryIdx) == 1) ? true : false);
|
bool Angry = (a_NBT.GetByte(AngryIdx) == 1);
|
||||||
Monster->SetIsAngry(Angry);
|
Monster->SetIsAngry(Angry);
|
||||||
}
|
}
|
||||||
int CollarColorIdx = a_NBT.FindChildByName(a_TagIdx, "CollarColor");
|
int CollarColorIdx = a_NBT.FindChildByName(a_TagIdx, "CollarColor");
|
||||||
@ -3518,7 +3518,7 @@ bool cWSSAnvil::cMCAFile::GetChunkData(const cChunkCoords & a_Chunk, AString & a
|
|||||||
if (CompressionType != 2)
|
if (CompressionType != 2)
|
||||||
{
|
{
|
||||||
// Chunk is in an unknown compression
|
// Chunk is in an unknown compression
|
||||||
m_ParentSchema.ChunkLoadFailed(a_Chunk.m_ChunkX, a_Chunk.m_ChunkZ, Printf("Unknown chunk compression: %d", CompressionType).c_str(), a_Data);
|
m_ParentSchema.ChunkLoadFailed(a_Chunk.m_ChunkX, a_Chunk.m_ChunkZ, Printf("Unknown chunk compression: %d", CompressionType), a_Data);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
return true;
|
return true;
|
||||||
|
@ -356,7 +356,7 @@ void cBlockingSslClientSocket::OnReceivedData(const char * a_Data, size_t a_Size
|
|||||||
|
|
||||||
void cBlockingSslClientSocket::SetLink(cTCPLinkPtr a_Link)
|
void cBlockingSslClientSocket::SetLink(cTCPLinkPtr a_Link)
|
||||||
{
|
{
|
||||||
m_Socket = a_Link;
|
m_Socket = std::move(a_Link);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -41,7 +41,7 @@ int cSslContext::Initialize(std::shared_ptr<const cSslConfig> a_Config)
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Check the Config:
|
// Check the Config:
|
||||||
m_Config = a_Config;
|
m_Config = std::move(a_Config);
|
||||||
if (m_Config == nullptr)
|
if (m_Config == nullptr)
|
||||||
{
|
{
|
||||||
ASSERT(!"Config must not be nullptr");
|
ASSERT(!"Config must not be nullptr");
|
||||||
|
Loading…
Reference in New Issue
Block a user