boostboost-pythonlnk2019bjamlnk2001

Linker errors running bjam on Boost Python Tutorial


I have been working on solving this problem for fourty hours now, using every boost python resource I could find, and every permutation of installation and building I can think of, but could not find anything that worked for me.

Like many people before me, I am getting linker errors when I run bjam inside the boost/boost_1_60_0/libs/python/example/tutorial directory. I have Visual Studio 2015, and I have tried running bjam with 32-bit Anaconda, 64-bit Anaconda, and plain Python 2.7, through different configurations of the user-config.jam file located in my home directory.

Here is the build log after running bjam with any settings.

    Performing configuration checks

        - 32-bit                   : yes (cached)
        - arm                      : no  (cached)
        - mips1                    : no  (cached)
        - power                    : no  (cached)
        - sparc                    : no  (cached)
        - x86                      : yes (cached)
    ...found 7 targets...
        - symlinks supported       : yes
    ...found 1 target...
    ...updating 1 target...
    config-cache.write bin\project-cache.jam
    ...updated 1 target...
    ...patience...
    ...patience...
    ...found 1917 targets...
    ...updating 9 targets...
    msvc.link.dll ..\..\..\..\bin.v2\libs\python\build\msvc-14.0\debug\threading-multi\boost_python-vc140-mt-gd-1_60.dll
       Creating library ..\..\..\..\bin.v2\libs\python\build\msvc-14.0\debug\threading-multi\boost_python-vc140-mt-gd-1_60.lib and object ..\..\..\..\bin.v2\libs\python\build\msvc-14.0\debug\threading-multi\boost_python-vc140-mt-gd-1_60.exp
    object_protocol.obj : error LNK2001: unresolved external symbol __imp__PyObject_GetAttrString
    wrapper.obj : error LNK2001: unresolved external symbol __imp__PyObject_GetAttrString
    numeric.obj : error LNK2001: unresolved external symbol __imp__PyObject_GetAttrString
    enum.obj : error LNK2001: unresolved external symbol __imp__PyObject_GetAttrString
    class.obj : error LNK2001: unresolved external symbol __imp__PyObject_GetAttrString
    function.obj : error LNK2001: unresolved external symbol __imp__PyObject_GetAttrString
    numeric.obj : error LNK2019: unresolved external symbol __imp__PyCallable_Check referenced in function "bool __cdecl boost::python::numeric::`anonymous namespace'::load(bool)" (?load@?A0xc5ed2080@numeric@python@boost@@YA_N_N@Z)
    class.obj : error LNK2001: unresolved external symbol __imp__PyCallable_Check
    function.obj : error LNK2001: unresolved external symbol __imp__PyInt_FromLong
    function_doc_signature.obj : error LNK2001: unresolved external symbol __imp__PyInt_FromLong
    numeric.obj : error LNK2001: unresolved external symbol __imp__PyInt_FromLong
    list.obj : error LNK2001: unresolved external symbol __imp__PyInt_FromLong
    enum.obj : error LNK2001: unresolved external symbol __imp__PyInt_FromLong
    class.obj : error LNK2001: unresolved external symbol __imp__PyInt_FromLong
    numeric.obj : error LNK2019: unresolved external symbol __imp__PyBool_FromLong referenced in function "public: __thiscall boost::python::converter::arg_to_python<bool>::arg_to_python<bool>(bool const &)" (??0?$arg_to_python@_N@converter@python@boost@@QAE@AB_N@Z)
    class.obj : error LNK2001: unresolved external symbol __imp__PyBool_FromLong
    numeric.obj : error LNK2019: unresolved external symbol __imp__PyString_FromStringAndSize referenced in function "public: __thiscall boost::python::converter::arg_to_python<class std::basic_string<char,struct std::char_traits<char>,class std::allocator<char> > >::arg_to_python<class std::basic_string<char,struct std::char_traits<char>,class std::allocator<char> > >(class std::basic_string<char,struct std::char_traits<char>,class std::allocator<char> > const &)" (??0?$arg_to_python@V?$basic_string@DU?$char_traits@D@std@@V?$allocator@D@2@@std@@@converter@python@boost@@QAE@ABV?$basic_string@DU?$char_traits@D@std@@V?$allocator@D@2@@std@@@Z)
    str.obj : error LNK2001: unresolved external symbol __imp__PyString_FromStringAndSize
    builtin_converters.obj : error LNK2001: unresolved external symbol __imp__PyString_FromStringAndSize
    function_doc_signature.obj : error LNK2001: unresolved external symbol __imp__PyString_FromStringAndSize
    numeric.obj : error LNK2019: unresolved external symbol __imp__PyErr_Clear referenced in function "bool __cdecl boost::python::numeric::`anonymous namespace'::load(bool)" (?load@?A0xc5ed2080@numeric@python@boost@@YA_N_N@Z)
    class.obj : error LNK2001: unresolved external symbol __imp__PyErr_Clear
    function.obj : error LNK2001: unresolved external symbol __imp__PyErr_Clear
    object_protocol.obj : error LNK2001: unresolved external symbol __imp__PyErr_Clear
    function.obj : error LNK2001: unresolved external symbol __imp__PyErr_Format
    numeric.obj : error LNK2001: unresolved external symbol __imp__PyErr_Format
    from_python.obj : error LNK2001: unresolved external symbol __imp__PyErr_Format
    registry.obj : error LNK2001: unresolved external symbol __imp__PyErr_Format
    class.obj : error LNK2001: unresolved external symbol __imp__PyErr_Format
    enum.obj : error LNK2001: unresolved external symbol __imp__PyEval_CallFunction
    class.obj : error LNK2001: unresolved external symbol __imp__PyEval_CallFunction
    pickle_support.obj : error LNK2001: unresolved external symbol __imp__PyEval_CallFunction
    stl_iterator.obj : error LNK2001: unresolved external symbol __imp__PyEval_CallFunction
    numeric.obj : error LNK2001: unresolved external symbol __imp__PyEval_CallFunction
    list.obj : error LNK2001: unresolved external symbol __imp__PyEval_CallFunction
    dict.obj : error LNK2001: unresolved external symbol __imp__PyEval_CallFunction
    str.obj : error LNK2001: unresolved external symbol __imp__PyEval_CallFunction
    numeric.obj : error LNK2019: unresolved external symbol __imp__PyImport_Import referenced in function "bool __cdecl boost::python::numeric::`anonymous namespace'::load(bool)" (?load@?A0xc5ed2080@numeric@python@boost@@YA_N_N@Z)
    numeric.obj : error LNK2019: unresolved external symbol __imp__PyObject_IsInstance referenced in function "public: static bool __cdecl boost::python::numeric::aux::array_object_manager_traits::check(struct _object *)" (?check@array_object_manager_traits@aux@numeric@python@boost@@SA_NPAU_object@@@Z)
    from_python.obj : error LNK2001: unresolved external symbol __imp__PyObject_IsInstance
    class.obj : error LNK2001: unresolved external symbol __imp__PyObject_IsInstance
    wrapper.obj : error LNK2001: unresolved external symbol __imp___Py_NoneStruct
    import.obj : error LNK2001: unresolved external symbol __imp___Py_NoneStruct
    exec.obj : error LNK2001: unresolved external symbol __imp___Py_NoneStruct
    function_doc_signature.obj : error LNK2001: unresolved external symbol __imp___Py_NoneStruct
    iterator.obj : error LNK2001: unresolved external symbol __imp___Py_NoneStruct
    stl_iterator.obj : error LNK2001: unresolved external symbol __imp___Py_NoneStruct
    object_protocol.obj : error LNK2001: unresolved external symbol __imp___Py_NoneStruct
    object_operators.obj : error LNK2001: unresolved external symbol __imp___Py_NoneStruct
    life_support.obj : error LNK2001: unresolved external symbol __imp___Py_NoneStruct
    pickle_support.obj : error LNK2001: unresolved external symbol __imp___Py_NoneStruct
    module.obj : error LNK2001: unresolved external symbol __imp___Py_NoneStruct
    builtin_converters.obj : error LNK2001: unresolved external symbol __imp___Py_NoneStruct
    registry.obj : error LNK2001: unresolved external symbol __imp___Py_NoneStruct
    enum.obj : error LNK2001: unresolved external symbol __imp___Py_NoneStruct
    class.obj : error LNK2001: unresolved external symbol __imp___Py_NoneStruct
    function.obj : error LNK2001: unresolved external symbol __imp___Py_NoneStruct
    tuple.obj : error LNK2001: unresolved external symbol __imp___Py_NoneStruct
    str.obj : error LNK2001: unresolved external symbol __imp___Py_NoneStruct
    slice.obj : error LNK2001: unresolved external symbol __imp___Py_NoneStruct
    from_python.obj : error LNK2001: unresolved external symbol __imp___Py_NoneStruct
    numeric.obj : error LNK2001: unresolved external symbol __imp___Py_NoneStruct
    list.obj : error LNK2001: unresolved external symbol __imp___Py_NoneStruct
    long.obj : error LNK2001: unresolved external symbol __imp___Py_NoneStruct
    dict.obj : error LNK2001: unresolved external symbol __imp___Py_NoneStruct
    numeric.obj : error LNK2001: unresolved external symbol __imp__PyExc_ImportError
    list.obj : error LNK2019: unresolved external symbol __imp__PyInt_AsLong referenced in function "public: int __thiscall boost::python::detail::list_base::count(class boost::python::api::object const &)const " (?count@list_base@detail@python@boost@@QBEHABVobject@api@34@@Z)
    str.obj : error LNK2001: unresolved external symbol __imp__PyInt_AsLong
    class.obj : error LNK2001: unresolved external symbol __imp__PyInt_AsLong
    builtin_converters.obj : error LNK2001: unresolved external symbol __imp__PyInt_AsLong
    list.obj : error LNK2019: unresolved external symbol __imp__PyList_New referenced in function "protected: __thiscall boost::python::detail::list_base::list_base(void)" (??0list_base@detail@python@boost@@IAE@XZ)
    list.obj : error LNK2019: unresolved external symbol __imp__PyList_Insert referenced in function "public: void __thiscall boost::python::detail::list_base::insert(int,class boost::python::api::object const &)" (?insert@list_base@detail@python@boost@@QAEXHABVobject@api@34@@Z)
    list.obj : error LNK2019: unresolved external symbol __imp__PyList_Append referenced in function "public: void __thiscall
