Compilation error while using VS 2005 library in VC6 - c++

I have a library which is compiled in VS 2005 and I am trying to link it with one of the old VC 6 workspace, while linking I am getting following errors.
error LNK2001: unresolved external symbol _sprintf_s
error LNK2001: unresolved external symbol _strncpy_s
error LNK2001: unresolved external symbol _strcpy_s
error LNK2001: unresolved external symbol _strcat_s
error LNK2001: unresolved external symbol __time64
unresolved external symbol __alloca_probe_16
unresolved external symbol _main
fatal error LNK1120: 7 unresolved externals
Error executing link.exe.
Please help me in getting away with this error.

_strcpy_s is not defined in the VC6 libraries, it was added in VS2005 (or maybe VS2002/2003 ?). I don't think there's a way around it.
AFAIK, it's not usual to use a library from an earlier version of the compiler with an older version of the compiler.

I assume the above is a result of you statically linking the executable?
The _s functions are "safe" functions that Microsoft added to the runtime library to make it harder to write code with buffer overflows. They were added after VC6 (either in VS.NET or VS2003) and the functions are not present in the VC6 runtime libraries, so that is why your link is failing. The only two ways to get around this are either to build the whole set of binaries with VS2005 or with VC6. The latter is probably not a good idea as it would require you reworking the library to use the standard C functions instead.
It is generally not a good idea to mix compiler versions in static libraries and executables as the runtime libraries do change and you're left with problems like these.
You could turn your library into a DLL, but that's opening another can of worms...

Related

unresolved external symbol _WebPInitUpsamplersSSE2 - why?

I have compiled QT5.6.2 myself with Visual Studio 2015 to compile some other software (Telegram desktop; build instructions are here https://github.com/telegramdesktop/tdesktop/blob/dev/docs/building-msvc.md#setup-gypninja-and-generate-vs-solution ).
Curiously, it seems necessary to state that I know what an unresolved external symbol is - but that I still cannot solve my issue, especially since it lies within a library that is not custom-made by me: QT
Now, when I try to compile Telegram with Visual Studio 2015 which depends on QT5.6.2, I get a weird unresolved symbol:
1>qwebpd.lib(upsampling.obj) : error LNK2019: unresolved external symbol
"_WebPInitUpsamplersSSE2" in Funktion
"_WebPInitUpsamplers".
I could not find anything on this function or in which library it might/should be defined.
It seems that the QT Webkit is built with Chromium and that during QT's compilation I have somehow activated some kind of SSE2 extension which, however, does not seem to be available now in Visual Studio 2015. I have also tried in "Project Settings -> C/C++ -> Code Generation" to explicitly activate SSE2 but without help. I have no clue where this function should actually be defined.
I know in general what an unresolved external symbol is, but I do not know how to resolve this error in my specific case with QT.

meet a link error while building opengl project on win7 with visual studio 2013

The compile all goes well. However, when it goes to the link stage, error comes out:
error LNK2001: unresolved external symbol _ptrc_glClear
There're also many other errors with the same link error, including _ptr_glViewport, _ptr_glDrawArrays......
I'm searched in stackoverflow, and find many questions about the link problem of opengl32.lib. I followed their advice, but still it doesn't work.
I also notice that, the problems occurred in others' question(error LNK2019: unresolved external symbol), appear to be somewhat different: what they failed to link is with the prefix "imp", while mine is "ptr".
I wonder, is the problem of the "_ptrc_xxxxx" thing also comes with the opengl32.lib, or did I miss some other libs to link?
Are you using any kind of OpenGL loader library (GLee, GLEW, glLoadGen)? Prefixed OpenGL symbols are usually imposed on your source code by including such a loaders header (which uses some preprocessor magic to turn all OpenGL symbols in your code into symbols referring to the loader). If then your program fails to link with that very loader you'll get these unresolved symbol linker errors.

_vswprintf unresolved only for x64

I'm writing a right click context menu extension dll for Windows to support functionality in another program.
It's building fine targeting Win32, but when I try to build for x64, I get this
error LNK2001: unresolved external symbol _vswprintf
I am not actually calling it anywhere in my code, so even if it is undefined, that shouldn't be a problem. (I am including stdio.h, stdarg.h, and wchar.h though, so it should be defined.)

LNK prob. Wrapping MFC Application with /clr

I have a problem writing wrapper program to use vendor's library in .Net client program(C#).
What the vendor provided are C++ header file and MFC static library file(.lib) built on both release and debug.
The problem is, when I build wrapper program, Visual Studio 2012 spits LNK error out like this:
error LNK2001: unresolved external symbol ___argc nafxcwd.lib(appcore.obj)
error LNK2001: unresolved external symbol ___argv nafxcwd.lib(appcore.obj)
I set up build property with option /clr,
set runtime library as Multi-threaded debug DLL (/MDd),
set using MFC as MFC in shared DLL,
ignored libraries(nafxcwd.lib;msvcrtd.lib;msvcmrtd.lib;libc.lib;libcmt.lib;msvcrt.lib;libcd.lib;libcmtd.lib, see this),
added dependencies(nafxcwd.lib;msvcrtd.lib;msvcmrtd.lib;(vendor's library), for CRT, MFC library order).
What I missed?
I don't know I described enough. If something is ambiguous, please ask to me.
Thanks in advance!
ps. I'm very new to C++(even Visual Studio..). I'm more familiar with Java.

LNK2019 / 2001: unresolved external symbol

I've seen similar questions online that are problems with people forgetting to include certain things, etc. However I'm getting this error after checking out our code from subversion--others have done the same without getting this problem. My question: is there anything that could've happened on my machine to cause this linker error, either in Visual Studio settings (but not something that would affect the .sln file) or outside Visual Studio?
Lnk2019, from here states:
unresolved external symbol 'symbol' referenced in function 'function'
Lnk2001, from here states
unresolved external symbol "symbol"
Edit: The LNK2019 errors result from the initial LNK2001 error (on a problem creating a certain dll). If I get that dll from someone else on our team (and adjust the creation date to tomorrow so VS won't delete it) I can edit and debug. Of course I would like to not resort to a workaround...
There's a chance that the library you were linked to was a local copy that no longer exists on your machine. We had this happen when someone imported a library dependency and used an absolute path from their C:\ drive to specify its location.
In addition to Tony's answer, this can also happen if you have an older version of the library higher in your lib search path then where the lib you built was copied to. I'd check all the places listed in:
"Tools->Options->Projects and Solutions->VC++Directories->"Show Directories for: Library Files."