diff options
author | Peter Powell <petpow@saberuk.com> | 2018-04-14 14:04:12 +0100 |
---|---|---|
committer | Peter Powell <petpow@saberuk.com> | 2018-04-16 15:07:06 +0100 |
commit | ccab908f14804776aab4c6728710e89b4847130a (patch) | |
tree | 63d6ae2ca725ceabfe1da51a42dd2f5d931c106d | |
parent | 7c2adcb46a01c7cf0f0e6f5aeeef070232e7d222 (diff) |
Extract ConfigTag::getInt magnitude logic to a function template.
-rw-r--r-- | src/configparser.cpp | 51 |
1 files changed, 39 insertions, 12 deletions
diff --git a/src/configparser.cpp b/src/configparser.cpp index 34ee006fe..5feff013f 100644 --- a/src/configparser.cpp +++ b/src/configparser.cpp @@ -419,6 +419,44 @@ std::string ConfigTag::getString(const std::string& key, const std::string& def, namespace { + /** Check for an invalid magnitude specifier. If one is found 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 val The full value set in the config as a string. + * @param num The value to verify and modify if needed. + * @param def The default value, \p res will be set to this if \p tail does not contain a. + * valid magnitude specifier. + * @param tail The location in the config value at which the magnifier is located. + */ + template <typename Numeric> + void CheckMagnitude(const std::string& tag, const std::string& key, const std::string& val, Numeric& num, Numeric def, const char* tail) + { + // If this is NULL then no magnitude specifier was given. + if (!*tail) + return; + + switch (toupper(*tail)) + { + case 'K': + num *= 1024; + return; + + case 'M': + num *= 1024 * 1024; + return; + + case 'G': + num *= 1024 * 1024 * 1024; + return; + } + + const std::string message = "WARNING: <" + tag + ":" + key + "> value of " + val + " contains an invalid magnitude specifier '" + + tail + "'; value set to " + ConvToStr(def) + "."; + ServerInstance->Logs->Log("CONFIG", LOG_DEFAULT, message); + num = def; + } + /** 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. @@ -452,19 +490,8 @@ long ConfigTag::getInt(const std::string &key, long def, long min, long max) long res = strtol(res_cstr, &res_tail, 0); if (res_tail == res_cstr) return def; - switch (toupper(*res_tail)) - { - case 'K': - res = res * 1024; - break; - case 'M': - res = res * 1024 * 1024; - break; - case 'G': - res = res * 1024 * 1024 * 1024; - break; - } + CheckMagnitude(tag, key, result, res, def, res_tail); CheckRange(tag, key, res, def, min, max); return res; } |