....
....(too many to put here)
....
    object_operators.obj : error LNK2019: unresolved external symbol __imp__PyNumber_Add referenced in function "class boost::python::api::object __cdecl boost::python::api::operator+(class boost::python::api::object const &,class boost::python::api::object const &)" (??Hapi@python@boost@@YA?AVobject@012@ABV3012@0@Z)
    object_operators.obj : error LNK2019: unresolved external symbol __imp__PyNumber_Subtract referenced in function "class boost::python::api::object __cdecl boost::python::api::operator-(class boost::python::api::object const &,class boost::python::api::object const &)" (??Gapi@python@boost@@YA?AVobject@012@ABV3012@0@Z)
    object_operators.obj : error LNK2019: unresolved external symbol __imp__PyNumber_Multiply referenced in function "class boost::python::api::object __cdecl boost::python::api::operator*(class boost::python::api::object const &,class boost::python::api::object const &)" (??Dapi@python@boost@@YA?AVobject@012@ABV3012@0@Z)
    object_operators.obj : error LNK2019: unresolved external symbol __imp__PyNumber_Divide referenced in function "class boost::python::api::object __cdecl boost::python::api::operator/(class boost::python::api::object const &,class boost::python::api::object const &)" (??Kapi@python@boost@@YA?AVobject@012@ABV3012@0@Z)
    object_operators.obj : error LNK2019: unresolved external symbol __imp__PyNumber_Remainder referenced in function "class boost::python::api::object __cdecl boost::python::api::operator%(class boost::python::api::object const &,class boost::python::api::object const &)" (??Lapi@python@boost@@YA?AVobject@012@ABV3012@0@Z)
    object_operators.obj : error LNK2019: unresolved external symbol __imp__PyNumber_Lshift referenced in function "class boost::python::api::object __cdecl boost::python::api::operator<<(class boost::python::api::object const &,class boost::python::api::object const &)" (??6api@python@boost@@YA?AVobject@012@ABV3012@0@Z)
    object_operators.obj : error LNK2019: unresolved external symbol __imp__PyNumber_Rshift referenced in function "class boost::python::api::object __cdecl boost::python::api::operator>>(class boost::python::api::object const &,class boost::python::api::object const &)" (??5api@python@boost@@YA?AVobject@012@ABV3012@0@Z)
    object_operators.obj : error LNK2019: unresolved external symbol __imp__PyNumber_And referenced in function "class boost::python::api::object __cdecl boost::python::api::operator&(class boost::python::api::object const &,class boost::python::api::object const &)" (??Iapi@python@boost@@YA?AVobject@012@ABV3012@0@Z)
    object_operators.obj : error LNK2019: unresolved external symbol __imp__PyNumber_Xor referenced in function "class boost::python::api::object __cdecl boost::python::api::operator^(class boost::python::api::object const &,class boost::python::api::object const &)" (??Tapi@python@boost@@YA?AVobject@012@ABV3012@0@Z)
    object_operators.obj : error LNK2019: unresolved external symbol __imp__PyNumber_Or referenced in function "class boost::python::api::object __cdecl boost::python::api::operator|(class boost::python::api::object const &,class boost::python::api::object const &)" (??Uapi@python@boost@@YA?AVobject@012@ABV3012@0@Z)
    object_operators.obj : error LNK2019: unresolved external symbol __imp__PyNumber_InPlaceAdd referenced in function "class boost::python::api::object & __cdecl boost::python::api::operator+=(class boost::python::api::object &,class boost::python::api::object const &)" (??Yapi@python@boost@@YAAAVobject@012@AAV3012@ABV3012@@Z)
    object_operators.obj : error LNK2019: unresolved external symbol __imp__PyNumber_InPlaceSubtract referenced in function "class boost::python::api::object & __cdecl boost::python::api::operator-=(class boost::python::api::object &,class boost::python::api::object const &)" (??Zapi@python@boost@@YAAAVobject@012@AAV3012@ABV3012@@Z)
    object_operators.obj : error LNK2019: unresolved external symbol __imp__PyNumber_InPlaceMultiply referenced in function "class boost::python::api::object & __cdecl boost::python::api::operator*=(class boost::python::api::object &,class boost::python::api::object const &)" (??Xapi@python@boost@@YAAAVobject@012@AAV3012@ABV3012@@Z)
    object_operators.obj : error LNK2019: unresolved external symbol __imp__PyNumber_InPlaceDivide referenced in function "class boost::python::api::object & __cdecl boost::python::api::operator/=(class boost::python::api::object &,class boost::python::api::object const &)" (??_0api@python@boost@@YAAAVobject@012@AAV3012@ABV3012@@Z)
    object_operators.obj : error LNK2019: unresolved external symbol __imp__PyNumber_InPlaceRemainder referenced in function "class boost::python::api::object & __cdecl boost::python::api::operator%=(class boost::python::api::object &,class boost::python::api::object const &)" (??_1api@python@boost@@YAAAVobject@012@AAV3012@ABV3012@@Z)
    object_operators.obj : error LNK2019: unresolved external symbol __imp__PyNumber_InPlaceLshift referenced in function "class boost::python::api::object & __cdecl boost::python::api::operator<<=(class boost::python::api::object &,class boost::python::api::object const &)" (??_3api@python@boost@@YAAAVobject@012@AAV3012@ABV3012@@Z)
    object_operators.obj : error LNK2019: unresolved external symbol __imp__PyNumber_InPlaceRshift referenced in function "class boost::python::api::object & __cdecl boost::python::api::operator>>=(class boost::python::api::object &,class boost::python::api::object const &)" (??_2api@python@boost@@YAAAVobject@012@AAV3012@ABV3012@@Z)
    object_operators.obj : error LNK2019: unresolved external symbol __imp__PyNumber_InPlaceAnd referenced in function "class boost::python::api::object & __cdecl boost::python::api::operator&=(class boost::python::api::object &,class boost::python::api::object const &)" (??_4api@python@boost@@YAAAVobject@012@AAV3012@ABV3012@@Z)
    object_operators.obj : error LNK2019: unresolved external symbol __imp__PyNumber_InPlaceXor referenced in function "class boost::python::api::object & __cdecl boost::python::api::operator^=(class boost::python::api::object &,class boost::python::api::object const &)" (??_6api@python@boost@@YAAAVobject@012@AAV3012@ABV3012@@Z)
    object_operators.obj : error LNK2019: unresolved external symbol __imp__PyNumber_InPlaceOr referenced in function "class boost::python::api::object & __cdecl boost::python::api::operator|=(class boost::python::api::object &,class boost::python::api::object const &)" (??_5api@python@boost@@YAAAVobject@012@AAV3012@ABV3012@@Z)
    wrapper.obj : error LNK2019: unresolved external symbol __imp__PyDict_GetItemString referenced in function "protected: class boost::python::override __thiscall boost::python::detail::wrapper_base::get_override(char const *,struct _typeobject *)const " (?get_override@wrapper_base@detail@python@boost@@IBE?AVoverride@34@PBDPAU_typeobject@@@Z)
    wrapper.obj : error LNK2001: unresolved external symbol __imp__PyMethod_Type
    import.obj : error LNK2019: unresolved external symbol __imp__PyImport_ImportModule referenced in function "class boost::python::api::object __cdecl boost::python::import(class boost::python::str)" (?import@python@boost@@YA?AVobject@api@12@Vstr@12@@Z)
    exec.obj : error LNK2019: unresolved external symbol __imp__PyFile_FromString referenced in function "class boost::python::api::object __cdecl boost::python::exec_file(class boost::python::str,class boost::python::api::object,class boost::python::api::object)" (?exec_file@python@boost@@YA?AVobject@api@12@Vstr@12@V3412@1@Z)
    exec.obj : error LNK2019: unresolved external symbol __imp__PyFile_AsFile referenced in function "class boost::python::api::object __cdecl boost::python::exec_file(class boost::python::str,class boost::python::api::object,class boost::python::api::object)" (?exec_file@python@boost@@YA?AVobject@api@12@Vstr@12@V3412@1@Z)
    exec.obj : error LNK2019: unresolved external symbol __imp__PyRun_StringFlags referenced in function "class boost::python::api::object __cdecl boost::python::eval(class boost::python::str,class boost::python::api::object,class boost::python::api::object)" (?eval@python@boost@@YA?AVobject@api@12@Vstr@12@V3412@1@Z)
    exec.obj : error LNK2019: unresolved external symbol __imp__PyRun_FileExFlags referenced in function "class boost::python::api::object __cdecl boost::python::exec_file(class boost::python::str,class boost::python::api::object,class boost::python::api::object)" (?exec_file@python@boost@@YA?AVobject@api@12@Vstr@12@V3412@1@Z)
    exec.obj : error LNK2019: unresolved external symbol __imp__PyEval_GetGlobals referenced in function "class boost::python::api::object __cdecl boost::python::eval(class boost::python::str,class boost::python::api::object,class boost::python::api::object)" (?eval@python@boost@@YA?AVobject@api@12@Vstr@12@V3412@1@Z)
    C:\Users\Joey\Anaconda2\libs\python27.lib : warning LNK4272: library machine type 'x64' conflicts with target machine type 'X86'
    ..\..\..\..\bin.v2\libs\python\build\msvc-14.0\debug\threading-multi\boost_python-vc140-mt-gd-1_60.dll : fatal error LNK1120: 135 unresolved externals

            call "C:\Users\Joey\AppData\Local\Temp\b2_msvc_14.0_vcvarsall_x86.cmd" >nul
    link /NOLOGO /INCREMENTAL:NO /DLL /DEBUG /MACHINE:X86 /MANIFEST /subsystem:console /out:"..\..\..\..\bin.v2\libs\python\build\msvc-14.0\debug\threading-multi\boost_python-vc140-mt-gd-1_60.dll" /IMPLIB:"..\..\..\..\bin.v2\libs\python\build\msvc-14.0\debug\threading-multi\boost_python-vc140-mt-gd-1_60.lib" /LIBPATH:"C:\Users\Joey\Anaconda2\libs"   @"..\..\..\..\bin.v2\libs\python\build\msvc-14.0\debug\threading-multi\boost_python-vc140-mt-gd-1_60.dll.rsp"
            if %ERRORLEVEL% NEQ 0 EXIT %ERRORLEVEL%

    ...failed msvc.link.dll ..\..\..\..\bin.v2\libs\python\build\msvc-14.0\debug\threading-multi\boost_python-vc140-mt-gd-1_60.dll ..\..\..\..\bin.v2\libs\python\build\msvc-14.0\debug\threading-multi\boost_python-vc140-mt-gd-1_60.lib ..\..\..\..\bin.v2\libs\python\build\msvc-14.0\debug\threading-multi\boost_python-vc140-mt-gd-1_60.pdb...
    ...removing ..\..\..\..\bin.v2\libs\python\build\msvc-14.0\debug\threading-multi\boost_python-vc140-mt-gd-1_60.lib
    ...removing ..\..\..\..\bin.v2\libs\python\build\msvc-14.0\debug\threading-multi\boost_python-vc140-mt-gd-1_60.pdb
    ...skipped <pbin\msvc-14.0\debug\threading-multi>hello_ext.dll for lack of <p..\..\..\..\bin.v2\libs\python\build\msvc-14.0\debug\threading-multi>boost_python-vc140-mt-gd-1_60.lib...
    ...skipped <pbin\msvc-14.0\debug\threading-multi>hello_ext.pdb for lack of <p..\..\..\..\bin.v2\libs\python\build\msvc-14.0\debug\threading-multi>boost_python-vc140-mt-gd-1_60.lib...
    ...skipped <p.>boost_python-vc140-mt-gd-1_60.dll for lack of <p..\..\..\..\bin.v2\libs\python\build\msvc-14.0\debug\threading-multi>boost_python-vc140-mt-gd-1_60.dll...
    ...skipped <p.>hello_ext.dll for lack of <pbin\msvc-14.0\debug\threading-multi>hello_ext.dll...
    ...skipped <pbin\hello.test\msvc-14.0\debug\threading-multi>hello for lack of <pbin\msvc-14.0\debug\threading-multi>hello_ext.dll...
    ...failed updating 3 targets...
    ...skipped 6 targets...

