Makefile会自动覆盖旧文件

时间:2012-12-22 18:19:07

标签: makefile

  

可能重复:
  How do you force a makefile to rebuild a target

我正在使用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

1 个答案:

答案 0 :(得分:2)

  

如何强制make重新编译?

两个选项:

  1. touch所有源文件
  2. 如果您使用的是GNU make,make --always-make