Подтвердить что ты не робот

Вложенные структуры с помощью методов с использованием шаблонов

Я хочу перевести python вложенные defs на С++, который я использую с помощью вложенных структур.

#include<iostream>
static void ffunc(int x, int y)
{
    static int x1 = x;
    static int y1 = y;
    struct g
    {
        static void gfunc(int z)
        {
            static int z1 = z;
            std::cout << x1 << y1 << z << std::endl;

            struct h
            {
                static void hfunc(int k)
                {
                    std::cout<< x1 << y1 << z1 << k <<  std::endl;
                }
            };
            h::hfunc(4);
        }
    };
    g::gfunc(3);
}
int main()
{
    ffunc(1, 2);
}

Этот код работает нормально. Проблема в том, что я хочу шаблонов, так что вложенные функции могут использовать любые параметры типа. Однако, когда я пытаюсь использовать шаблоны:

#include<iostream>
template <typename t1>
static void ffunc(t1 x, t1 y)
{
    static t1 x1 = x;
    static t1 y1 = y;
    struct g
    {
        static void gfunc(int z)
        {
            static int z1 = z;
            std::cout << x1 << y1 << z << std::endl;

            struct h
            {
                static void hfunc(int k)
                {
                    std::cout<< x1 << y1 << z1 << k <<  std::endl;
                }
            };
            h::hfunc(4);
        }
    };
    g::gfunc(3);
}
int main()
{
    ffunc(1, 2);
}

Я получаю сообщение об ошибке:

/tmp/cceIMovo.o: In function `void ffunc<int>(int, int)::g::gfunc(int)':
nested.cc:(.text+0x17d): undefined reference to `y1'
nested.cc:(.text+0x183): undefined reference to `x1'
/tmp/cceIMovo.o: In function `void ffunc<int>(int, int)::g::gfunc(int)::h::hfunc(int)':
nested.cc:(.text+0x1e5): undefined reference to `z1'
nested.cc:(.text+0x1ec): undefined reference to `y1'
nested.cc:(.text+0x1f2): undefined reference to `x1'

Кто-нибудь знает, возможно ли, что я хочу сделать в С++? Спасибо!

4b9b3361

Ответ 1

Возможно, я ошибаюсь, но это похоже на ошибку компилятора. GCC (4.7.2) создает эту ошибку, в то время как Clang (3.1) и ICC (13.0.0) справляются с этим просто.

Минимальный код для воспроизведения этого на других компиляторах: http://pastebin.com/kf2sF3NL