I have tried numerous user-config.jam settings, including each of the following for msvc:

using msvc : 14.0 ;
using msvc : 14.0 : "C:/Program Files (x86)/Microsoft Visual Studio 14.0/VC/bin" ;
using msvc ;

as well as the following for python:

using python ;
using python : 2.7 ;
using python : 2.7 : C:/Users/Joey/Anaconda2 ;

using python : 2.7 : "C:/Users/Joey/Anaconda2 (32-bit)" ;

using python 
    : 2.7                   # Version
    : C:\\Users\\Joey\\Anaconda2\\python.exe      # Python Path
    : C:\\Users\\Joey\\Anaconda2\\include         # include path
    : C:\\Users\\Joey\\Anaconda2\\libs            # lib path(s)
    : <define>BOOST_ALL_NO_LIB=1
    ;

for bjam settings, I have tried

bjam
bjam address-model=64
bjam address-model=64 architecture=x86

I have tried both 32-bit and 64-bit builds of the entire Boost library, with identical results.

When I run bjam address-model=64, I get the following errors much more quickly:

Performing configuration checks

    - 32-bit                   : yes (cached)
    - arm                      : no  (cached)
    - mips1                    : no  (cached)
    - power                    : no  (cached)
    - sparc                    : no  (cached)
    - x86                      : yes (cached)
    - symlinks supported       : no  (cached)
    - junctions supported      : yes (cached)
    - hardlinks supported      : yes (cached)
