Мне нужна оболочка constexpr над массивом C или std::array
с некоторыми дополнительными конструкторами (аналогично конструкторам std::vector
):
template<class T, int N>
struct wrapper {
T data[N];
constexpr wrapper(int s); // a
constexpr wrapper(int j, int k); // b
constexpr wrapper(...values...) // c
: data(...values...) {}
};
Я пытаюсь получить то же поведение, что и конструкторы std::vector
, то есть:
constexpr wrapper<T,2> w(1); // calls a
constexpr wrapper<T,2> w(1,2); // calls b
constexpr wrapper<T,2> w{1}; // calls c
constexpr wrapper<T,2> w{1,2}; // calls c
Примечание 1: идеальный конструктор пересылки:
template<class... Args>
constexpr wrapper(T&& t, Args&&... args)
: data(std::forward<T>(t), std::forward<Args>(args)...) {}
победит других конструкторов.
Примечание 2: T[N]/std::array<T,N>
не имеет конструкторов std::initializer_list<T>
, поэтому следующее тоже не работает:
constexpr wrapper(std::initializer_list<T> v) : data(std::move(v)) {}
Примечание 3: если значения не присвоены в списке инициализации конструктора, тип оболочки не будет работать в константных выражениях.