Имея (не беспокойтесь о длине этого кода, сконцентрируйтесь на struct X и Range) (вы можете скопировать и вставить и должны скомпилировать):
EDITED
#include <limits.h>
#include <type_traits>
//This is from file "Static_limits.h"
template<class T>struct static_numeric_limits;
template<>struct static_numeric_limits<signed char>
{
enum {min = SCHAR_MIN,max = SCHAR_MAX};
};
/*This "surplus" template is here for the reason that char is threated diferently from signed char */
template<>struct static_numeric_limits<char>
{
enum {min = SCHAR_MIN,max = SCHAR_MAX};
};
template<>struct static_numeric_limits<unsigned char>
{
enum {min = 0x0,max = UCHAR_MAX};
};
template<>struct static_numeric_limits<unsigned short>
{
enum {min = 0x0,max = USHRT_MAX};
};
template<>struct static_numeric_limits<signed short>
{
enum {min = SHRT_MIN,max = SHRT_MAX};
};
template<>struct static_numeric_limits<unsigned int>
{
enum {min = 0x0,max = UINT_MAX};
};
template<>struct static_numeric_limits<signed int>
{
enum {min = INT_MIN,max = INT_MAX};
};
template<>struct static_numeric_limits<unsigned long>
{
enum {min = 0x0,max = ULONG_MAX};
};
template<>struct static_numeric_limits<signed long>
{
enum {min = LONG_MIN,max = LONG_MAX};
};
template<>struct static_numeric_limits<unsigned long long>
{
static const long long min = 0x0;
static const long long max = ULLONG_MAX;
};
template<>struct static_numeric_limits<signed long long>
{
#define LLONG_MAX 9223372036854775807LL
/* maximum signed long long int value */
static const long long min = LLONG_MIN;
static const long long max = LLONG_MAX;
};
//This is from main.cpp
typedef unsigned long long uint_64;
typedef signed long long int_64;
/*Validates range*/
template<class IntType, uint_64 value_,bool C = std::is_signed<IntType>::value>
struct validate_range;
template<class IntType,uint_64 value_>
struct validate_range<IntType,value_,true>
{
enum {value = (static_cast<int_64>(value_) >= static_numeric_limits<IntType>::min) &&
(static_cast<int_64>(value_) <= static_numeric_limits<IntType>::max)
};
};
template<class IntType,uint_64 value_>
struct validate_range<IntType,value_,false>
{
enum {value = (value_ >= static_numeric_limits<IntType>::min) &&
(value_ <= static_numeric_limits<IntType>::max)
};
};
template<class IntType, IntType value>
struct Range
{
private:
const IntType value_;
protected:
const IntType getRange()const
{
return value_;
} public:
Range():value_(value)
{
/*eb*/
}
//this static assert in here won't work even though this class is a base class for Low
static_assert((validate_range<IntType, value>::value),"Value constant is out of range");
};
template<class IntType, IntType value>
struct Low : private Range<IntType,value>//HERE Range IS INHERITED BY Low
{
const IntType getLowRange()const
{
return Range<IntType,value>::getRange();
}
};
template<typename IntType, uint_64 low_range>
struct X : public Low<IntType,low_range>
{};
//static_assert((validate_range<IntType, Value>::value),"Value constant is out of range");//this static doesn't work if placed in Low's base class namely Range };
int main(int argc, char** argv)
{
X<unsigned char, -2> x4;//this should fail
return 0;
}
Итак, в основном я спрашиваю, почему static_assert ((validate_range :: value), ... не работает, если помещен в структуру Range, которая, в свою очередь, является базовым классом для Low, который в свою очередь является базовым X, но работает, если помещен непосредственно в структуру X
EDITED
Ребята, мне очень жаль за предыдущий код. Я отредактировал свой пост, и на этот раз он должен работать (разоблачая реальную проблему). Еще раз, извините за последний код, я просто не знаю, что случилось.