Fixed the way connecting clients receive player lists and broadcast chat to worlds
This commit is contained in:
parent
e7214dff65
commit
c8b1778847
@ -382,7 +382,7 @@ void cClientHandle::Authenticate(const AString & a_Name, const AString & a_UUID,
|
|||||||
// Send player list items
|
// Send player list items
|
||||||
SendPlayerListAddPlayer(*m_Player);
|
SendPlayerListAddPlayer(*m_Player);
|
||||||
World->BroadcastPlayerListAddPlayer(*m_Player);
|
World->BroadcastPlayerListAddPlayer(*m_Player);
|
||||||
World->SendPlayerList(m_Player);
|
cRoot::Get()->SendPlayerLists(m_Player);
|
||||||
|
|
||||||
m_Player->Initialize(*World);
|
m_Player->Initialize(*World);
|
||||||
m_State = csAuthenticated;
|
m_State = csAuthenticated;
|
||||||
@ -1475,7 +1475,7 @@ void cClientHandle::HandleChat(const AString & a_Message)
|
|||||||
Msg.AddTextPart(AString("<") + m_Player->GetName() + "> ", Color);
|
Msg.AddTextPart(AString("<") + m_Player->GetName() + "> ", Color);
|
||||||
Msg.ParseText(Message);
|
Msg.ParseText(Message);
|
||||||
Msg.UnderlineUrls();
|
Msg.UnderlineUrls();
|
||||||
m_Player->GetWorld()->BroadcastChat(Msg);
|
cRoot::Get()->BroadcastChat(Msg);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
10
src/Root.cpp
10
src/Root.cpp
@ -558,6 +558,14 @@ void cRoot::SaveAllChunks(void)
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
void cRoot::SendPlayerLists(cPlayer * a_DestPlayer)
|
||||||
|
{
|
||||||
|
for (WorldMap::iterator itr = m_WorldsByName.begin(), end = m_WorldsByName.end(); itr != end; ++itr)
|
||||||
|
{
|
||||||
|
itr->second->SendPlayerList(a_DestPlayer);
|
||||||
|
} // for itr - m_WorldsByName[]
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
void cRoot::BroadcastChat(const AString & a_Message, eMessageType a_ChatPrefix)
|
void cRoot::BroadcastChat(const AString & a_Message, eMessageType a_ChatPrefix)
|
||||||
@ -582,8 +590,6 @@ void cRoot::BroadcastChat(const cCompositeChat & a_Message)
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
bool cRoot::ForEachPlayer(cPlayerListCallback & a_Callback)
|
bool cRoot::ForEachPlayer(cPlayerListCallback & a_Callback)
|
||||||
{
|
{
|
||||||
for (WorldMap::iterator itr = m_WorldsByName.begin(), itr2 = itr; itr != m_WorldsByName.end(); itr = itr2)
|
for (WorldMap::iterator itr = m_WorldsByName.begin(), itr2 = itr; itr != m_WorldsByName.end(); itr = itr2)
|
||||||
|
@ -145,6 +145,10 @@ public:
|
|||||||
/** Finds the player using it's complete username and calls the callback */
|
/** Finds the player using it's complete username and calls the callback */
|
||||||
bool DoWithPlayer(const AString & a_PlayerName, cPlayerListCallback & a_Callback);
|
bool DoWithPlayer(const AString & a_PlayerName, cPlayerListCallback & a_Callback);
|
||||||
|
|
||||||
|
/** Send playerlist of all worlds to player */
|
||||||
|
void SendPlayerLists(cPlayer * a_DestPlayer);
|
||||||
|
|
||||||
|
|
||||||
// tolua_begin
|
// tolua_begin
|
||||||
|
|
||||||
/// Sends a chat message to all connected clients (in all worlds)
|
/// Sends a chat message to all connected clients (in all worlds)
|
||||||
|
Loading…
Reference in New Issue
Block a user