1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81
|
template<typename T>
using operator_t=T(*)(const T&, const T&);
template<typename T>
using comp_t=bool(*)(const T&, const T&);
template<typename T1, typename T2>
using log_t=bool(*)(const T1&, const T2&);
struct not_an_op: exception
{
virtual const char* what() const throw()
{
return "Not an operator!";
}
};
struct not_a_comp: exception
{
virtual const char* what() const throw()
{
return "Not a comparator!";
}
};
struct not_a_log: exception
{
virtual const char* what() const throw()
{
return "Not a logical operator!";
}
};
template<typename T>
operator_t<T> char_to_op(char c) throw(not_an_op)
{
switch(c)
{
case '+':
return [](const T& a, const T& b){return a+b;};
break;
case '-':
return [](const T& a, const T& b){return a-b;};
break;
case '*':
return [](const T& a, const T& b){return a*b;};
break;
case '/':
return [](const T& a, const T& b){return a/b;};
break;
case '^':
return [](const T& a, const T& b){return T(pow(a, b));};
break;
case '=':
return [](const T& a, const T& b){return const_cast<T&>(a)=b;};
break;
default:
throw not_an_op();
}
}
template<typename T>
comp_t<T> string_to_op(string a) throw(not_an_op)
{
if (a=="==") return [](const T& a, const T& b){return a==b;};
if (a=="!=") return [](const T& a, const T& b){return a!=b;};
if (a=="<") return [](const T& a, const T& b){return a<b;};
if (a==">") return [](const T& a, const T& b){return a>b;};
if (a=="<=") return [](const T& a, const T& b){return a<=b;};
if (a==">=") return [](const T& a, const T& b){return a>=b;};
throw not_a_comp();
}
template<typename T1=bool, typename T2=bool>
log_t<T1, T2> string_to_log(string a) throw(not_a_log)
{
if (a=="&&") return [](const T1& a, const T2& b){return a&&b;};
if (a=="||") return [](const T1& a, const T2& b){return a&&b;};
if (a=="^^") return [](const T1& a, const T2& b){return a||b && a!=b;};
throw not_a_log();
}
|