qmake:高级用法

一、添加新的配置特性

特性(features)是 *.prf 文件中自定义函数和定义的集合(Qt安装目录\mkspecs\features 中有很多 *.prf文件)。

存放特性文件的目录有很多地方,qmake 在查找 .prf 文件时会按以下顺序检查每个目录:

  • QMAKEFEATURES 环境变量中列出的目录中,
  • QMAKEFEATURES 属性变量中列出的目录中。
  • 在位于 mkspecs 目录中的 features 目录中。
  • QMAKESPEC 环境变量提供的目录下的 features 目录中。
  • data_install/mkspecs 目录中的 features 目录中。
  • 在作为 QMAKSPEC 环境变量指定的目录的同级存在的 features 目录中。

然后在以下子目录中搜索功能文件:

  • features/unix、features/win32、features/macx,取决于使用的平台
  • features/

例如以下配置:

 CONFIG += myfeatures

添加到 CONFIG 变量后,qmake 将在完成解析项目文件后搜索上面列出的位置以查找 myfeatures.prf 文件。在 Unix 系统上将查找以下文件:

  • $QMAKEFEATURES/myfeatures.prf
  • $$QMAKEFEATURES/myfeatures.prf
  • myfeatures.prf(在项目的根目录中)。项目根由顶级 *.pro 文件确定。
  • $QMAKEPATH/mkspecs/features/unix/myfeatures.prf 、$QMAKEPATH/mkspecs/features/myfeatures.prf
  • $QMAKESPEC/features/unix/myfeatures.prf、
    $QMAKESPEC/features/myfeatures.prf
  • data_install/mkspecs/features/unix/myfeatures.prf 和 data_install/mkspecs/features/myfeatures.prf
  • $QMAKESPEC/../features/unix/myfeatures.prf、
    $QMAKESPEC/../features/myfeatures.prf

注意:*.prf 文件的名称必须为小写。

二、安装文件

