Я хотел бы проверить во время компиляции, содержат ли различные перечисления данное значение, поэтому я написал следующее:
#include <optional>
enum class test_enum : int {
VALUE_0 = 0,
VALUE_1 = 1
};
// Template function to perform check
template<typename T>
constexpr std::optional<T> from_int(int value)
{
static_assert(false, __FUNCTION__ " not implemented for this type; see build output");
return std::optional<T>();
}
// Specialization for test_enum
template<>
constexpr std::optional<test_enum> from_int(int value)
{
switch (value) {
case static_cast<int>(test_enum::VALUE_0) :
return test_enum::VALUE_0;
case static_cast<int>(test_enum::VALUE_1):
return test_enum::VALUE_1;
default:
return std::optional<test_enum>();
}
}
int main(int argc, char* argv[])
{
static_assert(from_int<test_enum>(1));
return 0;
}
При использовании Visual Studio 2017 (версия 15.8.6),код успешно компилируется без ошибок в выводе.Тем не менее, в окне ошибки отображаются
E0028: expression must have a constant value" at line 30. (the first line of main)
и
"std::_Optional_construct_base<test_enum>::_Optional_construct_base(std::in_place_t, _Types &&..._Args) [with _Types=<test_enum>]" (declared implicitly) is not defined)".
Любые подсказки, почему это так?Я могу игнорировать E0028, но я бы предпочел не делать этого, если это возможно.
РЕДАКТИРОВАТЬ: Удаление static_assert из from_int не меняет ошибку.