I'm compiling my own DLL comprised of several .o files. One of the .o files has a function that calls SHLoadLibraryFromItem that is supported on Windows 7 only. The function is never called unless the application that uses the DLL is running on Windows 7. (Yes, I'm sure.)
However, when running the application on an older version of Windows (say, XP), the entire application crashes upon launch with an error "The specified procedure could not be found." Although the error doesn't specify which procedure could not be found, if I comment out the call to SHLoadLibraryFromItem, then everything works fine.
Questions:
- Why is Windows attempting to find
SHLoadLibraryFromItemeven though it's not being called on XP? - Is there any way to have Windows not do that, i.e., find
SHLoadLibraryFromItemonly when running Windows 7, i.e., some kind of lazy binding? - If not, what's the best way around this?
The only way's around this that I can think of are either:
- Use
LoadLibraryto load the Windows DLL thatSHLoadLibraryFromItemis in and useGetProcAddressto obtain the address manually into a pointer-to-function and use the pointer to callSHLoadLibraryFromIteminstead? - Have two DLLs: one that contains functions that are supported for Windows 7 that will be loaded only when running on Windows 7.
Any other ideas? I'd really prefer some kind of lazy binding as mentioned above.
Update
PLEASE READ WHAT I ACTUALLY WROTE. I clearly stated in the first paragraph that SHLoadLibraryFromItem is not called unless I KNOW FOR CERTAIN that the application ACTUALLY IS RUNNING ON WINDOWS 7.
The application crashes merely when the DLL is loaded.