在 Unix 上经常使用构建工具来安装应用程序和库,例如通过调用 make install。qmake 有一个安装集的概念。例如,可以通过以下方式描述文档文件的集合:

 documentation.path = /usr/local/program/doc
 documentation.files = docs/*
  • path成员:通知qmake文件应该安装在/usr/local/program/doc
  • files成员:指定应该复制到安装目录的文件。这里 docs 目录中的所有内容都将复制到 /usr/local/program/doc。

然后将其附加到安装列表中:

 INSTALLS += documentation

qmake 将确保将指定的文件复制到安装目录。

如果将内置安装集附加到 INSTALLS 变量并且不指定文件或额外成员,qmake 将决定需要复制的内容。当前,支持 target dlltarget 这两个内置安装集。例如:

 target.path = /usr/local/myprogram
 INSTALLS += target

在上面两行中,qmake 知道需要复制什么,并会自动处理安装过程。

三、添加自定义目标

qmake 尝试做跨平台构建工具所期望的一切。当确实需要运行特殊的平台相关命令时,可通过自定义目标实现。

例如:

 mytarget.target = .buildfile
 mytarget.commands = touch $$mytarget.target
 mytarget.depends = mytarget2

 mytarget2.commands = @echo "假装生成了mytarget2"

1、定义qmake要生成的名为 mytarget 的目标

2、mytarget 是名为 .buildfile 的 Makefile 文件,该目标由 touch 命令生成(Linux touch命令),即运行 mytarget.commands 指定的命令

3、mytarget 依赖于 mytarget2,即mytarget2生成之后才能生成mytarget,即运行 mytarget2.commands 指定的命令

4、最后一步是使用 QMAKE_EXTRA_TARGETS 变量来指示 qmake 这个对象是要构建的目标:

 QMAKE_EXTRA_TARGETS += mytarget mytarget2

这就是实际构建自定义目标所需要做的全部工作。

可能希望将这些目标绑定到 qmake 构建目标。只需将 Makefile 目标包含在 PRE_TARGETDEPS 列表中。

自定义目标规范支持以下成员:

  • commands:用于生成自定义构建目标的命令。
  • CONFIG:自定义构建目标的特定配置选项。
  • depends:自定义构建目标所依赖的现有构建目标。
  • recurse:指定在 Makefile 中创建规则以调用子目标特定的 Makefile 时应使用哪些子目标。 
  • recurse_target:指定应通过子目标 Makefile 为 Makefile 中的规则构建的目标。
  • target:自定义构建目标的名称。

四、库依赖

通常在链接库时,qmake 依赖于底层平台来了解该库链接到哪些其他库,并让平台将它们拉入。然而,在许多情况下,这还不够。 例如,在静态链接库时,不会链接其他库,因此不会创建对这些库的依赖项。如果明确启用跟踪,qmake 会在适当的情况下尝试跟踪库的依赖项。

第一步是在库本身中启用依赖项跟踪。必须告诉 qmake 保存有关库的信息:

 CONFIG += create_prl

这仅适用于 lib 模板类型的工程,所有其他模板将被忽略。 启用此选项后,qmake 将创建一个以 .prl 结尾的文件,该文件将保存有关库的一些元信息。这个元文件就像一个普通的项目文件,但只包含内部变量声明。安装库时,通过在 INSTALLS 声明中将其指定为目标,qmake 会自动将 .prl 文件复制到安装路径。

第二步是在使用静态库的应用程序中启用此元信息的读取:

 CONFIG += link_prl

启用此功能后,qmake 将处理应用程序链接的所有库并找到它们的元信息。qmake 将使用它来确定相关的链接信息,特别是将值添加到应用程序项目文件的 DEFINES LIBS 列表中。 一旦 qmake 处理了这个文件,它就会查看 LIBS 变量中新引入的库,并找到它们依赖的 .prl 文件,直到所有库都被解析为止。此时,Makefile 照常创建,并且库与应用程序显式链接。

.prl 文件应仅由 qmake 创建,不应在操作系统之间传输,因为它们可能包含平台相关信息。

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Go语言(也称为Golang)是由Google开发的一种静态强类型、编译型的编程语言。它旨在成为一门简单、高效、安全和并发的编程语言,特别适用于构建高性能的服务器和分布式系统。以下是Go语言的一些主要特点和优势: 简洁性:Go语言的语法简单直观,易于学习和使用。它避免了复杂的语法特性,如继承、重载等,转而采用组合和接口来实现代码的复用和扩展。 高性能:Go语言具有出色的性能,可以媲美C和C++。它使用静态类型系统和编译型语言的优势,能够生成高效的机器码。 并发性:Go语言内置了对并发的支持,通过轻量级的goroutine和channel机制,可以轻松实现并发编程。这使得Go语言在构建高性能的服务器和分布式系统时具有天然的优势。 安全性:Go语言具有强大的类型系统和内存管理机制,能够减少运行时错误和内存泄漏等问题。它还支持编译时检查,可以在编译阶段就发现潜在的问题。 标准库:Go语言的标准库非常丰富,包含了大量的实用功能和工具,如网络编程、文件操作、加密解密等。这使得开发者可以更加专注于业务逻辑的实现,而无需花费太多时间在底层功能的实现上。 跨平台:Go语言支持多种操作系统和平台,包括Windows、Linux、macOS等。它使用统一的构建系统(如Go Modules),可以轻松地跨平台编译和运行代码。 开源和社区支持:Go语言是开源的,具有庞大的社区支持和丰富的资源。开发者可以通过社区获取帮助、分享经验和学习资料。 总之,Go语言是一种简单、高效、安全、并发的编程语言,特别适用于构建高性能的服务器和分布式系统。如果你正在寻找一种易于学习和使用的编程语言,并且需要处理大量的并发请求和数据,那么Go语言可能是一个不错的选择。
根据提供的引用内容,出现 "bash: qmake: 未找到命令" 的问题可能是由于环境变量没有正确设置引起的。根据引用中的信息,可以通过以下步骤来解决问题: 1. 确认你安装的Qt的路径,根据你的安装位置进行配置。例如,如果你的Qt安装在 /opt/qtsdk-xxxx/qt 目录下,可以执行以下命令设置环境变量: ```bash export QTDIR=/opt/qtsdk-xxxx/qt export LD_LIBRARY_PATH=$LD_LIBRARY_PATH:$QTDIR/lib export PATH=$PATH:$QTDIR/bin ``` 2. 检查你的环境变量中是否包含 /usr/bin 目录,可以使用以下命令查看: ```bash echo $PATH ``` 如果发现 /usr/bin 目录下有 qmake-qt4 但没有 qmake,可以创建一个软连接来解决: ```bash ln -s qmake-qt4 qmake ``` 3. 如果以上步骤无效,可以尝试在 /etc/profile 文件中添加以下几行语句: ```bash export QTDIR=/opt/qt-xxxx/qt export LD_LIBRARY_PATH=$LD_LIBRARY_PATH:$QTDIR/lib export PATH=$PATH:$QTDIR/bin ``` 确保将路径替换为你实际的Qt安装路径。 通过以上步骤,你应该能够解决 "bash: qmake: 未找到命令" 的问题。如果仍然遇到困难,你可以参考引用和引用中的方法,使用 locate 或 find 命令来查找 qmake 的路径,并根据实际情况进行设置。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* [<转>bash: qmake: command not found...](https://blog.csdn.net/weixin_33825683/article/details/91850902)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *3* [bash: qmake: command not found](https://blog.csdn.net/m0_37806112/article/details/82623486)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值