...found 1 target...
...updating 1 target...
config-cache.write bin\project-cache.jam
...updated 1 target...
...patience...
...patience...
...found 1924 targets...
...updating 5 targets...
msvc.link.dll bin\msvc-14.0\debug\address-model-64\threading-multi\hello_ext.pyd
   Creating library bin\msvc-14.0\debug\address-model-64\threading-multi\hello_ext.pdb and object bin\msvc-14.0\debug\address-model-64\threading-multi\hello_ext.exp
LINK : fatal error LNK1104: cannot open file 'bin\msvc-14.0\debug\address-model-64\threading-multi\hello_ext.pdb'

        call "C:\Users\Joey\AppData\Local\Temp\b2_msvc_14.0_vcvarsall_amd64.cmd" >nul
link /NOLOGO /INCREMENTAL:NO /DLL /NOENTRY /DEBUG /MACHINE:X64 /MANIFEST /subsystem:console /out:"bin\msvc-14.0\debug\address-model-64\threading-multi\hello_ext.pyd" /IMPLIB:"bin\msvc-14.0\debug\address-model-64\threading-multi\hello_ext.pdb" /LIBPATH:"C:\Users\Joey\Anaconda2\libs"   @"bin\msvc-14.0\debug\address-model-64\threading-multi\hello_ext.pyd.rsp"
        if %ERRORLEVEL% NEQ 0 EXIT %ERRORLEVEL%

