comclsid

Given a Win32 COM interface locate its typelib


Consider the IUniformResourceLocator Interface defined in intshcut.h. I know how to manually define it for managed COM interop, but I'm trying to understand if I can get tlbimp to do that for me. Here's what I've tried:

Is there in fact a type library definition for it somewhere (possibly as a resource of some dll or exe) ? If so, how can I fid it?


Solution

  • You can tell from the intshcut.h SDK header file that there is no point in looking for a type library.

    The normal source of type libraries in Microsoft code is midl.exe, the compiler that translate declarations written in IDL, the Interface Description Language. This starts with an .idl file, the SDK has a bunch of them included, although not consistently. Midl auto-generates a .h file from the IDL, you can recognize them by the autogenerated /* this ALWAYS GENERATED file contains the definitions for the interfaces */ comment. That .h file is suitable for C or C++. And it generates a type library, often embedded as a resource in a DLL, suitable for other languages.

    You can locate such a type library by looking in the registry with Regedit.exe. Starting point is the HKLM\Software\Classes\Typelib key, look for the guid that matches the [uuid] attribute on the library keyword in the IDL.

    But type libraries have limitations, they were originally designed to support the Automation subset well but cannot express every possible declaration. The need to interop with any language can be very restrictive or cause too much overhead to be considered suitable. So a Microsoft programmer not uncommonly hand-crafts a .h file. Still using the COM programming style with interfaces derived from IUnknown but not using IDL to declare them. The most common examples are the shell interfaces and DirectX.

    Summarizing, strong hints that you'll have little hope of finding a type library:

    The intshcut.h header file hits almost all of these bullets. You'll have to craft the [ComImport] interface declarations by hand. Yes, very painful, small mistakes produce very hard to diagnose runtime errors. Do keep in mind that there might well be another programmer somewhere that did what you want to do. With some luck, Google will help you find his code. And keep in mind that you can always fall back to C++/CLI, a language that is very good at this kind of interop because it can directly consume the .h file.