#include <iostream>
using namespace std;
class Base
{
public:
//virtual void FunBase() = 0;
virtual int QueryInterface(int n,void** ppv) = 0;
};
class SubBaseA:public Base
{
public:
virtual void FunSubBaseA() = 0;
virtual void Cool()
{
cout<<"SubBaseA::Cool"<<endl;
}
};
class SubBaseB:public Base
{
public:
virtual void FunSubBaseB() = 0;
virtual void Cool()
{
cout<<"SubBaseB::Cool"<<endl;
}
};
class SubBaseC:public Base
{
public:
int QueryInterface(int n,void** ppv)
{
return 0;
}
//virtual void FunSubBaseC() = 0;
};
class Derived:public SubBaseA,public SubBaseB,public SubBaseC
{
public:
virtual void Cool()
{
cout<<"Derived::Cool"<<endl;
}
//void FunBase()
//{
// cout<<"Derived::FunBase"<<endl;
//}
void FunSubBaseA()
{
cout<<"Derived::FunSubBaseA"<<endl;
}
void FunSubBaseB()
{
cout<<"Derived::FunSubBaseB"<<endl;
}
//void FunSubBaseC()
//{
// cout<<"Derived::FunSubBaseC"<<endl;
//}
int QueryInterface(int n,void** ppv)
{
if (1 == n)
{
*ppv = (SubBaseA*)this;
}
else if (2 == n)
{
*ppv = (SubBaseB*)this;
}
else
{
*ppv = (SubBaseC*)this;
}
return 0;
}
};
int main()
{
Derived* pObj = new Derived;
pObj->Cool();
Base* pIBase = static_cast<Base*>(static_cast<SubBaseA*>(pObj));
SubBaseA* pIBaseA = NULL;
pIBase->QueryInterface(1,(void**)&pIBaseA);
pIBaseA->FunSubBaseA();
SubBaseC* pIBaseC = NULL;
pIBaseA->QueryInterface(3,(void**)&pIBaseC);
SubBaseB* pIBaseB = NULL;
pIBaseC->QueryInterface(2,(void**)&pIBaseB);
pIBaseB->FunSubBaseB();
//pIBaseC->FunSubBaseC();
return 0;
}
using namespace std;
class Base
{
public:
//virtual void FunBase() = 0;
virtual int QueryInterface(int n,void** ppv) = 0;
};
class SubBaseA:public Base
{
public:
virtual void FunSubBaseA() = 0;
virtual void Cool()
{
cout<<"SubBaseA::Cool"<<endl;
}
};
class SubBaseB:public Base
{
public:
virtual void FunSubBaseB() = 0;
virtual void Cool()
{
cout<<"SubBaseB::Cool"<<endl;
}
};
class SubBaseC:public Base
{
public:
int QueryInterface(int n,void** ppv)
{
return 0;
}
//virtual void FunSubBaseC() = 0;
};
class Derived:public SubBaseA,public SubBaseB,public SubBaseC
{
public:
virtual void Cool()
{
cout<<"Derived::Cool"<<endl;
}
//void FunBase()
//{
// cout<<"Derived::FunBase"<<endl;
//}
void FunSubBaseA()
{
cout<<"Derived::FunSubBaseA"<<endl;
}
void FunSubBaseB()
{
cout<<"Derived::FunSubBaseB"<<endl;
}
//void FunSubBaseC()
//{
// cout<<"Derived::FunSubBaseC"<<endl;
//}
int QueryInterface(int n,void** ppv)
{
if (1 == n)
{
*ppv = (SubBaseA*)this;
}
else if (2 == n)
{
*ppv = (SubBaseB*)this;
}
else
{
*ppv = (SubBaseC*)this;
}
return 0;
}
};
int main()
{
Derived* pObj = new Derived;
pObj->Cool();
Base* pIBase = static_cast<Base*>(static_cast<SubBaseA*>(pObj));
SubBaseA* pIBaseA = NULL;
pIBase->QueryInterface(1,(void**)&pIBaseA);
pIBaseA->FunSubBaseA();
SubBaseC* pIBaseC = NULL;
pIBaseA->QueryInterface(3,(void**)&pIBaseC);
SubBaseB* pIBaseB = NULL;
pIBaseC->QueryInterface(2,(void**)&pIBaseB);
pIBaseB->FunSubBaseB();
//pIBaseC->FunSubBaseC();
return 0;
}