...failed msvc.link.dll bin\msvc-14.0\debug\address-model-64\threading-multi\hello_ext.pyd bin\msvc-14.0\debug\address-model-64\threading-multi\hello_ext.pdb bin\msvc-14.0\debug\address-model-64\threading-multi\hello_ext.pdb...
...removing bin\msvc-14.0\debug\address-model-64\threading-multi\hello_ext.pyd
...skipped <p.>hello_ext.pyd for lack of <pbin\msvc-14.0\debug\address-model-64\threading-multi>hello_ext.pyd...
...skipped <pbin\hello.test\msvc-14.0\debug\address-model-64\threading-multi>hello for lack of <pbin\msvc-14.0\debug\address-model-64\threading-multi>hello_ext.pyd...
...failed updating 2 targets...
...skipped 3 targets...

I am running Windows 10 64-bit.

If anyone has any intuition into things to try, the nature of the problem, or anything else that could be helpful, I would greatly appreciate it. I am nearly running out of ideas.

EDIT

I used

    import toolset : using ;
using msvc : 14.0 ;
using python 
  : 2.7  # Version
  : C:\\Python27\\python.exe  # Interpreter
  : C:\\Python27\\include  # inc dir
  : C:\\Python27\\libs  # link libs
  : # conditions
  ;

