Skip to content
This repository has been archived by the owner on Jul 11, 2023. It is now read-only.

linking on vs2010 fails #68

Open
GoogleCodeExporter opened this issue Mar 17, 2015 · 2 comments
Open

linking on vs2010 fails #68

GoogleCodeExporter opened this issue Mar 17, 2015 · 2 comments

Comments

@GoogleCodeExporter
Copy link

What steps will reproduce the problem?

1. svn checkout http://ticpp.googlecode.com/svn/trunk/ ticpp ( checked out 
revision 124 )
2. cd ticpp && premake4 vs2008
3. Open and build in vs2010, converting project to vs2010 format when prompted

Use the following test program or similar:
#pragma comment(lib, "ticppd.lib")
#include <ticpp.h>

void TinyXmlAllThat();

int _tmain(int argc, _TCHAR* argv[])
{
    TinyXmlAllThat();
    std::cin.get();

    return 0;
}

void TinyXmlAllThat()
{
    try
    {
        ticpp::Document doc( "c:\\tiny.xml" );
        doc.LoadFile();

        ticpp::Element* pElem = doc.FirstChildElement();
    }
    catch( const ticpp::Exception & ex )
    {
        std::cout << ex.what();
    }
}

What is the expected output? What do you see instead?
Expect link stage to succeed.  Instead, I get the linker errors pasted at the 
end of this message


What version of the product are you using? On what operating system?
OS platform is Windows 7 x64, VS2010, ticpp revision 124.


