可能重复:
如何强制生成文件重建目标
我正在使用zedshaw 的 makefile的略微修改版本,但是当我运行它时,它不会重新编译.o
文件。
我只花了 2 个小时进行调试,却发现 make 正在查看现有的目标文件,而根本没有重新编译它们。
$(OBJECTS)
将来如何强制make重新编译?有没有办法在不添加clean
目标之前做到这一点all
?
编辑:为清楚起见:如果源代码中的某些内容已更改,Make 应该会自动重新编译,这不适用于,$(OBJECTS)
所以我需要强制重新编译它们或找出它为什么不自己这样做。
编辑 2:在复制整个文件夹并在不同时间对其进行比较后,我意识到 make 正确地看到了除一个依赖项之外的所有依赖项。问题出在以下几点:
tests: LDLIBS += $(TARGET)
tests: $(TESTS)
Make 无法将事物识别LDLIBS
为依赖项,因此我添加了:
$(TESTS): $(TARGET)
这解决了这个问题。由于 Jens 在评论中称它为已接受,因此我将他的回答标记为已接受。
CFLAGS=-g -O2 -Wall -Wextra -Isrc -rdynamic -DNDEBUG $(OPTFLAGS)
LDLIBS=-ldl $(OPTLIBS)
PREFIX?=/usr/local
SOURCES=$(wildcard src/**/*.c src/*.c)
OBJECTS=$(patsubst %.c,%.o,$(SOURCES))
TEST_SRC=$(wildcard tests/*_tests.c)
TESTS=$(patsubst %.c,%,$(TEST_SRC))
TARGET=build/liblcthw.a
SO_TARGET=$(patsubst %.a,%.so,$(TARGET))
# The Target Build
all: cls $(TARGET) $(SO_TARGET) tests
dev: CFLAGS=-g -Wall -Isrc -Wall -Wextra $(OPTFLAGS)
dev: all
$(TARGET): CFLAGS += -fPIC
$(TARGET): build $(OBJECTS)
ar rcs $@ $(OBJECTS)
ranlib $@
$(SO_TARGET): $(TARGET) $(OBJECTS)
$(CC) -shared -o $@ $(OBJECTS)
build:
@mkdir -p build
@mkdir -p bin
# The Unit Tests
.PHONY: tests
tests: LDLIBS += $(TARGET)
tests: $(TESTS)
sh ./tests/runtests.sh
valgrind:
VALGRIND="valgrind --log-file=/tmp/valgrind-%p.log" $(MAKE)
# The Cleaner
clean: cls
rm -rf build $(OBJECTS) $(TESTS)
rm -f tests/tests.log
find . -name "*.gc*" -exec rm {} \;
rm -rf `find . -name "*.dSYM" -print`
# The Install
install: all
install -d $(DESTDIR)/$(PREFIX)/lib/
install $(TARGET) $(DESTDIR)/$(PREFIX)/lib/
# The Checker
BADFUNCS='[^_.>a-zA-Z0-9](str(n?cpy|n?cat|xfrm|n?dup|str|pbrk|tok|_)|stpn?cpy|a?sn?printf|byte_)'
check:
@echo Files with potentially dangerous functions.
@egrep $(BADFUNCS) $(SOURCES) || true
# Clear screen for unspammy terminals
cls:
clear