summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorPeter Powell <petpow@saberuk.com>2018-04-14 13:17:20 +0100
committerPeter Powell <petpow@saberuk.com>2018-04-16 15:07:06 +0100
commit7c2adcb46a01c7cf0f0e6f5aeeef070232e7d222 (patch)
tree0576962a22b5d0b71cb8536923ad31f73ae9bafd
parent7ef2f87e39bd22c7914caf7f2afbb1a3bf8fbd43 (diff)
Convert ConfigTag::CheckRange to a function template.
-rw-r--r--include/configreader.h10
-rw-r--r--src/configparser.cpp38
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;
}