Merge pull request #229 from Salanto/option/tsu-playerids
Switch queue with stack
This commit is contained in:
		
						commit
						ef85d6d5ad
					
				| @ -201,10 +201,10 @@ class Server : public QObject { | ||||
|     QHash<int,AOClient*> m_clients_ids; | ||||
| 
 | ||||
|     /**
 | ||||
|      * @brief Queue of all available IDs for clients. When this is empty the server | ||||
|      * @brief Stack of all available IDs for clients. When this is empty the server | ||||
|      * rejects any new connection attempt. | ||||
|      */ | ||||
|     QQueue<int> m_available_ids; | ||||
|     QStack<int> m_available_ids; | ||||
| 
 | ||||
|     /**
 | ||||
|      * @brief The overall player count in the server. | ||||
|  | ||||
| @ -119,8 +119,8 @@ void Server::start() | ||||
|     connect(&next_message_timer, &QTimer::timeout, this, &Server::allowMessage); | ||||
| 
 | ||||
|     //Prepare player IDs and reference hash.
 | ||||
|     for (int i = 0; i <= ConfigManager::maxPlayers() - 1; i++){ | ||||
|         m_available_ids.enqueue(i); | ||||
|     for (int i = ConfigManager::maxPlayers() -1; i >= 0; i--){ | ||||
|         m_available_ids.push(i); | ||||
|         m_clients_ids.insert(i, nullptr); | ||||
|     } | ||||
| } | ||||
| @ -140,7 +140,7 @@ void Server::clientConnected() | ||||
|         return; | ||||
|     } | ||||
| 
 | ||||
|     int user_id = m_available_ids.dequeue(); | ||||
|     int user_id = m_available_ids.pop(); | ||||
|     AOClient* client = new AOClient(this, socket, this, user_id, music_manager); | ||||
|     m_clients_ids.insert(user_id, client); | ||||
| 
 | ||||
| @ -382,7 +382,7 @@ void Server::handleDiscordIntegration() | ||||
| 
 | ||||
| void Server::markIDFree(const int &f_user_id) | ||||
| { | ||||
|     m_available_ids.enqueue(f_user_id); | ||||
|     m_available_ids.push(f_user_id); | ||||
|     m_clients_ids.insert(f_user_id, nullptr); | ||||
| } | ||||
| 
 | ||||
|  | ||||
		Loading…
	
		Reference in New Issue
	
	Block a user
	 Rosemary Witchaven
						Rosemary Witchaven