- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我有以下 makefile,它似乎工作得很好:
HDRS = include/config.h include/opcode_def.h include/x86lib.h include/x86lib_internal.h
CXX ?= g++
AR ?= ar
TEST_CC ?= i386-elf-gcc
TEST_CFLAGS ?= -fdata-sections -ffunction-sections
CXX_VM_SRC = vm/x86lib.cpp vm/modrm.cpp vm/device_manager.cpp vm/cpu_helpers.cpp vm/ops/strings.cpp vm/ops/store.cpp vm/ops/maths.cpp \
vm/ops/groups.cpp vm/ops/flow.cpp vm/ops/flags.cpp vm/ops/etc.cpp
CXX_VM_OBJS = $(subst .cpp,.o,$(CXX_VM_SRC))
CXX_TESTBENCH_SRC = testbench/testbench.cpp
CXX_TESTBENCH_OBJS = $(subst .cpp,.o,$(CXX_TESTBENCH_SRC))
CXXFLAGS ?= -Wall -g3 -fexceptions -fPIC -Wall
CXXFLAGS += -DX86LIB_BUILD -I./include
VERSION=1.1
VM_OUTPUTS = libx86lib.a libx86lib.so.$(VERSION)
OUTPUTS = $(VM_OUTPUTS) x86testbench
default: build
build: $(OUTPUTS)
libx86lib.a: $(CXX_VM_OBJS) $(CXX_VM_SRC)
ar crs libx86lib.a $(CXX_VM_OBJS)
libx86lib.so.$(VERSION): $(CXX_VM_OBJS) $(CXX_VM_SRC)
$(CXX) -shared $(CXX_VM_OBJS) -o libx86lib.so.$(VERSION)
x86testbench: $(CXX_TESTBENCH_OBJS) $(VM_OUTPUTS)
$(CXX) $(CXXFLAGS) -static -o x86testbench $(CXX_TESTBENCH_OBJS) -lx86lib -L.
$(CXX_TESTBENCH_OBJS): $(HDRS)
$(CXX) $(CXXFLAGS) -c $*.cpp -o $@
$(CXX_VM_OBJS): $(HDRS)
$(CXX) $(CXXFLAGS) -c $*.cpp -o $@
clean:
rm $(CXX_VM_OBJS) $(OUTPUTS) $(CXX_TESTBENCH_OBJS)
我的问题是,如果我更改一个文件,例如“vm/x86lib.cpp”,那么它将重新链接最终输出等,但它不会重新编译 vm/x86lib.o。我不知道如何将此重新编译要求表达为 $(CXX_VM_OBJS)
构建规则。
我该如何解决这个问题,以便它重新编译我的源文件并重新链接它们?
注意:如果我将 $(CXX_VM_SRC)
作为对 $(CXX_VM_OBJS)
的依赖,那么它会在单个文件更改时重新编译每个文件。另外,我只关心 GNU Make 和 OSX/Linux 环境。
最佳答案
正如其他人所指出的,当源更改时您的 makefile 不重建任何目标文件的原因是您的规则:
$(CXX_VM_OBJS): $(HDRS)
...
没有提到源文件是先决条件。以及建议的添加它们的解决方案的原因:
$(CXX_VM_OBJS): $(HDRS) $(CXX_VM_SRC)
...
导致 Make 在任何 源文件更改时重建所有 源文件,这正是该规则所要求的。它使所有 源文件成为任何 目标文件的先决条件。
处理此问题的正确方法是使用 static pattern rule :
$(CXX_VM_OBJS): %.o: %.cpp $(HDRS)
...
我会为您的 $(CXX_TESTBENCH_OBJS)
规则推荐相同的规则;即使它现在只适用于一个目标文件,很明显您正在考虑稍后添加其他目标文件。
关于c++ - Makefile 将在文件更改时链接文件,但不会重新编译更改的源文件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/47272487/
我有一个 Makefile,它针对特定目标调用另一个 Makefile。假设主 Makefile 包含 some_dir/some_target: cd some_dir && make so
这两个文件大多出现在开源项目中。 它们的用途是什么?它们如何工作? 最佳答案 Makefile.am 是程序员定义的文件,由 automake 使用来生成 Makefile.in 文件( .am 代表
我的源代码位于一堆子目录中,例如: src/widgets/apple.cpp src/widgets/knob.cpp src/tests/blend.cpp src/ui/flash.cpp 在项
这就是我所拥有的: SUBDIRS = src/lib/ResourceManager all: $(SUBDIRS) $(SUBDIRS): make install -C $@ 我正在尝试
我想写一个 Makefile 来执行来自两个不同数组的两个输入的命令例如 a = A B C b = 1 2 3 ./run A 1 ./run B 2 ./run C 3 我不知道怎么写,因为在Ma
在 GNU make 手册的早期部分之一,Section 3.7 , 有一个 makefile 配方的大纲 immediate : immediate ; deferred defer
是否存在将 gmake 的 GNU Makefile 转换为可用于 make (FreeBSD-make) 的 Makefile 的实用程序? 最佳答案 该实用程序称为开发人员(程序员,制作大师,..
所以我前段时间了解了什么是 Makefile,创建了一个模板 Makefile,我所做的就是为我正在执行的每个程序复制和更改相同的文件。我改了几次,但它仍然是一个非常粗糙的Makefile。我应该如何
我正在做一些 Makefile 重构,并试图找出最简洁的方法来实现一个 Makefile,它执行以下操作: 有一个变量列出了所有源文件(可以是 C 和 C++ 文件) 所有目标文件都在 OBJ_DIR
我正在尝试创建一个 Makefile,它将通过 tic 编译位于目录中的 terminfo 文件。 tic 还将它自动创建的 termcap 文件复制到系统或用户特定的目标文件夹。对于普通用户,如果
我想要类似的东西 BROKEN_THINGS = \ thing1 \ # thing1 is completely broken thing2 \ # thing2 is broken to
如果我的程序必须为不同的结果(主要是错误)返回不同的值(例如 0、1、2、3 等),则调用该程序的 makefile 将不得不停止执行其余的 makefile 命令。即使该命令产生错误(返回非零值),
我正在学习使用漂亮的 Linux 工具:make。还有一点我想了解的: 让我们看一下这个简单的例子: JADE = $(shell find pages/*.jade) HTML = $(JADE:.
假设您有一个包含两个伪目标“all”和“debug”的 Makefile。 'debug' 目标旨在构建与 'all' 相同的项目,除了一些不同的编译开关(例如 -ggdb)。由于目标使用不同的编译开
我有一个调用多个其他生成文件的生成文件。 我想将 -j 参数传递给其他 makefile 调用。 类似(make -j8): all: make -f libpng_linux.mk -j
我处理过的 Makefile 大部分都很复杂,并且隐藏了很多关系。我自己从来没有写过一个,想知道是否有人有一些关于编写易于阅读和可重用的 Makefile 的提示? 最佳答案 我通常使用这样的东西,在
嘿,我有一个简单的“主” Makefile,它只是调用其他 makefile。我正在尝试执行以下操作,以便以正确的顺序构建组件: LIB_A = folder_a LIB_B = folder_b L
生成文件: #there is a whitespace after "/my/path/to" FOO = "/my/path/to" BAR = "dir" INCLUDE_DIRS = $(FO
我正在学习 makefile,我知道如何创建一个简单的 makefile。我正在继续使用嵌套的 makefile。这是我的目录结构 /src ...makefile ...main.cpp ...fo
什么TEMP0_FILES下面计算到? SOURCE_FILES可以等于多个源文件。请告诉我以下语法 :.cpp=.o 的用途 SOURCE_FILES = main.cpp TEMP0_FILES
我是一名优秀的程序员,十分优秀!