- fix compile on clang

- implement TCP connections in Linux
- fix passing of request string to a thread
- implement OS stats for ARM and PPC on Linux
This commit is contained in:
Rachael Alexanderson 2018-03-04 23:51:26 -05:00 committed by Christoph Oelckers
parent d2fa4d0ff9
commit 033a11a028
2 changed files with 102 additions and 38 deletions

View file

@ -58,8 +58,12 @@ static int GetOSVersion()
#else #else
// Todo: PPC + ARM // fall-through linux stuff here
#ifdef __arm__
return 10;
#elif __ppc__
return 9;
#else
if (sizeof(void*) == 4) // 32 bit if (sizeof(void*) == 4) // 32 bit
{ {
return 11; return 11;
@ -68,6 +72,7 @@ static int GetOSVersion()
{ {
return 12; return 12;
} }
#endif
#endif #endif
@ -123,7 +128,8 @@ void D_DoAnonStats()
if (currentrenderer == 0 && sentstats_swr) return; if (currentrenderer == 0 && sentstats_swr) return;
if (currentrenderer == 1 && sentstats_hwr) return; if (currentrenderer == 1 && sentstats_hwr) return;
FStringf requeststring("GET /stats.php?render=%i&cores=%i&os=%i HTTP/1.1\nHost: %s\nConnection: close\nUser-Agent: %s %s\n\n", static char requeststring[1024];
sprintf(requeststring, "GET /stats.php?render=%i&cores=%i&os=%i HTTP/1.1\nHost: %s\nConnection: close\nUser-Agent: %s %s\n\n",
GetRenderInfo(), GetCoreInfo(), GetOSVersion(), sys_statshost.GetHumanString(), GAMENAME, VERSIONSTR); GetRenderInfo(), GetCoreInfo(), GetOSVersion(), sys_statshost.GetHumanString(), GAMENAME, VERSIONSTR);
DPrintf(DMSG_NOTIFY, "Sending %s", requeststring); DPrintf(DMSG_NOTIFY, "Sending %s", requeststring);
std::thread t1(D_DoHTTPRequest, requeststring); std::thread t1(D_DoHTTPRequest, requeststring);

View file

@ -36,6 +36,11 @@
#include <SDL.h> #include <SDL.h>
#include <sys/socket.h>
#include <sys/types.h>
#include <netinet/in.h>
#include <netdb.h>
#include "doomerrors.h" #include "doomerrors.h"
#include <math.h> #include <math.h>
@ -69,6 +74,8 @@
#include "g_level.h" #include "g_level.h"
EXTERN_CVAR (String, language) EXTERN_CVAR (String, language)
EXTERN_CVAR(String, sys_statshost)
EXTERN_CVAR(Int, sys_statsport)
extern "C" extern "C"
{ {
@ -94,7 +101,7 @@ void I_Tactile (int /*on*/, int /*off*/, int /*total*/)
ticcmd_t emptycmd; ticcmd_t emptycmd;
ticcmd_t *I_BaseTiccmd(void) ticcmd_t *I_BaseTiccmd(void)
{ {
return &emptycmd; return &emptycmd;
} }
void I_BeginRead(void) void I_BeginRead(void)
@ -129,7 +136,7 @@ void I_Init (void)
DumpCPUInfo (&CPU); DumpCPUInfo (&CPU);
atterm (I_ShutdownSound); atterm (I_ShutdownSound);
I_InitSound (); I_InitSound ();
} }
// //
@ -139,9 +146,9 @@ static int has_exited;
void I_Quit (void) void I_Quit (void)
{ {
has_exited = 1; /* Prevent infinitely recursive exits -- killough */ has_exited = 1; /* Prevent infinitely recursive exits -- killough */
if (demorecording) if (demorecording)
G_CheckDemoStatus(); G_CheckDemoStatus();
C_DeinitConsole(); C_DeinitConsole();
@ -191,11 +198,11 @@ void Linux_I_FatalError(const char* errortext)
void I_FatalError (const char *error, ...) void I_FatalError (const char *error, ...)
{ {
static bool alreadyThrown = false; static bool alreadyThrown = false;
gameisdead = true; gameisdead = true;
if (!alreadyThrown) // ignore all but the first message -- killough if (!alreadyThrown) // ignore all but the first message -- killough
{ {
alreadyThrown = true; alreadyThrown = true;
char errortext[MAX_ERRORTEXT]; char errortext[MAX_ERRORTEXT];
int index; int index;
@ -221,25 +228,25 @@ void I_FatalError (const char *error, ...)
// throw CFatalError (errortext); // throw CFatalError (errortext);
fprintf (stderr, "%s\n", errortext); fprintf (stderr, "%s\n", errortext);
exit (-1); exit (-1);
} }
if (!has_exited) // If it hasn't exited yet, exit now -- killough if (!has_exited) // If it hasn't exited yet, exit now -- killough
{ {
has_exited = 1; // Prevent infinitely recursive exits -- killough has_exited = 1; // Prevent infinitely recursive exits -- killough
exit(-1); exit(-1);
} }
} }
void I_Error (const char *error, ...) void I_Error (const char *error, ...)
{ {
va_list argptr; va_list argptr;
char errortext[MAX_ERRORTEXT]; char errortext[MAX_ERRORTEXT];
va_start (argptr, error); va_start (argptr, error);
vsprintf (errortext, error, argptr); vsprintf (errortext, error, argptr);
va_end (argptr); va_end (argptr);
throw CRecoverableError (errortext); throw CRecoverableError (errortext);
} }
void I_SetIWADInfo () void I_SetIWADInfo ()
@ -291,8 +298,8 @@ int I_PickIWad (WadStuff *wads, int numwads, bool showwin, int defaultiwad)
{ {
FString cmd("kdialog --title \"" GAMESIG " "); FString cmd("kdialog --title \"" GAMESIG " ");
cmd << GetVersionString() << ": Select an IWAD to use\"" cmd << GetVersionString() << ": Select an IWAD to use\""
" --menu \"" GAMENAME " found more than one IWAD\n" " --menu \"" GAMENAME " found more than one IWAD\n"
"Select from the list below to determine which one to use:\""; "Select from the list below to determine which one to use:\"";
for(i = 0; i < numwads; ++i) for(i = 0; i < numwads; ++i)
{ {
@ -380,7 +387,7 @@ static int matchfile (struct dirent *ent)
static int matchfile (const struct dirent *ent) static int matchfile (const struct dirent *ent)
#endif #endif
{ {
return fnmatch (pattern, ent->d_name, FNM_NOESCAPE) == 0; return fnmatch (pattern, ent->d_name, FNM_NOESCAPE) == 0;
} }
void *I_FindFirst (const char *filespec, findstate_t *fileinfo) void *I_FindFirst (const char *filespec, findstate_t *fileinfo)
@ -399,22 +406,22 @@ void *I_FindFirst (const char *filespec, findstate_t *fileinfo)
dir = "."; dir = ".";
} }
fileinfo->current = 0; fileinfo->current = 0;
fileinfo->count = scandir (dir.GetChars(), &fileinfo->namelist, fileinfo->count = scandir (dir.GetChars(), &fileinfo->namelist,
matchfile, alphasort); matchfile, alphasort);
if (fileinfo->count > 0) if (fileinfo->count > 0)
{ {
return fileinfo; return fileinfo;
} }
return (void*)-1; return (void*)-1;
} }
int I_FindNext (void *handle, findstate_t *fileinfo) int I_FindNext (void *handle, findstate_t *fileinfo)
{ {
findstate_t *state = (findstate_t *)handle; findstate_t *state = (findstate_t *)handle;
if (state->current < fileinfo->count) if (state->current < fileinfo->count)
{ {
return ++state->current < fileinfo->count ? 0 : -1; return ++state->current < fileinfo->count ? 0 : -1;
} }
return -1; return -1;
} }
@ -486,12 +493,63 @@ unsigned int I_MakeRNGSeed()
TArray<FString> I_GetGogPaths() TArray<FString> I_GetGogPaths()
{ {
// GOG's Doom games are Windows only at the moment // GOG's Doom games are Windows only at the moment
return TArray<FString>(); return TArray<FString>();
} }
bool I_HTTPRequest(const char* request) bool I_HTTPRequest(const char* request)
{ {
// todo if (sys_statshost.GetHumanString() == NULL || sys_statshost.GetHumanString()[0] == 0)
return false; // no host, disable
int sockfd, portno, n;
struct sockaddr_in serv_addr;
struct hostent *server;
portno = sys_statsport;
sockfd = socket(AF_INET, SOCK_STREAM, 0);
if (sockfd < 0)
{
DPrintf(DMSG_ERROR, "Error opening TCP socket.\n");
return false;
}
server = gethostbyname(sys_statshost.GetHumanString());
if (server == NULL)
{
DPrintf(DMSG_ERROR, "Error looking up hostname.\n");
return false;
}
bzero((char*) &serv_addr, sizeof(serv_addr));
serv_addr.sin_family = AF_INET;
bcopy((char *)server->h_addr,
(char *)&serv_addr.sin_addr.s_addr,
server->h_length);
serv_addr.sin_port = htons(portno);
DPrintf(DMSG_NOTIFY, "Connecting to host %s\n", sys_statshost.GetHumanString());
if (connect(sockfd, (struct sockaddr *)&serv_addr, sizeof(serv_addr)) < 0)
{
DPrintf(DMSG_ERROR, "Connection to host %s failed!\n", sys_statshost.GetHumanString());
return false;
}
char buffer[1024];
sprintf(buffer, "%s", request);
Printf("Buffer: %s", buffer);
n = write(sockfd, (char*)buffer, (int)strlen(request));
if (n<0)
{
DPrintf(DMSG_ERROR, "Error writing to socket.\n");
close(sockfd);
return false;
}
bzero(buffer, 1024);
n = read(sockfd, buffer, 1023);
close(sockfd);
DPrintf(DMSG_NOTIFY, "Stats send successful.\n");
return true;
} }