Наследовать сигнал в libs
Я использую библиотеку libsourcey для обучения. Я пытаюсь написать новый класс, который наследует класс с именем Signal.
в свободном доступе
template <typename RT> class Signal;
template <typename RT, typename... Args> class Signal<RT(Args...)> {...}
и мой путь
template <typename RT> class NewSignal;
template <typename RT, typename... Args> class NewSignal<RT(Args...)> : public Signal<RT(Args...)> {...}
но я не могу получить доступ к любому свойству класса Signal, а также атрибута (хотя я изменяю атрибут для общественности). Отчет Complier (затмение): was not declared in this scope
пример
У меня 2 класс
класс B
template<class RT> class B;
template<class RT, class... Args>
class B<RT(Args...)> {
public:
B(int value = 0) : m_i(value) {}
~B() {}
void print() {
std::cout << "i = " << m_i << std::endl;
}
int m_i;
};
класс А
template<class RT> class A;
template<class RT, class... Args>
class A<RT(Args...)> : public B<RT(Args...)> {
public:
A(int value = 0) : B<RT(Args...)>(value) {}
virtual ~A() {}
void print() {
std::cout << "i = " << 2 * m_i << std::endl;
}
};
и main.cpp
#include "Aclass.hpp"
#include "Bclass.hpp"
int main(int argc, char* argv[]) {
B<void(void)> b(1);
b.print();
A<void(void)> a(2);
a.print();
return 0;
}
Но когда я изменюсь std::cout << "i = " << 2 * m_i << std::endl;
в классе А до std::cout << "i = " << 2 * B<RT(Args...)>::m_i << std::endl;
затем сборка завершена, ошибок нет.
Кто-нибудь объяснит, почему отчет компилятора такой. Как я могу унаследовать класс сигнала. Если нет, есть какое-нибудь решение? Спасибо за поддержку.