]> git.stg.codes - stg.git/blobdiff - stglibs/srvconf.lib/parsers/get_tariff.cpp
Merge remote-tracking branch 'origin/master' into ticket
[stg.git] / stglibs / srvconf.lib / parsers / get_tariff.cpp
index d929b26631f277fa823e532c23ed49ff1126c0a8..4844fd6c77fdbec69de28fe50aa46321c2414e6f 100644 (file)
@@ -97,28 +97,22 @@ else
 return true;
 }
 
 return true;
 }
 
+template <typename T>
 bool GetChangePolicy(const char ** attr, T & value, const std::string & attrName)
 {
 if (!CheckValue(attr, attrName))
     return false;
 std::string type(attr[1]);
 bool GetChangePolicy(const char ** attr, T & value, const std::string & attrName)
 {
 if (!CheckValue(attr, attrName))
     return false;
 std::string type(attr[1]);
-switch (type)
-    {
-    case "allow":
+if (type == "allow")
         value = TARIFF::ALLOW;
         value = TARIFF::ALLOW;
-        break;
-    case "to_cheap":
+else if (type == "to_cheap")
         value = TARIFF::TO_CHEAP;
         value = TARIFF::TO_CHEAP;
-        break;
-    case "to_expensive":
+else if (type == "to_expensive")
         value = TARIFF::TO_EXPENSIVE;
         value = TARIFF::TO_EXPENSIVE;
-        break;
-    case "deny":
+else if (type == "deny")
         value = TARIFF::DENY;
         value = TARIFF::DENY;
-        break;
-    default:
-        return false;
-    }
+else
+    return false;
 return true;
 }
 
 return true;
 }