#如果QTCREATOR_PRI_INCLUDED存在,那就抛出错误,相当于#ifndef,#define,防止pri文件被引入多次
!isEmpty(QTCREATOR_PRI_INCLUDED):error("qtcreator.pri already included")
QTCREATOR_PRI_INCLUDED = 1
#QTCreator的版本
QTCREATOR_VERSION = 4.0.3
#插件能兼容的QTCreator的版本
QTCREATOR_COMPAT_VERSION = 4.0.0
#指定的是git的分支
BINARY_ARTIFACTS_BRANCH = 4.0
# enable c++11
CONFIG += c++11
#自定义的替换函数,定义替换函数的语句使用的是defineReplace,定义了qtLibraryName函数,下面是他的实现
#函数的功能:当使用debug环境编译时,在mac下生成的库名被重命名追加_debug,win则追加d
defineReplace(qtLibraryName) {
#取消LIBRARY_NAME的定义
unset(LIBRARY_NAME)
#将定义时的第一个参数赋值给变量LIBRARY_NAME
LIBRARY_NAME = $$1
#CONFIG测试函数用来检测CONFIG变量中的值。CONFIG是一个重要的变量,用于指定编译参数
#CONFIG测试函数可以从函数的第二组参数中选择一个需要的
#CONFIG = debug
#CONFIG += release
#CONFIG首先被设置为 debug,其后又被设置为 release。
#CONFIG的赋值顺序非常重要,在一组互斥的值之间(例如 debug 和 release),最后面的会被认为是激活的。
#所以在执行CONFIG(debug, debug|release)时会选择release
CONFIG(debug, debug|release) {
#这个是scope语法,当不是debug_and_release或者build_pass时,
#对于mac,RET是$$member(LIBRARY_NAME, 0)_debug这个值
#debug_and_release是指同时编译debug和release版本
#build_pass是指构建过程
!debug_and_release|build_pass {
#member(variablename, position)是一个替换函数,
#返回variablename中第position个元素;没有找到的话则返回空串。
mac:RET = $$member(LIBRARY_NAME, 0)_debug
else:win32:RET = $$member(LIBRARY_NAME, 0)d
}
}
#如果RET为空,就将其赋值为LIBRARY_NAME
isEmpty(RET):RET = $$LIBRARY_NAME
return($$RET)
}
#defineTest(minQtVersion)定义了一个名为minQtVersion的测试函数。
#对qmake的几个预定义宏进行判断
defineTest(minQtVersion) {
maj = $$1
min = $$2
patch = $$3
isEqual(QT_MAJOR_VERSION, $$maj) {
isEqual(QT_MINOR_VERSION, $$min) {
对qtcreator.pri文件的理解
最新推荐文章于 2024-03-18 08:13:55 发布