1
0

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:
peterbell10 2020-05-14 23:15:35 +01:00 committed by GitHub
parent edb548f9d6
commit 13144a08e4
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
100 changed files with 286 additions and 297 deletions

View File

@ -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
View 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

View File

@ -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'

View 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

View File

@ -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);
} }

View File

@ -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());

View File

@ -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);

View File

@ -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();
} }

View File

@ -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;
} }

View File

@ -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)

View File

@ -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")

View File

@ -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;
} }

View File

@ -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

View File

@ -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;
}
} }

View File

@ -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",

View File

@ -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
); );
}; };

View File

@ -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))
{ {

View File

@ -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

View File

@ -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;
} }

View File

@ -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);

View File

@ -1749,8 +1749,6 @@ void cChunk::RemoveClient(cClientHandle * a_Client)
a_Client->SendDestroyEntity(*Entity); a_Client->SendDestroyEntity(*Entity);
} }
} }
return;
} }

View File

@ -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);
} }

View File

@ -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

View File

@ -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();

View File

@ -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;
} }

View File

@ -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)
{ {

View File

@ -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);

View File

@ -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;
} }

View File

@ -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;
} }

View File

@ -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;
} }

View File

@ -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;

View File

@ -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;
} }

View File

@ -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);
} }

View File

@ -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;

View File

@ -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)]),

View File

@ -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
) )
{ {

View File

@ -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
); );
} ; } ;

View File

@ -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))
{ {
} }

View File

@ -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

View File

@ -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];

View File

@ -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)

View File

@ -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++)

View File

@ -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);

View File

@ -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())

View File

@ -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))
{ {
} }

View File

@ -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:

View File

@ -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

View File

@ -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, "|");

View File

@ -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;

View File

@ -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))
{ {
} }

View File

@ -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))
{ {
} }

View File

@ -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
) )

View File

@ -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)
{ {
} }

View File

@ -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;

View File

@ -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);
} }

View File

@ -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);

View File

@ -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)
{ {

View File

@ -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; }

View File

@ -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();
} }

View File

@ -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)
{ {

View File

@ -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;

View File

@ -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
) )
{ {

View File

@ -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()
); );

View File

@ -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)
{ {

View File

@ -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))
{ {

View File

@ -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);

View File

@ -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);

View File

@ -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());
} }

View File

@ -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))
{ {
} }

View File

@ -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;
} }

View File

@ -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))

View File

@ -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
} }

View File

@ -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:
{ {

View File

@ -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();

View File

@ -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)

View File

@ -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;
} }

View File

@ -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)
{ {
} }

View File

@ -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);
} }

View File

@ -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))
{ {
} }
}; };

View File

@ -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);

View File

@ -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. */

View File

@ -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));
} }

View File

@ -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);
} }

View File

@ -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);
} }

View File

@ -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?)

View File

@ -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?)

View File

@ -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?)

View File

@ -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?)

View File

@ -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))

View File

@ -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) :

View File

@ -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();
} }

View File

@ -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. */

View File

@ -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;
} }

View File

@ -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;
} }

View File

@ -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)));
} }

View File

@ -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))
{ {
} }
}; };

View File

@ -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));
} }
} }

View File

@ -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;

View File

@ -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);
} }

View File

@ -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");