Merge
This commit is contained in:
		
						commit
						88afac51f0
					
				| @ -9,6 +9,7 @@ char fileNames[NUM_FILES][30] = { | |||||||
| 	"core.games.txt", | 	"core.games.txt", | ||||||
| 	"sdktools.games.txt", | 	"sdktools.games.txt", | ||||||
| 	"sdktools.games.ep2.txt", | 	"sdktools.games.ep2.txt", | ||||||
|  | 	"sdktools.games.l4d.txt", | ||||||
| 	"sm-cstrike.games.txt", | 	"sm-cstrike.games.txt", | ||||||
| 	"sm-tf2.games.txt", | 	"sm-tf2.games.txt", | ||||||
| }; | }; | ||||||
| @ -143,7 +144,7 @@ int main(int argc, char **argv) | |||||||
| 		fprintf(stdout, | 		fprintf(stdout, | ||||||
| 				"Accepting connection from client (sock %d, ip %s)", | 				"Accepting connection from client (sock %d, ip %s)", | ||||||
| 				clientSocket, | 				clientSocket, | ||||||
| 				inet_ntoa(&clientAddress)); | 				inet_ntoa(clientAddress.sin_addr)); | ||||||
| #endif | #endif | ||||||
| 
 | 
 | ||||||
| 		pool->AddConnection(clientSocket); | 		pool->AddConnection(clientSocket); | ||||||
|  | |||||||
| @ -16,7 +16,7 @@ | |||||||
| 
 | 
 | ||||||
| #define closesocket close | #define closesocket close | ||||||
| 
 | 
 | ||||||
| #define NUM_FILES 5 | #define NUM_FILES 6 | ||||||
| 
 | 
 | ||||||
| extern char fileNames[NUM_FILES][30]; | extern char fileNames[NUM_FILES][30]; | ||||||
| extern void *fileLocations[NUM_FILES]; | extern void *fileLocations[NUM_FILES]; | ||||||
|  | |||||||
| @ -145,33 +145,61 @@ QueryResult ConnectionPool::ProcessConnection( smud_connection *con ) | |||||||
| 
 | 
 | ||||||
