Developing with COM Components

RookPSU

New member
Joined
Apr 6, 2005
Messages
1
I have a few Com.dlls that I use in a multiple of my applications. These are in house .dlls which are rebuilt a few times a month when we discover bugs or decide to add minor functionality.

Since Ive started building in .NET Ive been forced to create (or at least I assumed this was the ideal way) primary interops for these .dlls and stick them in my GAC. Therefore all the applications (VB6 or VB.NET) that use the .dll can pull from the same file. The only problem is, it seems everytime I build my COM.DLL I have to create a new primary interop and install it in the GAC. My question is, if I choose not to auto-increment the dll version on build (assuming i m not changing the interface) can I continue to work without recreating an new interop?

I have yet to find the reccommended way of building with COM components in the manner that I do. From what ive been able to ascertain it seems that the GAC is something that should only be utilized on the client machine - UNLESS youre working with interops.

Any help would be appreciated.

-Ryan
 
RookPSU said:
My question is, if I choose not to auto-increment the dll version on build (assuming i m not changing the interface) can I continue to work without recreating an new interop?
Im going to guess that the answer to this is "no". That is, you would have to keep creating a new Primary Interop every time.

Ive not played with what you are taking about, but here is my thinking...

Each time you change your COM.DLL, even if you do not "break binary", and therefore maintain the same GUID, you are still potentially adding functionality. .Net will not recognize the new functionality unless a new PIA is made for it. It is possible that an older-generated PIA is still functional (and therefore a candidate for the GAC), but you would have to test this I think. In theory, if you do not break binary, then all the VTables should be the same and so the old PIA could work, but there may be more to this on the .Net side of things that dont allow an old PIA to actually work with an updated COM DLL.

As for putting an Interop PIA in the GAC, I dont know how important that is. When you use, say, MS Office 2002 or MS Office 2003, its best if one references the PIAs found in the GAC and not make (or distribute) a locally-created PIA. But as for functionalty, I dont think it really matters; the point of doing this is that if MSFT offers patches or updates to the PIA, your local version would not see the fix. Beyond that, I dont really see the "big deal", but I could be missing something here, Im not sure...

For your own COM DLLs, esp. if they are changing, I dont really see the benefit of going through the hassle of putting it in the GAC. I would just distribute any updated DLL along with the updated PIA.

-- Mike
 
Back
Top