The best I can imagine, is develop a C++11 substitute for std::index_sequence
and std::make_index_sequence
and apply the C++14 solution that you've linked.
But if you avoid it, you can use recursion.
Give an home made integer sequence
template <typename T, T...>
struct myIntegerSequence
{ };
and an helper struct mot_h
("make output template helper")
template <typename T, T, std::size_t, typename>
struct mot_h;
// recursive version
template <typename T, std::size_t N, const T(&A)[N], std::size_t Pos, T ... ts>
struct mot_h<const T(&)[N], A, Pos, myIntegerSequence<T, ts...>>
: mot_h<const T(&)[N], A, Pos+1u, myIntegerSequence<T, ts..., A[Pos]>>
{ };
// ground case
template <typename T, std::size_t N, const T(&A)[N], T ... ts>
struct mot_h<const T(&)[N], A, N, myIntegerSequence<T, ts...>>
{ using type = myIntegerSequence<T, ts...>; };
you can write the following template output
template <typename T, T inp>
using output = typename mot_h<T, inp, 0u,
myIntegerSequence<
typename std::remove_const<
typename std::remove_reference<decltype(inp[0])>::type>::type>
>::type;
The following is a full compiling C++11 example
#include <type_traits>
template <typename T, T...>
struct myIntegerSequence
{ };
constexpr int input[] = { 2, 3, 5, 7, 11, 13, 17, 19 };
template <std::size_t N, typename T, const T (&A)[N]>
struct foo
{ };
template <typename T, T, std::size_t, typename>
struct mot_h;
template <typename T, std::size_t N, const T(&A)[N], std::size_t Pos, T ... ts>
struct mot_h<const T(&)[N], A, Pos, myIntegerSequence<T, ts...>>
: mot_h<const T(&)[N], A, Pos+1u, myIntegerSequence<T, ts..., A[Pos]>>
{ };
template <typename T, std::size_t N, const T(&A)[N], T ... ts>
struct mot_h<const T(&)[N], A, N, myIntegerSequence<T, ts...>>
{ using type = myIntegerSequence<T, ts...>; };
template <typename T, T inp>
using output = typename mot_h<T, inp, 0u,
myIntegerSequence<
typename std::remove_const<
typename std::remove_reference<decltype(inp[0])>::type>::type>
>::type;
int main ()
{
using target = myIntegerSequence<int, 2, 3, 5, 7, 11, 13, 17, 19>;
static_assert( std::is_same<output<decltype((input)), input>,
target>::value, "!" );
}