1>------ Build started: Project: ScratchMe, Configuration: Debug Win32 ------
1>  stdafx.cpp
1>  ScratchMe.cpp
1>msvcprtd.lib(MSVCP100D.dll) : error LNK2005: "public: int __thiscall 
std::basic_istream<char,struct std::char_traits<char> >::get(void)" 
(?get@?$basic_istream@DU?$char_traits@D@std@@@std@@QAEHXZ) already defined in 
ticppd.lib(tinyxmlparser.obj)
1>msvcprtd.lib(MSVCP100D.dll) : error LNK2005: "public: class 
std::basic_ostream<char,struct std::char_traits<char> > & __thiscall 
std::basic_ostream<char,struct std::char_traits<char> >::operator<<(int)" 
(??6?$basic_ostream@DU?$char_traits@D@std@@@std@@QAEAAV01@H@Z) already defined 
in ticppd.lib(ticpp.obj)
1>msvcprtd.lib(MSVCP100D.dll) : error LNK2005: "public: virtual __thiscall 
std::basic_ios<char,struct std::char_traits<char> >::~basic_ios<char,struct 
std::char_traits<char> >(void)" 
(??1?$basic_ios@DU?$char_traits@D@std@@@std@@UAE@XZ) already defined in 
ticppd.lib(ticpp.obj)
1>msvcprtd.lib(MSVCP100D.dll) : error LNK2005: "public: virtual __thiscall 
std::basic_ostream<char,struct std::char_traits<char> 
>::~basic_ostream<char,struct std::char_traits<char> >(void)" 
(??1?$basic_ostream@DU?$char_traits@D@std@@@std@@UAE@XZ) already defined in 
ticppd.lib(ticpp.obj)
1>msvcprtd.lib(MSVCP100D.dll) : error LNK2005: "public: __thiscall 
std::basic_ostream<char,struct std::char_traits<char> 
>::basic_ostream<char,struct std::char_traits<char> >(class 
std::basic_streambuf<char,struct std::char_traits<char> > *,bool)" 
(??0?$basic_ostream@DU?$char_traits@D@std@@@std@@QAE@PAV?$basic_streambuf@DU?$ch
ar_traits@D@std@@@1@_N@Z) already defined in ticppd.lib(ticpp.obj)
1>msvcprtd.lib(MSVCP100D.dll) : error LNK2005: "protected: __thiscall 
std::basic_ios<char,struct std::char_traits<char> >::basic_ios<char,struct 
std::char_traits<char> >(void)" 
(??0?$basic_ios@DU?$char_traits@D@std@@@std@@IAE@XZ) already defined in 
ticppd.lib(ticpp.obj)
1>msvcprtd.lib(MSVCP100D.dll) : error LNK2005: "public: virtual __thiscall 
std::basic_streambuf<char,struct std::char_traits<char> 
>::~basic_streambuf<char,struct std::char_traits<char> >(void)" 
(??1?$basic_streambuf@DU?$char_traits@D@std@@@std@@UAE@XZ) already defined in 
ticppd.lib(ticpp.obj)
1>msvcprtd.lib(MSVCP100D.dll) : error LNK2005: "protected: char * __thiscall 
std::basic_streambuf<char,struct std::char_traits<char> >::gptr(void)const " 
(?gptr@?$basic_streambuf@DU?$char_traits@D@std@@@std@@IBEPADXZ) already defined 
in ticppd.lib(ticpp.obj)
1>msvcprtd.lib(MSVCP100D.dll) : error LNK2005: "protected: void __thiscall 
std::basic_streambuf<char,struct std::char_traits<char> >::setg(char *,char 
*,char *)" (?setg@?$basic_streambuf@DU?$char_traits@D@std@@@std@@IAEXPAD00@Z) 
already defined in ticppd.lib(ticpp.obj)
1>msvcprtd.lib(MSVCP100D.dll) : error LNK2005: "protected: void __thiscall 
std::basic_streambuf<char,struct std::char_traits<char> >::setp(char *,char *)" 
(?setp@?$basic_streambuf@DU?$char_traits@D@std@@@std@@IAEXPAD0@Z) already 
defined in ticppd.lib(ticpp.obj)
1>msvcprtd.lib(MSVCP100D.dll) : error LNK2005: "protected: char * __thiscall 
std::basic_streambuf<char,struct std::char_traits<char> >::eback(void)const " 
(?eback@?$basic_streambuf@DU?$char_traits@D@std@@@std@@IBEPADXZ) already 
defined in ticppd.lib(ticpp.obj)
1>msvcprtd.lib(MSVCP100D.dll) : error LNK2005: "protected: char * __thiscall 
std::basic_streambuf<char,struct std::char_traits<char> >::_Pninc(void)" 
(?_Pninc@?$basic_streambuf@DU?$char_traits@D@std@@@std@@IAEPADXZ) already 
defined in ticppd.lib(ticpp.obj)
1>msvcprtd.lib(MSVCP100D.dll) : error LNK2005: "protected: void __thiscall 
std::basic_streambuf<char,struct std::char_traits<char> >::setp(char *,char 
*,char *)" (?setp@?$basic_streambuf@DU?$char_traits@D@std@@@std@@IAEXPAD00@Z) 
already defined in ticppd.lib(ticpp.obj)
1>msvcprtd.lib(MSVCP100D.dll) : error LNK2005: "protected: char * __thiscall 
std::basic_streambuf<char,struct std::char_traits<char> >::pbase(void)const " 
(?pbase@?$basic_streambuf@DU?$char_traits@D@std@@@std@@IBEPADXZ) already 
defined in ticppd.lib(ticpp.obj)
1>msvcprtd.lib(MSVCP100D.dll) : error LNK2005: "protected: char * __thiscall 
std::basic_streambuf<char,struct std::char_traits<char> >::epptr(void)const " 
(?epptr@?$basic_streambuf@DU?$char_traits@D@std@@@std@@IBEPADXZ) already 
defined in ticppd.lib(ticpp.obj)
1>msvcprtd.lib(MSVCP100D.dll) : error LNK2005: "protected: char * __thiscall 
std::basic_streambuf<char,struct std::char_traits<char> >::pptr(void)const " 
(?pptr@?$basic_streambuf@DU?$char_traits@D@std@@@std@@IBEPADXZ) already defined 
in ticppd.lib(ticpp.obj)
1>msvcprtd.lib(MSVCP100D.dll) : error LNK2005: "protected: void __thiscall 
std::basic_streambuf<char,struct std::char_traits<char> >::gbump(int)" 
(?gbump@?$basic_streambuf@DU?$char_traits@D@std@@@std@@IAEXH@Z) already defined 
in ticppd.lib(ticpp.obj)
1>msvcprtd.lib(MSVCP100D.dll) : error LNK2005: "protected: char * __thiscall 
std::basic_streambuf<char,struct std::char_traits<char> >::egptr(void)const " 
(?egptr@?$basic_streambuf@DU?$char_traits@D@std@@@std@@IBEPADXZ) already 
defined in ticppd.lib(ticpp.obj)
1>msvcprtd.lib(MSVCP100D.dll) : error LNK2005: "protected: void __thiscall 
std::basic_streambuf<char,struct std::char_traits<char> >::pbump(int)" 
(?pbump@?$basic_streambuf@DU?$char_traits@D@std@@@std@@IAEXH@Z) already defined 
in ticppd.lib(ticpp.obj)
1>msvcprtd.lib(MSVCP100D.dll) : error LNK2005: "public: __thiscall 
std::_Container_base12::~_Container_base12(void)" 
(??1_Container_base12@std@@QAE@XZ) already defined in ticppd.lib(ticpp.obj)
1>msvcprtd.lib(MSVCP100D.dll) : error LNK2005: "public: __thiscall 
std::_Container_base12::_Container_base12(void)" 
(??0_Container_base12@std@@QAE@XZ) already defined in ticppd.lib(ticpp.obj)
1>msvcprtd.lib(MSVCP100D.dll) : error LNK2005: "public: void __thiscall 
std::_Container_base12::_Orphan_all(void)" 
(?_Orphan_all@_Container_base12@std@@QAEXXZ) already defined in 
ticppd.lib(ticpp.obj)
1>msvcprtd.lib(MSVCP100D.dll) : error LNK2005: "protected: __thiscall 
std::basic_streambuf<char,struct std::char_traits<char> 
>::basic_streambuf<char,struct std::char_traits<char> >(void)" 
(??0?$basic_streambuf@DU?$char_traits@D@std@@@std@@IAE@XZ) already defined in 
ticppd.lib(ticpp.obj)
1>msvcprtd.lib(MSVCP100D.dll) : error LNK2005: "public: void __thiscall 
std::basic_ios<char,struct std::char_traits<char> >::setstate(int,bool)" 
(?setstate@?$basic_ios@DU?$char_traits@D@std@@@std@@QAEXH_N@Z) already defined 
in ticppd.lib(ticpp.obj)
1>msvcprtd.lib(MSVCP100D.dll) : error LNK2005: "public: __int64 __thiscall 
std::ios_base::width(__int64)" (?width@ios_base@std@@QAE_J_J@Z) already defined 
in ticppd.lib(ticpp.obj)
1>msvcprtd.lib(MSVCP100D.dll) : error LNK2005: "public: __int64 __thiscall 
std::basic_streambuf<char,struct std::char_traits<char> >::sputn(char const 
*,__int64)" 
(?sputn@?$basic_streambuf@DU?$char_traits@D@std@@@std@@QAE_JPBD_J@Z) already 
defined in ticppd.lib(ticpp.obj)
1>msvcprtd.lib(MSVCP100D.dll) : error LNK2005: "public: int __thiscall 
std::basic_streambuf<char,struct std::char_traits<char> >::sputc(char)" 
(?sputc@?$basic_streambuf@DU?$char_traits@D@std@@@std@@QAEHD@Z) already defined 
in ticppd.lib(ticpp.obj)
1>msvcprtd.lib(MSVCP100D.dll) : error LNK2005: "public: class 
std::basic_streambuf<char,struct std::char_traits<char> > * __thiscall 
std::basic_ios<char,struct std::char_traits<char> >::rdbuf(void)const " 
(?rdbuf@?$basic_ios@DU?$char_traits@D@std@@@std@@QBEPAV?$basic_streambuf@DU?$cha
r_traits@D@std@@@2@XZ) already defined in ticppd.lib(ticpp.obj)
1>msvcprtd.lib(MSVCP100D.dll) : error LNK2005: "public: char __thiscall 
std::basic_ios<char,struct std::char_traits<char> >::fill(void)const " 
(?fill@?$basic_ios@DU?$char_traits@D@std@@@std@@QBEDXZ) already defined in 
ticppd.lib(ticpp.obj)
1>msvcprtd.lib(MSVCP100D.dll) : error LNK2005: "public: int __thiscall 
std::ios_base::flags(void)const " (?flags@ios_base@std@@QBEHXZ) already defined 
in ticppd.lib(ticpp.obj)
1>msvcprtd.lib(MSVCP100D.dll) : error LNK2005: "public: __int64 __thiscall 
std::ios_base::width(void)const " (?width@ios_base@std@@QBE_JXZ) already 
defined in ticppd.lib(ticpp.obj)
1>msvcprtd.lib(MSVCP100D.dll) : error LNK2005: "public: class 
std::basic_ostream<char,struct std::char_traits<char> > & __thiscall 
std::basic_ostream<char,struct std::char_traits<char> >::flush(void)" 
(?flush@?$basic_ostream@DU?$char_traits@D@std@@@std@@QAEAAV12@XZ) already 
defined in ticppd.lib(ticpp.obj)
1>msvcprtd.lib(MSVCP100D.dll) : error LNK2005: "public: class 
std::basic_ostream<char,struct std::char_traits<char> > * __thiscall 
std::basic_ios<char,struct std::char_traits<char> >::tie(void)const " 
(?tie@?$basic_ios@DU?$char_traits@D@std@@@std@@QBEPAV?$basic_ostream@DU?$char_tr
aits@D@std@@@2@XZ) already defined in ticppd.lib(ticpp.obj)
1>msvcprtd.lib(MSVCP100D.dll) : error LNK2005: "public: bool __thiscall 
std::ios_base::good(void)const " (?good@ios_base@std@@QBE_NXZ) already defined 
in ticppd.lib(ticpp.obj)
1>msvcprtd.lib(MSVCP100D.dll) : error LNK2005: "public: void __thiscall 
std::basic_ostream<char,struct std::char_traits<char> >::_Osfx(void)" 
(?_Osfx@?$basic_ostream@DU?$char_traits@D@std@@@std@@QAEXXZ) already defined in 
ticppd.lib(ticpp.obj)
1>msvcprtd.lib(MSVCP100D.dll) : error LNK2005: "public: class 
std::locale::facet * __thiscall std::locale::facet::_Decref(void)" 
(?_Decref@facet@locale@std@@QAEPAV123@XZ) already defined in 
ticppd.lib(ticpp.obj)
1>libcpmtd.lib(ios.obj) : error LNK2005: "private: static void __cdecl 
std::ios_base::_Ios_base_dtor(class std::ios_base *)" 
(?_Ios_base_dtor@ios_base@std@@CAXPAV12@@Z) already defined in 
msvcprtd.lib(MSVCP100D.dll)
1>libcpmtd.lib(ios.obj) : error LNK2005: "public: static void __cdecl 
std::ios_base::_Addstd(class std::ios_base *)" 
(?_Addstd@ios_base@std@@SAXPAV12@@Z) already defined in 
msvcprtd.lib(MSVCP100D.dll)
1>libcpmtd.lib(locale0.obj) : error LNK2005: "private: static void __cdecl 
std::locale::facet::_Facet_Register(class std::locale::facet *)" 
(?_Facet_Register@facet@locale@std@@CAXPAV123@@Z) already defined in 
msvcprtd.lib(locale0_implib.obj)
1>libcpmtd.lib(locale0.obj) : error LNK2005: "private: static class 
std::locale::_Locimp * __cdecl std::locale::_Getgloballocale(void)" 
(?_Getgloballocale@locale@std@@CAPAV_Locimp@12@XZ) already defined in 
msvcprtd.lib(MSVCP100D.dll)
1>libcpmtd.lib(locale0.obj) : error LNK2005: "private: static class 
std::locale::_Locimp * __cdecl std::locale::_Init(void)" 
(?_Init@locale@std@@CAPAV_Locimp@12@XZ) already defined in 
msvcprtd.lib(MSVCP100D.dll)
1>libcpmtd.lib(locale0.obj) : error LNK2005: "public: static void __cdecl 
std::_Locinfo::_Locinfo_ctor(class std::_Locinfo *,char const *)" 
(?_Locinfo_ctor@_Locinfo@std@@SAXPAV12@PBD@Z) already defined in 
msvcprtd.lib(MSVCP100D.dll)
1>libcpmtd.lib(locale0.obj) : error LNK2005: "public: static void __cdecl 
std::_Locinfo::_Locinfo_dtor(class std::_Locinfo *)" 
(?_Locinfo_dtor@_Locinfo@std@@SAXPAV12@@Z) already defined in 
msvcprtd.lib(MSVCP100D.dll)
1>libcpmtd.lib(xlock.obj) : error LNK2005: "public: __thiscall 
std::_Lockit::_Lockit(int)" (??0_Lockit@std@@QAE@H@Z) already defined in 
msvcprtd.lib(MSVCP100D.dll)
1>libcpmtd.lib(xlock.obj) : error LNK2005: "public: __thiscall 
std::_Lockit::~_Lockit(void)" (??1_Lockit@std@@QAE@XZ) already defined in 
msvcprtd.lib(MSVCP100D.dll)
1>LIBCMTD.lib(setlocal.obj) : error LNK2005: __configthreadlocale already 
defined in MSVCRTD.lib(MSVCR100D.dll)
1>LIBCMTD.lib(dbgheap.obj) : error LNK2005: __free_dbg already defined in 
MSVCRTD.lib(MSVCR100D.dll)
1>LIBCMTD.lib(dbgheap.obj) : error LNK2005: __CrtSetDbgFlag already defined in 
MSVCRTD.lib(MSVCR100D.dll)
1>LIBCMTD.lib(dbgheap.obj) : error LNK2005: __CrtDumpMemoryLeaks already 
defined in MSVCRTD.lib(MSVCR100D.dll)
1>LIBCMTD.lib(dbgheap.obj) : error LNK2005: __CrtSetCheckCount already defined 
in MSVCRTD.lib(MSVCR100D.dll)
1>LIBCMTD.lib(lconv.obj) : error LNK2005: _localeconv already defined in 
MSVCRTD.lib(MSVCR100D.dll)
1>LIBCMTD.lib(dbghook.obj) : error LNK2005: __crt_debugger_hook already defined 
in MSVCRTD.lib(MSVCR100D.dll)
1>LIBCMTD.lib(invarg.obj) : error LNK2005: __invalid_parameter already defined 
in MSVCRTD.lib(MSVCR100D.dll)
1>LIBCMTD.lib(invarg.obj) : error LNK2005: __invoke_watson already defined in 
MSVCRTD.lib(MSVCR100D.dll)
1>LIBCMTD.lib(mlock.obj) : error LNK2005: __lock already defined in 
MSVCRTD.lib(MSVCR100D.dll)
1>LIBCMTD.lib(mlock.obj) : error LNK2005: __unlock already defined in 
MSVCRTD.lib(MSVCR100D.dll)
1>LIBCMTD.lib(crt0dat.obj) : error LNK2005: _exit already defined in 
MSVCRTD.lib(MSVCR100D.dll)
1>LIBCMTD.lib(crt0dat.obj) : error LNK2005: __exit already defined in 
MSVCRTD.lib(MSVCR100D.dll)
1>LIBCMTD.lib(crt0dat.obj) : error LNK2005: __cexit already defined in 
MSVCRTD.lib(MSVCR100D.dll)
1>LIBCMTD.lib(crt0dat.obj) : error LNK2005: __amsg_exit already defined in 
MSVCRTD.lib(MSVCR100D.dll)
1>LIBCMTD.lib(crt0dat.obj) : error LNK2005: __initterm_e already defined in 
MSVCRTD.lib(MSVCR100D.dll)
1>LIBCMTD.lib(winxfltr.obj) : error LNK2005: __XcptFilter already defined in 
MSVCRTD.lib(MSVCR100D.dll)
1>LIBCMTD.lib(atox.obj) : error LNK2005: _atoi already defined in 
MSVCRTD.lib(MSVCR100D.dll)
1>LIBCMTD.lib(sprintf.obj) : error LNK2005: _sprintf_s already defined in 
MSVCRTD.lib(MSVCR100D.dll)
1>LIBCMTD.lib(errmode.obj) : error LNK2005: ___set_app_type already defined in 
MSVCRTD.lib(MSVCR100D.dll)
1>LIBCMTD.lib(crt0init.obj) : error LNK2005: ___xi_a already defined in 
MSVCRTD.lib(cinitexe.obj)
1>LIBCMTD.lib(crt0init.obj) : error LNK2005: ___xi_z already defined in 
MSVCRTD.lib(cinitexe.obj)
1>LIBCMTD.lib(crt0init.obj) : error LNK2005: ___xc_a already defined in 
MSVCRTD.lib(cinitexe.obj)
1>LIBCMTD.lib(crt0init.obj) : error LNK2005: ___xc_z already defined in 
MSVCRTD.lib(cinitexe.obj)
1>LIBCMTD.lib(hooks.obj) : error LNK2005: "void __cdecl terminate(void)" 
(?terminate@@YAXXZ) already defined in MSVCRTD.lib(MSVCR100D.dll)
1>LIBCMTD.lib(tolower.obj) : error LNK2005: _tolower already defined in 
MSVCRTD.lib(MSVCR100D.dll)
1>LIBCMTD.lib(dbgrptw.obj) : error LNK2005: __CrtDbgReportW already defined in 
MSVCRTD.lib(MSVCR100D.dll)
1>LIBCMTD.lib(vsnprnc.obj) : error LNK2005: __vsnprintf_s already defined in 
MSVCRTD.lib(MSVCR100D.dll)
1>LINK : warning LNK4098: defaultlib 'MSVCRTD' conflicts with use of other 
libs; use /NODEFAULTLIB:library
1>LINK : warning LNK4098: defaultlib 'LIBCMTD' conflicts with use of other 
libs; use /NODEFAULTLIB:library
1>LIBCMTD.lib(crt0.obj) : error LNK2019: unresolved external symbol _main 
referenced in function ___tmainCRTStartup
1>C:\Work\ScratchMe\Debug\ScratchMe.exe : fatal error LNK1120: 1 unresolved 
externals
========== Build: 0 succeeded, 1 failed, 0 up-to-date, 0 skipped ==========



Original issue reported on code.google.com by [email protected] on 6 Feb 2012 at 3:26

@GoogleCodeExporter
Copy link
Author

I had this exact issue, and fixed it by changing the flag from /MT to /MD 
during compilation of the library to match my calling program. Alternatively, I 
supposed you could change your test program to /MT, but I haven't tried that.

Original comment by [email protected] on 14 Feb 2012 at 3:34

@GoogleCodeExporter
Copy link
Author

thanks.  Changing from /MDd to /MTd got me linked successfully ;)

Original comment by [email protected] on 18 Feb 2012 at 10:56

Sign up for free to subscribe to this conversation on GitHub. Already have an account? Sign in.
Projects
None yet
Development

No branches or pull requests

1 participant