c++ - qmake - 未检测到配置更改并且库不会重新编译
问题描述
我想根据配置选择编译成静态库的文件。
为此,我在 QtCreator 的 Projects 选项卡和我的 .pro 文件中创建了两个配置(A 和 B)
CONFIG(USE_A){
SOURCES += My_lib_a.cpp
}
CONFIG(USE_B){
SOURCES += My_lib_b.cpp
}
它有效,但有一个问题。
当我在 A 和 B 配置之间切换几次时,在这两个版本都已构建之后,qmake 不再检测到有任何更改,并且库被旧文件卡住了。我被迫要么触摸我想要重新编译的文件,要么手动选择重建库。
我已经检查了 Qt 5.12 和 msvc 2017,但我需要它才能在 Windows 和 linux 上工作。
这是这样做的正确方法吗?有没有办法克服这个问题?
最小的例子:
// example/top.pro
TEMPLATE = subdirs
CONFIG += ordered
SUBDIRS += \
my_lib\
app
// example/app/app.pro
TARGET = app
SOURCES += main.cpp
INCLUDEPATH += ../my_lib
DEPENDPATH += ../my_lib
LIBS += -L../my_lib/debug -lmy_lib
PRE_TARGETDEPS += ../my_lib/debug/my_lib.lib
// example/app/main.cpp
#include "My_lib.h"
int main()
{
My_lib m;
}
// example/my_lib/my_lib.pro
TARGET = my_lib
TEMPLATE = lib
CONFIG += staticlib
CONFIG(USE_A){
SOURCES += My_lib_a.cpp
}
CONFIG(USE_B){
SOURCES += My_lib_b.cpp
}
HEADERS += My_lib.h
// example/my_lib/My_lib.h
#pragma once
struct My_lib
{
My_lib();
};
// example/my_lib/My_lib_a
#include "My_lib.h"
#include <iostream>
My_lib::My_lib()
{
std::cout << "This is A" << std::endl;
}
// example/my_lib/My_lib_b
#include "My_lib.h"
#include <iostream>
My_lib::My_lib()
{
std::cout << "This is B" << std::endl;
}
解决方案
由于您在相同的构建目录中构建库,具有相同的目标名称,因此无论当前构建配置设置为什么,您总是会得到最新的构建文件。为了克服这个问题,您需要使用单独的构建目录,每个配置一个。
在Build Settings中,对于每个配置,在Build 目录路径%{CurrentBuild:Name}
的末尾添加:
/somepath/example/%{CurrentBuild:Name}
清理您当前的构建目录,然后再次构建每个配置。给定A和B你的配置名称,你会得到一个像这样的目录树:
- somepath
- example
- A
+ app
+ my_lib
- B
+ app
+ my_lib
推荐阅读
- json - OpenWeatherMap 和 Swift 4
- python - 如何在 Python 中将二维数组更改为一维数组
- r - 将数据框写入多个excel文件
- php - 使用 PHP 从 MySql 表创建子菜单
- kubernetes - 将 Google Cloud SQL 凭据连接到 Kubernetes Secret
- python - 从 0.5.1 升级到 0.8.2 后 graph_from_polygon 中的 osmnx TypeError
- arrays - 字符串的动态数组跳过第一个索引
- typescript - 返回扩展匿名类的函数的类型定义
- r - R:无法将绘图从循环输出到文件
- javascript - x 不是一个文件中的函数,但它可以在另一个文件中使用?