我正在使用zedshaw's makefile的略微修改版本,但是当我运行它时,它不会重新编译.o
个文件。
我只花了2个小时进行调试,发现make正在查看现有的目标文件,而不是重新编译它们。
将来如何强制make重新编译$(OBJECTS)
?有没有办法在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
答案 0 :(得分:2)
如何强制make重新编译?
两个选项:
touch
所有源文件make --always-make