Following this article, I have successfully translated C++ COM class/interface declaration into C# like this:
[InterfaceType(ComInterfaceType.InterfaceIsIUnknown), Guid(IfaceGuid)]
public interface IFoo
{
void Bar();
}
[ComImport, Guid(ClassGuid)]
public class Foo
{ }
I use it like this:
var foo = new Foo();
var ifoo = (IFoo)foo;
ifoo.Bar();
My question is, how can this possibly work, considering that Foo
doesn't implement IFoo
(even at runtime, typeof(Foo).GetInterfaces()
is empty) and that user-defined conversions to interfaces are forbidden?
Is this some special handling reserved just for COM? What does the C# specification have to say about this?
ComImport
types are treated differently compared to "normal" .NET classes, as they constitute a runtime-callable wrapper around an underlying COM coclass. Casting an instance of one of these into a COM interface type is transparently mapped into a call to the object's implementation of the COM interface methodIUnknown.QueryInterface
.If QI for the requested interface succeeds at the COM level, then the C# cast will also succeed.