views:

4248

answers:

8

I am using a makefile system with the pvcs compiler (using Microsoft Visual C++, 2008 compiler) and I am getting several link errors of the form:

error LNK2019: unresolved external symbol __imp__RegisterFilter@8 referenced in function _main

This is happening DESPITE using the extern "C" declaration, viz.:

extern "C" int CLRDUMP_API RegisterFilter( LPCWSTR pDumpFileName, unsigned long DumpType );

Also, in the makeexe.mak, the library is being linked in as:

$(COMPILEBASE)\lib\clrdump.lib \

To be honest, I am not an expert at makefiles, and I am changing over a system from Microsoft Visual C++ 6.0 to 2008. This change-over may have something to do with the link errors, as the system used to work before.

Any help would really be appreciated.

Thanks in Advance,

Sincerely, Joseph

A: 

Try turning on verbose output for your linker (typically a command-line switch). That will show you exactly how the linker is trying to resolve the symbol, so you can see if:

  • the symbol's signature is what you expect
  • the linker is looking in the right location for your library

I hope this helps!

Brian
A: 

Does anyone know how to turn verbose on in the makefile system of pvcs?

Note that the above function is already a compiler-decorated version, having

__imp__RegisterFilter@8

whereas the C++ function is just

RegisterFilter

Thanks for the help, but if anyone can post a more complete solution, that would also be very appreciated.

Sincerely, Joseph

A: 

Some kind person posted this, but when I signed in it disappeared:

The imp prefix indicates that this function is imported from a DLL. Check the definition of CLRDUMP_API - is it __declspec(dllimport)? See this article for more information.

There was a working link, but I've lost that, however I suppose one can always search the topic.

Thanks, whoever you were!

I deleted the answer because it doesn't solve your problem. Here's the link: http://msdn.microsoft.com/en-us/library/3y1sfaz2.aspx
ChrisN
A: 

Thanks ChrisN (I'm not yet allowed to vote). Despite using the refresh button, your answer disappeared, but then re-appeared after I posted a cut-n-paste.

This is my definition of that:

define CLRDUMP_API __declspec(dllimport) __stdcall

I assume that the __stdcall is OK?

On StackOverflow, you should add more information by editing your original question rather than adding new answers.
ChrisN
+3  A: 

The __imp_ prefix indicates that the linker expects this function to be imported from a DLL.

Is the clrdump library from this page? If so, note that extern "C" is not used in the header file supplied with the library. I confirmed this using the following command:

dumpbin /exports clrdump.lib

which produces the following output for RegisterFilter - this is a mangled C++ function name:

?RegisterFilter@@YGHPBGK@Z (int __stdcall RegisterFilter(unsigned short const *,unsigned long))

I tried creating a sample program using clrdump.lib using Visual Studio 2008. Here's my code:

#include <windows.h>
#include "ClrDump.h"

int _tmain(int argc, _TCHAR* argv[])
{
    RegisterFilter(L"", 0);
    return 0;
}

Building this produced the following linker error:

LNK2019: unresolved external symbol "__declspec(dllimport) int __stdcall RegisterFilter(wchar_t const *,unsigned long)" (__imp_?RegisterFilter@@YGHPB_WK@Z)

The code builds OK with Visual C++ 6.0.

Notice that the dumpbin output shows the first parameter to RegisterFilter as unsigned short const * but the linker error shows wchar_t const *. In Visual C++ 6.0, wchar_t is normally a typedef for unsigned short, whereas in later versions it is a distinct built-in type.

To work around the problem in Visual Studio 2008, I set the "Treat wchar_t as Built-in Type" option to "No" (specify /Zc:wchar_t- on the compiler command line), and the code now builds OK.

Sorry for the confusion with my previous answer. I hope this is more helpful!

ChrisN
Without seeing more of your code, I don't think I'm able to help further. Do you have the source code for the library?
ChrisN
A: 

While I appreciate the efforts of those who answered, particularly ChrisN, at least on my particular system, the link error remains. So if anyone has any further insight, I'd appreciate it. Thanks again.

A: 

i was creating a simple win32 c++ application in vs2005 and i was getting this error,

LNK2019: unresolved external symbol _imp_somefunction

this application was using propertysheets hence it required this header (prsht.h)

the solution to my problem was as follows,

in program properties-->configuration properties-->linker-->General i set [additional library Directories] to "c:\Program Files\Microsoft Visual Studio 8\VC\PlatformSDK\Lib"

also in program properties-->configuration properties-->linker-->Command line for the [additional options] i added ComCtl32.Lib ComDlg32.Lib

my program is now compiling without any problems

my two cents ---> you need to identify all the libraries that your program requires hint:check all the headers you have included

              you need to make sure that your liker can see them.
antonymken
A: 

I am also working on porting a C++ 6.0 project to Visual Studio 2008. I have not been able to get a batch or makefile to work yet! I'm in the same boat as Joseph here.