summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorPeter Powell <petpow@saberuk.com>2018-04-14 14:04:12 +0100
committerPeter Powell <petpow@saberuk.com>2018-04-16 15:07:06 +0100
commitccab908f14804776aab4c6728710e89b4847130a (patch)
tree63d6ae2ca725ceabfe1da51a42dd2f5d931c106d
parent7c2adcb46a01c7cf0f0e6f5aeeef070232e7d222 (diff)
Extract ConfigTag::getInt magnitude logic to a function template.
-rw-r--r--src/configparser.cpp51
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;
}