ClientInterface::getClientIDs doesn't need a std::list. Use a std::vector for better perfs
This commit is contained in:
parent
7e088fdfe3
commit
2066655aae
@ -560,9 +560,9 @@ ClientInterface::~ClientInterface()
|
||||
}
|
||||
}
|
||||
|
||||
std::list<u16> ClientInterface::getClientIDs(ClientState min_state)
|
||||
std::vector<u16> ClientInterface::getClientIDs(ClientState min_state)
|
||||
{
|
||||
std::list<u16> reply;
|
||||
std::vector<u16> reply;
|
||||
JMutexAutoLock clientslock(m_clients_mutex);
|
||||
|
||||
for(std::map<u16, RemoteClient*>::iterator
|
||||
@ -596,20 +596,22 @@ void ClientInterface::UpdatePlayerList()
|
||||
{
|
||||
if (m_env != NULL)
|
||||
{
|
||||
std::list<u16> clients = getClientIDs();
|
||||
std::vector<u16> clients = getClientIDs();
|
||||
m_clients_names.clear();
|
||||
|
||||
|
||||
if(!clients.empty())
|
||||
infostream<<"Players:"<<std::endl;
|
||||
for(std::list<u16>::iterator
|
||||
|
||||
for(std::vector<u16>::iterator
|
||||
i = clients.begin();
|
||||
i != clients.end(); ++i)
|
||||
{
|
||||
i != clients.end(); ++i) {
|
||||
Player *player = m_env->getPlayer(*i);
|
||||
if(player==NULL)
|
||||
|
||||
if (player == NULL)
|
||||
continue;
|
||||
infostream<<"* "<<player->getName()<<"\t";
|
||||
|
||||
infostream << "* " << player->getName() << "\t";
|
||||
|
||||
{
|
||||
JMutexAutoLock clientslock(m_clients_mutex);
|
||||
@ -617,6 +619,7 @@ void ClientInterface::UpdatePlayerList()
|
||||
if(client != NULL)
|
||||
client->PrintInfo(infostream);
|
||||
}
|
||||
|
||||
m_clients_names.push_back(player->getName());
|
||||
}
|
||||
}
|
||||
|
@ -388,7 +388,7 @@ public:
|
||||
void step(float dtime);
|
||||
|
||||
/* get list of active client id's */
|
||||
std::list<u16> getClientIDs(ClientState min_state=CS_Active);
|
||||
std::vector<u16> getClientIDs(ClientState min_state=CS_Active);
|
||||
|
||||
/* get list of client player names */
|
||||
std::vector<std::string> getPlayerNames();
|
||||
|
@ -851,10 +851,9 @@ void Server::handleCommand_ChatMessage(NetworkPacket* pkt)
|
||||
else {
|
||||
actionstream << "CHAT: " << wide_to_narrow(line)<<std::endl;
|
||||
|
||||
std::list<u16> clients = m_clients.getClientIDs();
|
||||
std::vector<u16> clients = m_clients.getClientIDs();
|
||||
|
||||
for (std::list<u16>::iterator
|
||||
i = clients.begin();
|
||||
for (std::vector<u16>::iterator i = clients.begin();
|
||||
i != clients.end(); ++i) {
|
||||
if (*i != pkt->getPeerId())
|
||||
SendChatMessage(*i, line);
|
||||
|
102
src/server.cpp
102
src/server.cpp
@ -1374,16 +1374,14 @@ void Server::setInventoryModified(const InventoryLocation &loc)
|
||||
|
||||
void Server::SetBlocksNotSent(std::map<v3s16, MapBlock *>& block)
|
||||
{
|
||||
std::list<u16> clients = m_clients.getClientIDs();
|
||||
std::vector<u16> clients = m_clients.getClientIDs();
|
||||
m_clients.Lock();
|
||||
// Set the modified blocks unsent for all the clients
|
||||
for (std::list<u16>::iterator
|
||||
i = clients.begin();
|
||||
for (std::vector<u16>::iterator i = clients.begin();
|
||||
i != clients.end(); ++i) {
|
||||
RemoteClient *client = m_clients.lockedGetClientNoEx(*i);
|
||||
if (client != NULL)
|
||||
if (RemoteClient *client = m_clients.lockedGetClientNoEx(*i))
|
||||
client->SetBlocksNotSent(block);
|
||||
}
|
||||
}
|
||||
m_clients.Unlock();
|
||||
}
|
||||
|
||||
@ -1954,15 +1952,15 @@ s32 Server::playSound(const SimpleSoundSpec &spec,
|
||||
}
|
||||
else
|
||||
{
|
||||
std::list<u16> clients = m_clients.getClientIDs();
|
||||
std::vector<u16> clients = m_clients.getClientIDs();
|
||||
|
||||
for(std::list<u16>::iterator
|
||||
i = clients.begin(); i != clients.end(); ++i)
|
||||
{
|
||||
for(std::vector<u16>::iterator
|
||||
i = clients.begin(); i != clients.end(); ++i) {
|
||||
Player *player = m_env->getPlayer(*i);
|
||||
if(!player)
|
||||
continue;
|
||||
if(pos_exists){
|
||||
|
||||
if(pos_exists) {
|
||||
if(player->getPosition().getDistanceFrom(pos) >
|
||||
params.max_hear_distance)
|
||||
continue;
|
||||
@ -1970,6 +1968,7 @@ s32 Server::playSound(const SimpleSoundSpec &spec,
|
||||
dst_clients.push_back(*i);
|
||||
}
|
||||
}
|
||||
|
||||
if(dst_clients.empty())
|
||||
return -1;
|
||||
|
||||
@ -2025,9 +2024,8 @@ void Server::sendRemoveNode(v3s16 p, u16 ignore_id,
|
||||
NetworkPacket* pkt = new NetworkPacket(TOCLIENT_REMOVENODE, 6);
|
||||
*pkt << p;
|
||||
|
||||
std::list<u16> clients = m_clients.getClientIDs();
|
||||
for(std::list<u16>::iterator
|
||||
i = clients.begin();
|
||||
std::vector<u16> clients = m_clients.getClientIDs();
|
||||
for(std::vector<u16>::iterator i = clients.begin();
|
||||
i != clients.end(); ++i) {
|
||||
if(far_players) {
|
||||
// Get player
|
||||
@ -2055,22 +2053,16 @@ void Server::sendAddNode(v3s16 p, MapNode n, u16 ignore_id,
|
||||
float maxd = far_d_nodes*BS;
|
||||
v3f p_f = intToFloat(p, BS);
|
||||
|
||||
std::list<u16> clients = m_clients.getClientIDs();
|
||||
for(std::list<u16>::iterator
|
||||
i = clients.begin();
|
||||
i != clients.end(); ++i)
|
||||
{
|
||||
std::vector<u16> clients = m_clients.getClientIDs();
|
||||
for(std::vector<u16>::iterator i = clients.begin();
|
||||
i != clients.end(); ++i) {
|
||||
|
||||
if(far_players)
|
||||
{
|
||||
if(far_players) {
|
||||
// Get player
|
||||
Player *player = m_env->getPlayer(*i);
|
||||
if(player)
|
||||
{
|
||||
if(Player *player = m_env->getPlayer(*i)) {
|
||||
// If player is far away, only set modified blocks not sent
|
||||
v3f player_pos = player->getPosition();
|
||||
if(player_pos.getDistanceFrom(p_f) > maxd)
|
||||
{
|
||||
if(player_pos.getDistanceFrom(p_f) > maxd) {
|
||||
far_players->push_back(*i);
|
||||
continue;
|
||||
}
|
||||
@ -2102,12 +2094,10 @@ void Server::sendAddNode(v3s16 p, MapNode n, u16 ignore_id,
|
||||
|
||||
void Server::setBlockNotSent(v3s16 p)
|
||||
{
|
||||
std::list<u16> clients = m_clients.getClientIDs();
|
||||
std::vector<u16> clients = m_clients.getClientIDs();
|
||||
m_clients.Lock();
|
||||
for(std::list<u16>::iterator
|
||||
i = clients.begin();
|
||||
i != clients.end(); ++i)
|
||||
{
|
||||
for(std::vector<u16>::iterator i = clients.begin();
|
||||
i != clients.end(); ++i) {
|
||||
RemoteClient *client = m_clients.lockedGetClientNoEx(*i);
|
||||
client->SetBlockNotSent(p);
|
||||
}
|
||||
@ -2153,13 +2143,11 @@ void Server::SendBlocks(float dtime)
|
||||
{
|
||||
ScopeProfiler sp(g_profiler, "Server: selecting blocks for sending");
|
||||
|
||||
std::list<u16> clients = m_clients.getClientIDs();
|
||||
std::vector<u16> clients = m_clients.getClientIDs();
|
||||
|
||||
m_clients.Lock();
|
||||
for(std::list<u16>::iterator
|
||||
i = clients.begin();
|
||||
i != clients.end(); ++i)
|
||||
{
|
||||
for(std::vector<u16>::iterator i = clients.begin();
|
||||
i != clients.end(); ++i) {
|
||||
RemoteClient *client = m_clients.lockedGetClientNoEx(*i, CS_Active);
|
||||
|
||||
if (client == NULL)
|
||||
@ -2630,26 +2618,24 @@ void Server::DeleteClient(u16 peer_id, ClientDeletionReason reason)
|
||||
Print out action
|
||||
*/
|
||||
{
|
||||
if(player != NULL && reason != CDR_DENY)
|
||||
{
|
||||
if(player != NULL && reason != CDR_DENY) {
|
||||
std::ostringstream os(std::ios_base::binary);
|
||||
std::list<u16> clients = m_clients.getClientIDs();
|
||||
std::vector<u16> clients = m_clients.getClientIDs();
|
||||
|
||||
for(std::list<u16>::iterator
|
||||
i = clients.begin();
|
||||
i != clients.end(); ++i)
|
||||
{
|
||||
for(std::vector<u16>::iterator i = clients.begin();
|
||||
i != clients.end(); ++i) {
|
||||
// Get player
|
||||
Player *player = m_env->getPlayer(*i);
|
||||
if(!player)
|
||||
continue;
|
||||
|
||||
// Get name of player
|
||||
os<<player->getName()<<" ";
|
||||
os << player->getName() << " ";
|
||||
}
|
||||
|
||||
actionstream<<player->getName()<<" "
|
||||
<<(reason==CDR_TIMEOUT?"times out.":"leaves game.")
|
||||
<<" List of players: "<<os.str()<<std::endl;
|
||||
actionstream << player->getName() << " "
|
||||
<< (reason == CDR_TIMEOUT ? "times out." : "leaves game.")
|
||||
<< " List of players: " << os.str() << std::endl;
|
||||
}
|
||||
}
|
||||
{
|
||||
@ -2723,10 +2709,9 @@ std::wstring Server::getStatusString()
|
||||
// Information about clients
|
||||
bool first = true;
|
||||
os<<L", clients={";
|
||||
std::list<u16> clients = m_clients.getClientIDs();
|
||||
for(std::list<u16>::iterator i = clients.begin();
|
||||
i != clients.end(); ++i)
|
||||
{
|
||||
std::vector<u16> clients = m_clients.getClientIDs();
|
||||
for(std::vector<u16>::iterator i = clients.begin();
|
||||
i != clients.end(); ++i) {
|
||||
// Get player
|
||||
Player *player = m_env->getPlayer(*i);
|
||||
// Get name of player
|
||||
@ -2735,12 +2720,12 @@ std::wstring Server::getStatusString()
|
||||
name = narrow_to_wide(player->getName());
|
||||
// Add name to information string
|
||||
if(!first)
|
||||
os<<L", ";
|
||||
os << L", ";
|
||||
else
|
||||
first = false;
|
||||
os<<name;
|
||||
os << name;
|
||||
}
|
||||
os<<L"}";
|
||||
os << L"}";
|
||||
if(((ServerMap*)(&m_env->getMap()))->isSavingEnabled() == false)
|
||||
os<<std::endl<<L"# Server: "<<" WARNING: Map saving is disabled.";
|
||||
if(g_settings->get("motd") != "")
|
||||
@ -2763,11 +2748,10 @@ bool Server::checkPriv(const std::string &name, const std::string &priv)
|
||||
|
||||
void Server::reportPrivsModified(const std::string &name)
|
||||
{
|
||||
if(name == ""){
|
||||
std::list<u16> clients = m_clients.getClientIDs();
|
||||
for(std::list<u16>::iterator
|
||||
i = clients.begin();
|
||||
i != clients.end(); ++i){
|
||||
if(name == "") {
|
||||
std::vector<u16> clients = m_clients.getClientIDs();
|
||||
for(std::vector<u16>::iterator i = clients.begin();
|
||||
i != clients.end(); ++i) {
|
||||
Player *player = m_env->getPlayer(*i);
|
||||
reportPrivsModified(player->getName());
|
||||
}
|
||||
|
Loading…
x
Reference in New Issue
Block a user