diff options
author | Peter Powell <petpow@saberuk.com> | 2018-04-14 13:17:20 +0100 |
---|---|---|
committer | Peter Powell <petpow@saberuk.com> | 2018-04-16 15:07:06 +0100 |
commit | 7c2adcb46a01c7cf0f0e6f5aeeef070232e7d222 (patch) | |
tree | 0576962a22b5d0b71cb8536923ad31f73ae9bafd | |
parent | 7ef2f87e39bd22c7914caf7f2afbb1a3bf8fbd43 (diff) |
Convert ConfigTag::CheckRange to a function template.
-rw-r--r-- | include/configreader.h | 10 | ||||
-rw-r--r-- | src/configparser.cpp | 38 |
2 files changed, 26 insertions, 22 deletions
diff --git a/include/configreader.h b/include/configreader.h index bb4c03fae..d55c1830f 100644 --- a/include/configreader.h +++ b/include/configreader.h @@ -69,16 +69,6 @@ class CoreExport ConfigTag : public refcountbase */ bool readString(const std::string& key, std::string& value, bool allow_newline = false); - /** Check for an out of range value. If the value falls outside the boundaries a warning is - * logged and the value is corrected (set to def). - * @param key The key name, used in the warning message - * @param res The value to verify and modify if needed - * @param def The default value, res will be set to this if (min <= res <= max) doesn't hold true - * @param min Minimum accepted value for res - * @param max Maximum accepted value for res - */ - void CheckRange(const std::string& key, long& res, long def, long min, long max); - std::string getTagLocation(); inline const ConfigItems& getItems() const { return items; } diff --git a/src/configparser.cpp b/src/configparser.cpp index 2af796b21..34ee006fe 100644 --- a/src/configparser.cpp +++ b/src/configparser.cpp @@ -417,6 +417,30 @@ std::string ConfigTag::getString(const std::string& key, const std::string& def, return res; } +namespace +{ + /** Check for an out of range value. If the value falls outside the boundaries a warning is + * logged and the value is corrected (set to \p def). + * @param tag The tag name; used in the warning message. + * @param key The key name; used in the warning message. + * @param num The value to verify and modify if needed. + * @param def The default value, \p res will be set to this if (min <= res <= max) doesn't hold true. + * @param min Minimum accepted value for \p res. + * @param max Maximum accepted value for \p res. + */ + template <typename Numeric> + void CheckRange(const std::string& tag, const std::string& key, Numeric& num, Numeric def, Numeric min, Numeric max) + { + if (num >= min && num <= max) + return; + + const std::string message = "WARNING: <" + tag + ":" + key + "> value of " + ConvToStr(num) + " is not between " + + ConvToStr(min) + " and " + ConvToStr(max) + "; value set to " + ConvToStr(def) + "."; + ServerInstance->Logs->Log("CONFIG", LOG_DEFAULT, message); + num = def; + } +} + long ConfigTag::getInt(const std::string &key, long def, long min, long max) { std::string result; @@ -441,20 +465,10 @@ long ConfigTag::getInt(const std::string &key, long def, long min, long max) break; } - CheckRange(key, res, def, min, max); + CheckRange(tag, key, res, def, min, max); return res; } -void ConfigTag::CheckRange(const std::string& key, long& res, long def, long min, long max) -{ - if (res < min || res > max) - { - ServerInstance->Logs->Log("CONFIG", LOG_DEFAULT, "WARNING: <%s:%s> value of %ld is not between %ld and %ld; set to %ld.", - tag.c_str(), key.c_str(), res, min, max, def); - res = def; - } -} - long ConfigTag::getDuration(const std::string& key, long def, long min, long max) { std::string duration; @@ -462,7 +476,7 @@ long ConfigTag::getDuration(const std::string& key, long def, long min, long max return def; long ret = InspIRCd::Duration(duration); - CheckRange(key, ret, def, min, max); + CheckRange(tag, key, ret, def, min, max); return ret; } |