From c71db5cbdece1b5ce878c68f162acb52eff8becd Mon Sep 17 00:00:00 2001 From: w00t Date: Sat, 1 Aug 2009 21:58:17 +0000 Subject: Various rehash fixes that it seems were introduced by untested code. - Remove unused ReportConfigError member - Don't report successful load (and spam modules that failed to load) if there is a config error - Restore server name before attempting to send error string to client(s) otherwise most of them won't recieve the notifications. Fixes bug #891. Still to come: report errors loudly on startup regardless of debug mode. git-svn-id: http://svn.inspircd.org/repository/trunk/inspircd@11450 e03df62e-2008-0410-955e-edbf42e46eb7 --- include/configreader.h | 4 ---- src/configreader.cpp | 28 +++++++++++++++++----------- 2 files changed, 17 insertions(+), 15 deletions(-) diff --git a/include/configreader.h b/include/configreader.h index cc0c06d38..c4b603342 100644 --- a/include/configreader.h +++ b/include/configreader.h @@ -800,10 +800,6 @@ class CoreExport ServerConfig : public Extensible */ bool StartsWithWindowsDriveLetter(const std::string &path); - /** Report a configuration error given in errormessage. - */ - void ReportConfigError(const std::string &errormessage); - /** Load 'filename' into 'target', with the new config parser everything is parsed into * tag/key/value at load-time rather than at read-value time. */ diff --git a/src/configreader.cpp b/src/configreader.cpp index cbd9049a0..1fb434493 100644 --- a/src/configreader.cpp +++ b/src/configreader.cpp @@ -707,12 +707,6 @@ bool DoneMaxBans(ServerConfig*, const char*) return true; } -void ServerConfig::ReportConfigError(const std::string &errormessage) -{ - ServerInstance->Logs->Log("CONFIG",DEFAULT, "There were errors in your configuration file: %s", errormessage.c_str()); - errstr << errormessage << std::endl; -} - void ServerConfig::Read() { static char maxkeep[MAXBUF]; /* Temporary buffer for WhoWasMaxKeep value */ @@ -1171,12 +1165,22 @@ void ServerConfig::Read() void ServerConfig::Apply(ServerConfig* old, const std::string &useruid) { int rem = 0, add = 0; + bool errors = false; // write once here, to try it out and make sure its ok ServerInstance->WritePID(this->PID); FailedPortList pl; ServerInstance->BindPorts(pl); + /* + * These values can only be set on boot. Keep their old values. Do it before we send messages so we actually have a servername. + */ + if (old) + { + memcpy(this->ServerName, old->ServerName, sizeof(this->ServerName)); + memcpy(this->sid, old->sid, sizeof(this->sid)); + } + if (pl.size()) { errstr << "Not all your client ports could be bound.\nThe following port(s) failed to bind:\n"; @@ -1194,6 +1198,9 @@ void ServerConfig::Apply(ServerConfig* old, const std::string &useruid) while (errstr.good()) { + if (errors == false) + ServerInstance->Logs->Log("CONFIG",DEFAULT, "There were errors in your configuration file:"); + errors = true; // XXX: has to be a nicer way to accomplish this. std::string line; getline(errstr, line, '\n'); if (!line.empty()) @@ -1212,11 +1219,10 @@ void ServerConfig::Apply(ServerConfig* old, const std::string &useruid) if (!old) return; - /* - * These values can only be set on boot. Keep their old values. - */ - memcpy(this->ServerName, old->ServerName, sizeof(this->ServerName)); - memcpy(this->sid, old->sid, sizeof(this->sid)); + // If there were errors processing configuration, don't touch modules. + if (errors) + return; + if (!removed_modules.empty()) { -- cgit v1.2.3