1

可能重复:
如何强制生成文件重建目标

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

1 回答 1

3

如何强制 make 重新编译?

两种选择:

  1. touch所有源文件
  2. 如果您使用的是 GNU make,make --always-make
于 2012-12-22T18:33:27.327 回答