浏览代码

Fixed potentially uninitialized class member

Ivan Savenko 1 年之前
父节点
当前提交
dd88220b7c
共有 4 个文件被更改,包括 8 次插入8 次删除
  1. 5 0
      lib/CGameInfoCallback.cpp
  2. 1 1
      lib/CGameInfoCallback.h
  3. 1 5
      server/CGameHandler.cpp
  4. 1 2
      server/CGameHandler.h

+ 5 - 0
lib/CGameInfoCallback.cpp

@@ -721,6 +721,11 @@ bool CGameInfoCallback::isPlayerMakingTurn(PlayerColor player) const
 	return gs->actingPlayers.count(player);
 	return gs->actingPlayers.count(player);
 }
 }
 
 
+CGameInfoCallback::CGameInfoCallback():
+	gs(nullptr)
+{
+}
+
 CGameInfoCallback::CGameInfoCallback(CGameState * GS):
 CGameInfoCallback::CGameInfoCallback(CGameState * GS):
 	gs(GS)
 	gs(GS)
 {
 {

+ 1 - 1
lib/CGameInfoCallback.h

@@ -134,7 +134,7 @@ class DLL_LINKAGE CGameInfoCallback : public IGameInfoCallback
 protected:
 protected:
 	CGameState * gs;//todo: replace with protected const getter, only actual Server and Client objects should hold game state
 	CGameState * gs;//todo: replace with protected const getter, only actual Server and Client objects should hold game state
 
 
-	CGameInfoCallback() = default;
+	CGameInfoCallback();
 	CGameInfoCallback(CGameState * GS);
 	CGameInfoCallback(CGameState * GS);
 	bool hasAccess(std::optional<PlayerColor> playerId) const;
 	bool hasAccess(std::optional<PlayerColor> playerId) const;
 
 

+ 1 - 5
server/CGameHandler.cpp

@@ -489,11 +489,6 @@ void CGameHandler::handleReceivedPack(CPackForServer * pack)
 	vstd::clear_pointer(pack);
 	vstd::clear_pointer(pack);
 }
 }
 
 
-
-CGameHandler::CGameHandler()
-	: turnTimerHandler(*this)
-{}
-
 CGameHandler::CGameHandler(CVCMIServer * lobby)
 CGameHandler::CGameHandler(CVCMIServer * lobby)
 	: lobby(lobby)
 	: lobby(lobby)
 	, heroPool(std::make_unique<HeroPoolProcessor>(this))
 	, heroPool(std::make_unique<HeroPoolProcessor>(this))
@@ -518,6 +513,7 @@ CGameHandler::~CGameHandler()
 {
 {
 	delete spellEnv;
 	delete spellEnv;
 	delete gs;
 	delete gs;
+	gs = nullptr;
 }
 }
 
 
 void CGameHandler::reinitScripting()
 void CGameHandler::reinitScripting()

+ 1 - 2
server/CGameHandler.h

@@ -92,8 +92,7 @@ public:
 	bool isAllowedExchange(ObjectInstanceID id1, ObjectInstanceID id2);
 	bool isAllowedExchange(ObjectInstanceID id1, ObjectInstanceID id2);
 	void giveSpells(const CGTownInstance *t, const CGHeroInstance *h);
 	void giveSpells(const CGTownInstance *t, const CGHeroInstance *h);
 
 
-	CGameHandler();
-	CGameHandler(CVCMIServer * lobby);
+	explicit CGameHandler(CVCMIServer * lobby);
 	~CGameHandler();
 	~CGameHandler();
 
 
 	//////////////////////////////////////////////////////////////////////////
 	//////////////////////////////////////////////////////////////////////////