将C ++组件添加到正在编译并通过命令行运行的Swift应用程序之后,我现在需要编译C ++和Objective-C ++(* .mm)文件并将它们与Swift应用程序链接。
生成文件:
all: foo-renderer
clean:
rm -f foo-renderer cpp.o objc.o
cpp.o: FooRenderer/FooRenderer/FooLibrary.cpp
clang++ -c -o $@ $^
objc.o: cpp.o FooRenderer/FooRenderer/FooLibraryWrapper.mm
clang++ -c -framework Foundation -o $@ $^
foo-renderer: objc.o FooRenderer/FooRenderer/*.swift
xcrun -sdk macosx swiftc -import-objc-header FooRenderer/FooRenderer/FooRenderer-Bridging-Header.h -o $@ $^
编译器因这些错误而失败:
ld: warning: object file (objc.o) was built for newer OSX version (10.12) than being linked (10.9)
Undefined symbols for architecture x86_64:
"__ZN11FooLibrary23printifyERKNSt3__112basic_stringIcNS0_11char_traitsIcEENS0_9allocatorIcEEEE", referenced from:
-[FooLibraryWrapper printify:] in objc.o
"__ZN11FooLibrary8optimizeERKNSt3__112basic_stringIcNS0_11char_traitsIcEENS0_9allocatorIcEEEE", referenced from:
-[FooLibraryWrapper optimize:] in objc.o
"__ZNSt3__112basic_stringIcNS_11char_traitsIcEENS_9allocatorIcEEE6__initEPKcm", referenced from:
-[FooLibraryWrapper printify:] in objc.o
-[FooLibraryWrapper optimize:] in objc.o
"__ZNSt3__112basic_stringIcNS_11char_traitsIcEENS_9allocatorIcEEED1Ev", referenced from:
-[FooLibraryWrapper printify:] in objc.o
-[FooLibraryWrapper optimize:] in objc.o
"__ZSt9terminatev", referenced from:
___clang_call_terminate in objc.o
"___cxa_begin_catch", referenced from:
___clang_call_terminate in objc.o
"___gxx_personality_v0", referenced from:
-[FooLibraryWrapper printify:] in objc.o
-[FooLibraryWrapper optimize:] in objc.o
Dwarf Exception Unwind Info (__eh_frame) in objc.o
ld: symbol(s) not found for architecture x86_64
我的第一直觉是标准的C ++库没有被包含在内。我尝试将这些lib标志添加到以下命令中,但无济于事:
cpp.o: FooRenderer/FooRenderer/FooLibrary.cpp
clang++ -c --std=c++14 -lstdc++ -lc++ -stdlib=libstdc++ -o $@ $^
我错过了什么?
答案 0 :(得分:3)
一个问题是最后一个命令行中缺少foo-renderer: objc.o FooRenderer/FooRenderer/*.swift cpp.o
xcrun -sdk macosx swiftc -import-objc-header FooRenderer/FooRenderer/FooRenderer-Bridging-Header.h -o $@ $^
。将它添加到依赖项列表应该可以做到这一点:
-l...
这是因为链接器需要C ++代码中找到的符号的定义。
将cpp.o
标志添加到cpp.o
目标的命令是不必要的,因为它们是链接器标志,此时您只是编译。
此外,您可能不需要objc.o
目标的-framework Foundation
依赖项,因为您仍在编译并且编译不依赖于其他目标文件。你可以在没有compute()
的情况下做好,但它不会伤害任何东西。
答案 1 :(得分:1)
虽然我对objc / clang / swift不太熟悉,但我有一些关于如何进行的指示,
> "__ZN11FooLibrary23printifyERKNSt3__112basic_stringIcNS0_11char_traitsIcEENS0_9allocatorIcEEEE", > referenced from: > -[FooLibraryWrapper printify:] in objc.o
以上说在函数printify中的objc对象文件中,你有一个未定义的符号,可能是FooLibrary :: printify :: basic_string :: char_traits,所以很可能你缺少一个c ++库,尝试添加libc ++库你的链接命令。
cpp.o: FooRenderer/FooRenderer/FooLibrary.cpp
clang++ -c --std=c++14 -lstdc++ -lc++ -stdlib=libstdc++ -o $@ $^
在编译期间添加链接器标志/库没有任何意义。