I've been trying to statically link against a C++ library called Poco on Windows using the Visual Studio 2008 command line tools.
I build my program with:
cl /I..\poco\lib /c myapp.cpp
link /libpath:..\poco\lib myapp.obj PocoNet.lib
This results in an exe that at runtime requires PocoNet.dll and PocoFoundation.dll.
I spent some time reading up on linking in Windows, and learned that cl /MT
statically links against the standard library, while cl /MD
links dynamically.
I tried to specify /MT
, but that didn't seem to change anything; my app still requires the Poco DLLs. (I also suspect that /MT
is the default behavior.)
Looking under ..\poco\lib
, I found there was also a PocoNetmt.lib, but specifying that instead of PocoNet.lib resulted in a bunch of LNK2005 errors ("already defined"):
msvcprt.lib(MSVCP90.dll) : error LNK2005: "public: __thiscall std::basic_string<char,struct std::char_traits<char>,class std::allocator<char> >::~basic_string<char,struct std::char_traits<char>,class std::allocator<char> >(void)" (??1?$basic_string@DU?$char_traits@D@std@@V?$allocator@D@2@@std@@QAE@XZ) already defined in exp.obj
I then tried stacking on more flags:
/verbose:lib
: useful for seeing what's happening/Zl
: same results as before/nodefaultlib:libcmt.lib /nodefaultlib:msvcprt.lib
: got this error:PocoFoundationmt.lib(Exception.obj) : warning LNK4217: locally defined symbol ??1?$basic_string@DU?$char_traits@D@std@@V?$allocator@D@2@@std@@QAE@XZ (public: __thiscall std::basic_string<char,struct std::char_traits<char>,class std::allocator<char> >::~basic_string<char,struct std::char_traits<char>,class std::allocator<char> >(void)) imported in function __ehhandler$??0Exception@Poco@@QAE@ABV01@@Z
dropping the
.lib
altogether, as suggested here: same error as above
I also tried some combinations of the above, all to no avail.
Any clues would be greatly appreciated. But just as useful would be any pointers to resources that are useful for debugging (or learning about) these types of issues.