X-Git-Url: https://jfr.im/git/irc/gameservirc.git/blobdiff_plain/20d5d7219d871c31dd7b20e2001df9f52fe117cd..1e1b5312aab8cad09bacc048d457b2e79805023c:/gameserv/config.cpp diff --git a/gameserv/config.cpp b/gameserv/config.cpp index 92086a8..21088cd 100644 --- a/gameserv/config.cpp +++ b/gameserv/config.cpp @@ -1,10 +1,14 @@ -#include +#include #include #include #include #include "extern.h" -void load_config_file(char *config); +using std::ifstream; +using std::cerr; +using std::endl; + +int load_config_file(char *config); void unload_config_file(); /* Random Configuration Stuff Goes Here until I code it to load from a .conf file :)*/ @@ -30,6 +34,10 @@ char *remotepass; // Password for the server link char *playerdata; // File to store player data in char *monsterdata; // File to load monster data from +#if defined(P10) + char *gsnum = "[]AAA"; // GameServ Numeric +#endif + void unload_config_file() { if (s_GameServ) @@ -60,24 +68,58 @@ void unload_config_file() delete [] welcomemsg; } -void load_config_file(char *config) +int load_config_file(char *config) { char *buf, *directive, *value; - buf = new char[1024]; + #define numdirectives 15 unload_config_file(); + struct DIRECTIVE { + bool done; + char *desc; + }; + + DIRECTIVE directives[numdirectives]; + + directives[0].desc = "s_GameServ - GameServ Nickname"; + directives[1].desc = "GSHOST - GameServ Hostname"; + directives[2].desc = "GSIDENT - GameServ Ident"; + directives[3].desc = "SERVERNAME - Pseudo Server's Name"; + directives[4].desc = "C_FOREST - Forest Channel"; + directives[5].desc = "C_FORESTTOPIC - Topic for the Forest Channel"; + directives[6].desc = "REMOTESERVER - Server for gameserv to connect to (ip or hostname)"; + directives[7].desc = "REMOTEPORT - Port on the remote server to connect to"; + directives[8].desc = "REMOTEPASS - Password on the remote server"; + directives[9].desc = "PLAYERDATA - File to store the player saves in"; + directives[10].desc = "MONSTERDATA - File to load the monsters from"; + directives[11].desc = "ADMINPASS - Password to identify as an admin with"; + directives[12].desc = "WELCOMEDELAY - Delay (in seconds) to wait before welcoming new users to the network"; + directives[13].desc = "FORESTFIGHTS - Number of forest fights players get every day"; + directives[14].desc = "UPDATEPERIOD - Number of seconds between every player data save"; + directives[15].desc = "WELCOMEMSG - Message to send to new users on the network"; + + for (int count = 0; count < numdirectives; count++) + { + directives[count].done = false; + } + ifstream infile; infile.open(config); if (infile.fail()) { - cout << "Error opening " << config << endl; - return; + log("Error opening %s", config); + cerr << "Error opening " << config << endl; + return 0; } + buf = new char[1024]; + while (infile.getline(buf, 1024, '\n')) { - cout << "Buf: " << buf << endl; + #ifdef DEBUGMODE + log("Config file entry buf: %s", buf); + #endif if (buf[0] == '#' || buf[0] == ' ' || buf[0] == '\0' || buf[0] == '\n' || buf[0] == '\r') continue; @@ -87,7 +129,10 @@ void load_config_file(char *config) if (stricmp(directive, "DIE") == 0) { value = strtok(NULL, ""); - cerr << value << endl; + log("You should read the entire %s file!", config); + cerr << "You should read the entire " << config << " file!" + << endl; + delete []buf; exit(0); } if (stricmp(directive, "S_GAMESERV") == 0) @@ -95,100 +140,132 @@ void load_config_file(char *config) value = strtok(NULL, " "); s_GameServ = new char[strlen(value) + 1]; strcpy(s_GameServ, value); + directives[0].done = true; } else if (stricmp(directive, "GSHOST") == 0) { value = strtok(NULL, " "); gshost = new char[strlen(value) + 1]; strcpy(gshost, value); + directives[1].done = true; } else if (stricmp(directive, "GSIDENT") == 0) { value = strtok(NULL, " "); gsident = new char[strlen(value) + 1]; strcpy(gsident, value); + directives[2].done = true; } else if (stricmp(directive, "SERVERNAME") == 0) { value = strtok(NULL, " "); servername = new char[strlen(value) + 1]; strcpy(servername, value); + directives[3].done = true; } else if (stricmp(directive, "C_FOREST") == 0) { value = strtok(NULL, " "); c_Forest = new char[strlen(value) + 1]; strcpy(c_Forest, value); + directives[4].done = true; } else if (stricmp(directive, "C_FORESTTOPIC") == 0) { value = strtok(NULL, ""); c_ForestTopic = new char[strlen(value) + 1]; strcpy(c_ForestTopic, value); + directives[5].done = true; } else if (stricmp(directive, "REMOTESERVER") == 0) { value = strtok(NULL, " "); remoteserver = new char[strlen(value) + 1]; strcpy(remoteserver, value); + directives[6].done = true; } else if (stricmp(directive, "REMOTEPORT") == 0) { value = strtok(NULL, " "); remoteport = new char[strlen(value) + 1]; strcpy(remoteport, value); + directives[7].done = true; } else if (stricmp(directive, "REMOTEPASS") == 0) { value = strtok(NULL, ""); remotepass = new char[strlen(value) + 1]; strcpy(remotepass, value); + directives[8].done = true; } else if (stricmp(directive, "PLAYERDATA") == 0) { value = strtok(NULL, ""); playerdata = new char[strlen(value) + 1]; strcpy(playerdata, value); + directives[9].done = true; } else if (stricmp(directive, "MONSTERDATA") == 0) { value = strtok(NULL, ""); monsterdata = new char[strlen(value) + 1]; strcpy(monsterdata, value); + directives[10].done = true; } else if (stricmp(directive, "ADMINPASS") == 0) { value = strtok(NULL, ""); adminpass = new char[strlen(value) + 1]; strcpy(adminpass, value); + directives[11].done = true; } else if (stricmp(directive, "WELCOMEDELAY") == 0) { value = strtok(NULL, " "); welcomedelay = stringtoint(value); + directives[12].done = true; } else if (stricmp(directive, "FORESTFIGHTS") == 0) { value = strtok(NULL, " "); forestfights = stringtoint(value); + directives[13].done = true; } else if (stricmp(directive, "UPDATEPERIOD") == 0) { value = strtok(NULL, " "); updateperiod = stringtoint(value); + directives[14].done = true; } else if (stricmp(directive, "WELCOMEMSG") == 0) { value = strtok(NULL, ""); welcomemsg = new char[strlen(value) + 1]; strcpy(welcomemsg, value); + directives[15].done = true; } else { - cout << "Unknown Directive. Buffer: " << buf << endl; + #ifdef DEBUGMODE + log("Unknown Directive. Buffer: %s", buf); + cerr << "Unknown " << config << " directive. Buffer: " + << buf << endl; + #endif continue; } } delete [] buf; infile.close(); + + int nonemissing = 1; + for (int count2 = 0; count2 < numdirectives; count2++) + { + if (!directives[count2].done) + { + cerr << "Missing config directive: " << directives[count2].desc << endl; + nonemissing = 0; + } + } + + return nonemissing; }