| void ConnectionPool::ReadQueryHeader( smud_connection *con ) | void ConnectionPool::ReadQueryHeader( smud_connection *con ) | ||||||
| { | { | ||||||
| 	char data[11]; | 	if (con->buffer == NULL) | ||||||
|  | 	{ | ||||||
|  | 		con->buffer = new char[QUERY_HEADER_SIZE]; | ||||||
|  | 		con->writtenCount = 0; | ||||||
|  | 	} | ||||||
|  | 	 | ||||||
|  | 	int bytesReceived = 0; | ||||||
| 
 | 
 | ||||||
| 	if (recv(con->fd, data, sizeof(data), 0) == -1) | 	bytesReceived = recv(con->fd, con->buffer+con->writtenCount, QUERY_HEADER_SIZE-con->writtenCount, 0); | ||||||
|  | 
 | ||||||
|  | 	if (bytesReceived == -1) | ||||||
| 	{ | 	{ | ||||||
| 		if (errno != EAGAIN && errno != EWOULDBLOCK) | 		if (errno != EAGAIN && errno != EWOULDBLOCK) | ||||||
| 		{ | 		{ | ||||||
| 			con->state = ConnectionState_Complete; | 			con->state = ConnectionState_Complete; | ||||||
|  | 			delete [] con->buffer; | ||||||
|  | 			con->buffer = NULL; | ||||||
|  | 			con->writtenCount = 0; | ||||||
| 		} | 		} | ||||||
| 
 | 
 | ||||||
| 		return; | 		return; | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	if (data[0] != 'A' || data[1] != 'G') | 	con->writtenCount += bytesReceived; | ||||||
|  | 
 | ||||||
|  | 	assert(con->writtenCount <= QUERY_HEADER_SIZE); | ||||||
|  | 
 | ||||||
|  | 	if (con->writtenCount < QUERY_HEADER_SIZE) | ||||||
|  | 	{ | ||||||
|  | 		/* Don't change the connection status, so next cycle we will come back to here and continue receiving data */ | ||||||
|  | 		return; | ||||||
|  | 	} | ||||||
|  | 	 | ||||||
|  | 	if (con->buffer[0] != 'A' || con->buffer[1] != 'G') | ||||||
| 	{ | 	{ | ||||||
| 		con->state = ConnectionState_Complete; | 		con->state = ConnectionState_Complete; | ||||||
|  | 		delete [] con->buffer; | ||||||
|  | 		con->buffer = NULL; | ||||||
|  | 		con->writtenCount = 0; | ||||||
| 		return; | 		return; | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	//Ignore the next 8 bytes for the moment. Versioning data is currently unused
 | 	//Ignore the next 8 bytes for the moment. Versioning data is currently unused
 | ||||||
| 	// uint16[4] - source version major/minor/something/rev
 | 	// uint16[4] - source version major/minor/something/rev
 | ||||||
| 
 | 
 | ||||||
| 	con->sentSums = data[10]; | 	con->sentSums = con->buffer[10]; | ||||||
| 
 | 
 | ||||||
| 	con->state = ConnectionState_ReadQueryData; | 	con->state = ConnectionState_ReadQueryData; | ||||||
| #if defined DEBUG | #if defined DEBUG | ||||||
| 	fprintf(stdout, "Query Header Read Complete, %i md5's expected\n", con->sentSums); | 	fprintf(stdout, "Query Header Read Complete, %i md5's expected\n", con->sentSums); | ||||||
| #endif | #endif | ||||||
|  | 
 | ||||||
|  | 	delete [] con->buffer; | ||||||
|  | 	con->buffer = NULL; | ||||||
|  | 	con->writtenCount = 0; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void ConnectionPool::ReplyQuery(smud_connection *con) | void ConnectionPool::ReplyQuery(smud_connection *con) | ||||||
| @ -188,20 +216,31 @@ void ConnectionPool::ReplyQuery(smud_connection *con) | |||||||
| 
 | 
 | ||||||
| 	data[11] = (char)con->sendCount; | 	data[11] = (char)con->sendCount; | ||||||
| 
 | 
 | ||||||
| 	if (send(con->fd, data, sizeof(data), 0) == -1) | 	int bytesSent = send(con->fd, data+con->writtenCount, sizeof(data)-con->writtenCount, 0); | ||||||
|  | 	 | ||||||
|  | 	if (bytesSent == -1) | ||||||
| 	{ | 	{ | ||||||
| 		if (errno != EAGAIN && errno != EWOULDBLOCK) | 		if (errno != EAGAIN && errno != EWOULDBLOCK) | ||||||
| 		{ | 		{ | ||||||
| 			con->state = ConnectionState_Complete; | 			con->state = ConnectionState_Complete; | ||||||
|  | 			con->writtenCount = 0; | ||||||
| 		} | 		} | ||||||
| 
 | 
 | ||||||
| 		return; | 		return; | ||||||
| 	} | 	} | ||||||
| 	 |  | ||||||
| 	//Now we need more send sub functions for all the damn files. Geh.
 |  | ||||||
| 	//Alternatively we could just send all at once here. Could make for a damn big query. 100k anyone?
 |  | ||||||
| 
 | 
 | ||||||
|  | 	con->writtenCount += bytesSent; | ||||||
|  | 
 | ||||||
|  | 	assert(con->writtenCount <= 12); | ||||||
|  | 
 | ||||||
|  | 	if (con->writtenCount < 12) | ||||||
|  | 	{ | ||||||
|  | 		/** Still more data needs to be sent - Return so we come back here next cycle */ | ||||||
|  | 		return; | ||||||
|  | 	} | ||||||
|  | 	 | ||||||
| 	con->state = ConnectionState_SendingFiles; | 	con->state = ConnectionState_SendingFiles; | ||||||
|  | 	con->writtenCount = 0; | ||||||
| #if defined DEBUG | #if defined DEBUG | ||||||
| 	printf("Query Reply Header Complete\n"); | 	printf("Query Reply Header Complete\n"); | ||||||
| #endif | #endif | ||||||
| @ -209,16 +248,36 @@ void ConnectionPool::ReplyQuery(smud_connection *con) | |||||||
| 
 | 
 | ||||||
| void ConnectionPool::ReadQueryContent( smud_connection *con ) | void ConnectionPool::ReadQueryContent( smud_connection *con ) | ||||||
| { | { | ||||||
| 	char *data = new char[16*(con->sentSums)](); | 	if (con->buffer == NULL) | ||||||
|  | 	{ | ||||||
|  | 		con->buffer = new char[QUERY_CONTENT_SIZE*con->sentSums]; | ||||||
|  | 		con->writtenCount = 0; | ||||||
|  | 	} | ||||||
| 
 | 
 | ||||||
| 	if (recv(con->fd, data, 16*(con->sentSums), 0) == -1) | 	int bytesReceived = 0; | ||||||
|  | 
 | ||||||
|  | 	bytesReceived = recv(con->fd, con->buffer+con->writtenCount, (QUERY_CONTENT_SIZE*con->sentSums)-con->writtenCount, 0); | ||||||
|  | 
 | ||||||
|  | 	if (bytesReceived == -1) | ||||||
| 	{ | 	{ | ||||||
| 		if (errno != EAGAIN && errno != EWOULDBLOCK) | 		if (errno != EAGAIN && errno != EWOULDBLOCK) | ||||||
| 		{ | 		{ | ||||||
| 			con->state = ConnectionState_Complete; | 			con->state = ConnectionState_Complete; | ||||||
|  | 			delete [] con->buffer; | ||||||
|  | 			con->buffer = NULL; | ||||||
|  | 			con->writtenCount = 0; | ||||||
| 		} | 		} | ||||||
| 
 | 
 | ||||||
| 		delete [] data; | 		return; | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
|  | 	con->writtenCount += bytesReceived; | ||||||
|  | 
 | ||||||
|  | 	assert(con->writtenCount <= (QUERY_CONTENT_SIZE*con->sentSums)); | ||||||
|  | 
 | ||||||
|  | 	if (con->writtenCount < (QUERY_CONTENT_SIZE*con->sentSums)) | ||||||
|  | 	{ | ||||||
|  | 		/* Don't change the connection status, so next cycle we will come back to here and continue receiving data */ | ||||||
| 		return; | 		return; | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| @ -229,7 +288,7 @@ void ConnectionPool::ReadQueryContent( smud_connection *con ) | |||||||
| 	for (int i=0; i<con->sentSums; i++) | 	for (int i=0; i<con->sentSums; i++) | ||||||
| 	{ | 	{ | ||||||
| 		con->fileLocation[i] = -1; | 		con->fileLocation[i] = -1; | ||||||
| 		con->shouldSend[i] = GetMD5UpdateStatus(data + (16*i), con, i); | 		con->shouldSend[i] = GetMD5UpdateStatus(con->buffer + (QUERY_CONTENT_SIZE*i), con, i); | ||||||
| 		 | 		 | ||||||
| 		if (con->shouldSend[i] == MD5Status_NeedsUpdate) | 		if (con->shouldSend[i] == MD5Status_NeedsUpdate) | ||||||
| 		{ | 		{ | ||||||
| @ -252,7 +311,9 @@ void ConnectionPool::ReadQueryContent( smud_connection *con ) | |||||||
| 
 | 
 | ||||||
| 	con->state = ConnectionState_ReplyQuery; | 	con->state = ConnectionState_ReplyQuery; | ||||||
| 	con->pollData.events = POLLOUT; | 	con->pollData.events = POLLOUT; | ||||||
| 	delete [] data; | 	delete [] con->buffer; | ||||||
|  | 	con->buffer = NULL; | ||||||
|  | 	con->writtenCount = 0; | ||||||
| #if defined DEBUG | #if defined DEBUG | ||||||
| 	fprintf(stdout, "Query Data Read Complete\n"); | 	fprintf(stdout, "Query Data Read Complete\n"); | ||||||
| #endif | #endif | ||||||
| @ -335,7 +396,8 @@ MD5Status ConnectionPool::GetMD5UpdateStatus( const char *md5 , smud_connection | |||||||
| void ConnectionPool::SendFile( smud_connection *con ) | void ConnectionPool::SendFile( smud_connection *con ) | ||||||
| { | { | ||||||
| 	//Find the next file to send.
 | 	//Find the next file to send.
 | ||||||
| 	while (con->currentFile < con->sentSums && | 	while (con->writtenCount == 0 && | ||||||
|  | 			con->currentFile < con->sentSums && | ||||||
| 			con->shouldSend[con->currentFile] != MD5Status_NeedsUpdate) | 			con->shouldSend[con->currentFile] != MD5Status_NeedsUpdate) | ||||||
| 	{ | 	{ | ||||||
| 		con->currentFile++; | 		con->currentFile++; | ||||||
| @ -348,6 +410,7 @@ void ConnectionPool::SendFile( smud_connection *con ) | |||||||
| 		fprintf(stdout, "All files sent!\n"); | 		fprintf(stdout, "All files sent!\n"); | ||||||
| #endif | #endif | ||||||
| 		con->state = ConnectionState_SendUnknownList; | 		con->state = ConnectionState_SendUnknownList; | ||||||
|  | 		con->writtenCount = 0; | ||||||
| 		return; | 		return; | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| @ -362,36 +425,64 @@ void ConnectionPool::SendFile( smud_connection *con ) | |||||||
| 			con->fileLocation[con->currentFile]); | 			con->fileLocation[con->currentFile]); | ||||||
| #endif | #endif | ||||||
| 
 | 
 | ||||||
|  | 	int sentBytes = 0; | ||||||
|  | 
 | ||||||
| 	if (!con->headerSent[con->currentFile]) | 	if (!con->headerSent[con->currentFile]) | ||||||
| 	{ | 	{ | ||||||
| 		char buffer[5]; | 		char buffer[5]; | ||||||
| 		buffer[0] = con->currentFile; | 		buffer[0] = con->currentFile; | ||||||
| 		*((int *)&buffer[1]) = filelength; | 		*((int *)&buffer[1]) = filelength; | ||||||
| 
 | 
 | ||||||
| 		if (send(con->fd, buffer, 5, 0) == -1) | 		sentBytes = send(con->fd, buffer+con->writtenCount, 5-con->writtenCount, 0); | ||||||
|  | 
 | ||||||
|  | 		if (sentBytes == -1) | ||||||
| 		{ | 		{ | ||||||
| 			if (errno != EAGAIN && errno != EWOULDBLOCK) | 			if (errno != EAGAIN && errno != EWOULDBLOCK) | ||||||
| 			{ | 			{ | ||||||
| 				con->state = ConnectionState_Complete; | 				con->state = ConnectionState_Complete; | ||||||
|  | 				con->writtenCount = 0; | ||||||
| 			} | 			} | ||||||
| 
 | 
 | ||||||
| 			return; | 			return; | ||||||
| 		} | 		} | ||||||
| 
 | 
 | ||||||
|  | 		con->writtenCount += sentBytes; | ||||||
|  | 	 | ||||||
|  | 		assert(con->writtenCount <= 5); | ||||||
|  | 
 | ||||||
|  | 		if (con->writtenCount < 5) | ||||||
|  | 		{ | ||||||
|  | 			return; | ||||||
|  | 		} | ||||||
|  | 
 | ||||||
| 		con->headerSent[con->currentFile] = true; | 		con->headerSent[con->currentFile] = true; | ||||||
|  | 		con->writtenCount = 0; | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	if (send(con->fd, file, filelength, 0) == -1) | 	sentBytes = send(con->fd, (unsigned char *)file+con->writtenCount, filelength-con->writtenCount, 0); | ||||||
|  | 
 | ||||||
|  | 	if (sentBytes == -1) | ||||||
| 	{ | 	{ | ||||||
| 		if (errno != EAGAIN && errno != EWOULDBLOCK) | 		if (errno != EAGAIN && errno != EWOULDBLOCK) | ||||||
| 		{ | 		{ | ||||||
| 			con->state = ConnectionState_Complete; | 			con->state = ConnectionState_Complete; | ||||||
|  | 			con->writtenCount = 0; | ||||||
| 		} | 		} | ||||||
| 
 | 
 | ||||||
| 		return; | 		return; | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
|  | 	con->writtenCount += sentBytes; | ||||||
|  | 
 | ||||||
|  | 	assert(con->writtenCount <= filelength); | ||||||
|  | 
 | ||||||
|  | 	if (con->writtenCount < filelength) | ||||||
|  | 	{ | ||||||
|  | 		return; | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
| 	con->currentFile++; | 	con->currentFile++; | ||||||
|  | 	con->writtenCount = 0; | ||||||
| #if defined DEBUG | #if defined DEBUG | ||||||
| 	fprintf(stdout, "Sent a file!: %s\n", fileNames[con->fileLocation[con->currentFile-1]]); | 	fprintf(stdout, "Sent a file!: %s\n", fileNames[con->fileLocation[con->currentFile-1]]); | ||||||
| #endif | #endif | ||||||
| @ -419,17 +510,30 @@ void ConnectionPool::SendUnknownList( smud_connection *con ) | |||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	if (send(con->fd, packet, size, 0) == -1) | 	int sentBytes = send(con->fd, packet+con->writtenCount, size-con->writtenCount, 0); | ||||||
|  | 	 | ||||||
|  | 	if (sentBytes == -1) | ||||||
| 	{ | 	{ | ||||||
| 		if (errno != EAGAIN && errno != EWOULDBLOCK) | 		if (errno != EAGAIN && errno != EWOULDBLOCK) | ||||||
| 		{ | 		{ | ||||||
| 			con->state = ConnectionState_Complete; | 			con->state = ConnectionState_Complete; | ||||||
|  | 			con->writtenCount = 0; | ||||||
| 		} | 		} | ||||||
| 
 | 
 | ||||||
| 		return; | 		return; | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
|  | 	con->writtenCount += sentBytes; | ||||||
|  | 
 | ||||||
|  | 	assert(con->writtenCount <= size); | ||||||
|  | 
 | ||||||
|  | 	if (con->writtenCount < size) | ||||||
|  | 	{ | ||||||
|  | 		return; | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
| 	con->state = ConnectionState_Complete; | 	con->state = ConnectionState_Complete; | ||||||
|  | 	con->writtenCount = 0; | ||||||
| #if defined DEBUG | #if defined DEBUG | ||||||
| 	fprintf(stdout, "Unknowns Sent\n"); | 	fprintf(stdout, "Unknowns Sent\n"); | ||||||
| #endif | #endif | ||||||
|  | |||||||
| @ -5,6 +5,9 @@ | |||||||
| #include <list> | #include <list> | ||||||
| #include "poll.h" | #include "poll.h" | ||||||
| 
 | 
 | ||||||
|  | #define QUERY_HEADER_SIZE 11 | ||||||
|  | #define QUERY_CONTENT_SIZE 16 | ||||||
|  | 
 | ||||||
| enum ConnectionState | enum ConnectionState | ||||||
| { | { | ||||||
| 	ConnectionState_ReadQueryHeader, | 	ConnectionState_ReadQueryHeader, | ||||||
| @ -54,6 +57,8 @@ struct smud_connection | |||||||
| 		state = ConnectionState_ReadQueryHeader; | 		state = ConnectionState_ReadQueryHeader; | ||||||
| 		this->fd = fd; | 		this->fd = fd; | ||||||
| 		pollData.fd = fd; | 		pollData.fd = fd; | ||||||
|  | 		buffer = NULL; | ||||||
|  | 		writtenCount = 0; | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	~smud_connection() | 	~smud_connection() | ||||||
| @ -77,6 +82,8 @@ struct smud_connection | |||||||
| 	int unknownCount;				/** Number of files that were unknown */ | 	int unknownCount;				/** Number of files that were unknown */ | ||||||
| 	int currentFile;				/** Current file being sent (index into the above 3 arrays) */ | 	int currentFile;				/** Current file being sent (index into the above 3 arrays) */ | ||||||
| 	pollfd pollData;				/** Data to be passed into poll() */ | 	pollfd pollData;				/** Data to be passed into poll() */ | ||||||
|  | 	char *buffer;					/** Temporary storage buffer to hold data until all of it is available */ | ||||||
|  | 	int writtenCount;				/** Number of bytes written into the storage buffer */ | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user