我正在开展一个有多个级别的项目。就个人而言,我是qbs的新手,关于qbs内部的文档和示例并不多。
环境:
Qt5.6.1; Qt创建者4.01; Ubuntu 16.04; Qbs 1.5.1
这是项目的层次结构。在顶层,它有project.qbs:
import qbs
import qbs.File
Project{
var binaries = [
"component1/component1.qbs",
"component2/component2.qbs",
"subpro/subpro.qbs", // <- 1. the project I am working on
"ourlib/ourlib.qbs", // <- 2. the library I am using
]
return binaries
}
subpro.qbs类似于:
import qbs
Project {
name: subpro
references:[
"app1/app1.qbs"
"app2/app2.qbs"
"myapp/myapp.qbs" //<- 3. the application I am working on
]
}
myapp.qbs就像:
import qbs
CppApplication{
type: "application"
name: "myapp"
Group{
name: "project-install"
fileTagsFilter: "application"
qbs.install: false
qbs.install: "bin"
}
Depends {name:"cpp"}
Depends {name:"blah1"}
Depends {name:"ourlib"}
cpp.libraryPaths:["path_of_lib3rdParty"] // 4. set the 3rd party lib path
cpp.staticLibraries:["lib3rdParty.a"] // 5. set the 3rd party lib name
files["myapp.cpp","f2"...]
}
最终我们的lib的qbs:
import qbs
DynamicLibrary{
name: "ourlib"
Group{
name: "project-install"
fileTagsFilter: "dynamiclibrary"
qbs.install: false
qbs.installDir: "debug"
}
Depends {name: "cpp"}
cpp.includePath:["..."]
cpp.libraryPaths:["path_of_lib3rdParty"] // 6. same as 4
cpp.staticLibraries:["lib3rdParty.a"] // 7. same as 5
}
当我运行&#34; qbs debug&#34;在项目根文件夹下。 qbs显示:
linking ourlib.so
compiling myapp.cpp
ERROR: ...
/usr/bin/ld: cannot find -llib3rdParty_s.a
因此,基于错误消息,qbs无法构建myapp.cpp并尝试在myapp项目中找到lib3rdParty。我添加了4和5,仍然有相同的错误。似乎6和7是正确的,因为mylib.so没有链接错误。我应该如何配置qbs以使构建过程正常工作?
另一个问题是关键字&#34;引用&#34;。我可以在项目的任何级别引用其他qbs文件吗?它是如何工作的?我得到了同样的问题&#34;取决于&#34;同样。
由于
融
答案 0 :(得分:3)
cpp.dynamicLibraries
和cpp.staticLibraries
属性会列出要链接的库名称列表,即没有lib
前缀或.so
的库名称}后缀。
例如,您使用:
cpp.libraryPaths: ["/home/r0ng/tools/myapp/libs/relic/lib"]
cpp.dynamicLibraries: ["relic"]
但是,由于您已经拥有了要链接的动态库的完整文件路径,因此您只需传递完整的文件路径,而无需指定cpp.libraryPaths
,如下所示:
cpp.dynamicLibraries: ["/home/r0ng/tools/myapp/libs/relic/lib/librelic.so"]
第二种方法是首选方法,因为它指定要链接的确切库,而不是依赖于搜索路径,而搜索路径可能不一定会选择您期望的库类型(如果存在静态和动态版本)。
我承认我们应该更好地记录我们的cpp.dynamicLibraries
和cpp.staticLibraries
属性以解释其预期用途。
关于references
,是的,无论文件系统位置如何,都可以引用任何文件路径。
关于Depends
,该项的name
属性指定了要创建依赖关系的产品或模块的名称。此类产品或模块必须已存在于项目树中,例如,由于使用qbsSearchPaths
或references
属性而已加载。