And now get this, similar to this post.

Performing configuration checks

    - 32-bit                   : yes (cached)
    - arm                      : no  (cached)
    - mips1                    : no  (cached)
    - power                    : no  (cached)
    - sparc                    : no  (cached)
    - x86                      : yes (cached)
...found 7 targets...
    - symlinks supported       : yes
...found 1 target...
...updating 1 target...
config-cache.write bin\project-cache.jam
...updated 1 target...
...patience...
...patience...
...found 1916 targets...
...updating 5 targets...
msvc.link.dll bin\msvc-14.0\debug\threading-multi\hello_ext.pyd
   Creating library bin\msvc-14.0\debug\threading-multi\hello_ext.pdb and object bin\msvc-14.0\debug\threading-multi\hello_ext.exp
LINK : fatal error LNK1207: incompatible PDB format in 'C:\Program Files\boost\boost_1_60_0_64\libs\python\example\tutorial\bin\msvc-14.0\debug\threading-multi\hello_ext.pdb'; delete and rebuild

        call "C:\Users\Joey\AppData\Local\Temp\b2_msvc_14.0_vcvarsall_x86.cmd" >nul
link /NOLOGO /INCREMENTAL:NO /DLL /NOENTRY /DEBUG /MACHINE:X86 /MANIFEST /subsystem:console /out:"bin\msvc-14.0\debug\threading-multi\hello_ext.pyd" /IMPLIB:"bin\msvc-14.0\debug\threading-multi\hello_ext.pdb" /LIBPATH:"C:\Python27\libs"   @"bin\msvc-14.0\debug\threading-multi\hello_ext.pyd.rsp"
        if %ERRORLEVEL% NEQ 0 EXIT %ERRORLEVEL%

...failed msvc.link.dll bin\msvc-14.0\debug\threading-multi\hello_ext.pyd bin\msvc-14.0\debug\threading-multi\hello_ext.pdb bin\msvc-14.0\debug\threading-multi\hello_ext.pdb...
...removing bin\msvc-14.0\debug\threading-multi\hello_ext.pdb
...skipped <p.>hello_ext.pyd for lack of <pbin\msvc-14.0\debug\threading-multi>hello_ext.pyd...
...skipped <pbin\hello.test\msvc-14.0\debug\threading-multi>hello for lack of <pbin\msvc-14.0\debug\threading-multi>hello_ext.pyd...
...failed updating 2 targets...
...skipped 3 targets...

Solution

  • I suffered similar problems as you and found this to be the main culprit:

        C:\Users\Joey\Anaconda2\libs\python27.lib : warning LNK4272: library machine type 'x64' conflicts with target machine type 'X86'
    

    You are mixing libraries of different bitness. When building 64-bit Boost Python you have to link to 64-bit Python and likewise for the 32-bit builds.

    Make sure you install the two versions of Python to different directories. I used the default directory in the installers and both installations end up in the same directory. Even though I installed the 64-bit version after the 32-bit one, I still only had 32-bit libs in my Python libs/ folder.