Из руководства GNU Make я узнал, что знак $^
- это автоматическая переменная, которая представляет имена всех предварительных условий. Однако я наткнулся на такой make-файл:
SVR_OBJECT_FILES = server.o\
server_func.o
CLT_OBJECT_FILES = client.o
CFLAGS = -Wall -Werror -W
CC = gcc
all: client/client server/serveur
client/client: $(CLT_OBJECT_FILES)
server/serveur: $(SVR_OBJECT_FILES)
client/client server/serveur:
@mkdir -p $(dir $@)
$(CC) $(CFLAGS) $^ -o $@
%.o: %.c
$(CC) -c $<
clean:
rm -f client/client server/serveur *.o
Что отлично работает, поэтому мой вопрос: как команда ниже может связывать правильные объектные файлы, в то время как переменная $ ^ вообще не ссылается на предварительные требования. (правило не имеет предпосылок)
$(CC) $(CFLAGS) $^ -o $@