qmake语法(pro文件写法)
qmake语法
生成文件图标设置
RC_FILE += res_widget.rc
RC_ICONS += SARBOX_BLUE_512.ico
rc文件内容:
IDI_ICON ICON DISCARDABLE ".\\icon\\SARBOX_BLUE_512.ico"
- 创建*.rc文件,写明图标所在路径(相对路径即可)
- qmake中添加如上所示的
RC_FILE
和RC_ICONS
两行代码,执行qmake *:有时一次执行qmake后新生成的文件仍然不带图标,需要多次尝试...
中间文件生成路径
CONFIG(debug, debug|release){
DESTDIR = $$PWD/../../bin/debug
UI_DIR = ./debug/UI
MOC_DIR = ./debug/MOC
OBJECTS_DIR = ./debug/OBJ
}else{
DESTDIR = $$PWD/../../bin/release
UI_DIR = ./release/UI
MOC_DIR = ./release/MOC
OBJECTS_DIR = ./release/OBJ
}
其中,DESTDIR
为生成文件路径(exe、dll等文件),UI_DIR
是又*.ui自动生成的ui_.h文件的路径,MOC_DIR
是自动生成的存放指针和槽函数的moc_.h文件的路径,OBJECTS_DIR
是各个.cpp生成的中间文件*.o的路径
QMAKE_CXXFLAGS
将所有的警告当成错误处理
QMAKE_CXXFLAGS += -Werror = return-type //函数有返回值
QMAKE_CXXFLAGS += -Werror = return-local-addr //返回局部变量地址
QMAKE_CXXFLAGS += -Werror = missing-field-initializers //缺少初始值设定项
QMAKE_CXXFLAGS += -Werror = maybe-uninitialized //变量可能没有被初始化
QMAKE_CXXFLAGS += -Werror = delete-non-virtual-dtor //
QMAKE_CXXFLAGS += -Werror = unused-but-set-variable //设置了但未使用的变量
QMAKE_CXXFLAGS += -Werror = parentheses //括号不匹配
QMAKE_CXXFLAGS += -Werror = pointer-arith //指针用在了算术运算
QMAKE_CXXFLAGS += -Werror = reorder //警告构造函数的顺序不会被使用
QMAKE_CXXFLAGS += -Werror = format-extra-args //格式不对
QMAKE_CXXFLAGS += -Werror = format= //格式不对
QMAKE_CXXFLAGS += -Werror = unused-variable //未使用的变量
忽略该警告
QMAKE_CXXFLAGS += -Wno-unused-function //未使用的函数
QMAKE_CXXFLAGS += -Wno-unused-parameter //设置了但未使用的参数
QMAKE_CXXFLAGS += -Wno-comment //注释使用不规范。
QMAKE_CXXFLAGS += -Wno-sequence-point //如出现i=i++这类代码,则报警告
stdlib.h no such file or directory
linux编程时,
#include <QDialog>
后,通过多级include ,最后到达#include <cstdlib.h
>中,
在cstdlib.h中,#include_next <stdlib.h>
报错,提示:no such file or directory
原因: 这是由于gcc7已经吧stdlib.h纳入了libstdc++以进行更好的优化,C Library的头文件stdlib.h使用 Include_next,而include_next对gcc系统头文件路径很敏感
解决方法:
在.pro文件中,添加
DEFINES += ENABLE_PRECOMPILED_HEADERS=OFF
QMAKE_CFLAGS_ISYSTEM = -I
greaterThan(QT_MAJOR_VERSION, 4): {
QT += widgets
QMAKE_CFLAGS_ISYSTEM=-I
}
COPY
编译前COPY文件到指定位置
场景:当工程调用外部库时,需要将dll文件拷贝到exe的目录中才可以正常使用软件。而拷贝是一个繁琐的过程。
最好的办法是使用qmake自动查找依赖库并且自动填充到指定位置。
由于还不会上述操作,暂时使用QMAKE_PRE_LINK
+COPY
代替。
QMAKE_PRE_LINK
首先确定待拷贝文件的地址以及需要拷贝到的路径。
MINGW64_BIN = D:/msys64/mingw64/bin
src_dll = $$MINGW64_BIN/libgdal*.dll
src_dll = $$replace(src_dll, /, \\)
dst_dll = $$replace(DESTDIR, /, \\)
QMAKE_PRE_LINK += copy /Y $$src_dll $$dst_dll
src_dll就是存储多有dll地址的文件,dst_dll是dll拷贝到的路径,使用copy指令执行copy操作。 一次只能copy一个或一批可以用*号替换的文件。
windows中(至少是windows)的copy操作,只能识别\\
windows版本的分隔符。
COPIES
使用该方法可以复制整个文件夹
CONFIG += file_copies
example.files += $$PWD/folder #$$PWD指当前pro文件的路径
example.path = $$DESTDIR #$$DESTDIR指编译输出路径
#如果是windows系统的话 需要把地址从 ../../.. 更换为..\\..\\..
win32: example.files ~= s,/,\\,g
win32: example.path ~= s,/,\\,g
COPIES += example
该方法很方便,但是不确定是编译前还是编译后,不一定可以替代QMAKE_PRE_LINK