0

我编写了一个非常简单的 Make-File,它可以完美运行。只是我的一些回声命令不起作用,我完全不知道为什么会这样。

LIBNAME=E2E.lib

CC=gcc
CFLAGS=-c -Wall 

AR=ar
ARFLAGS=rvs

SOURCES=E2E_P01.c E2E_P02.c Crc.c E2E.c
OBJECTS=$(SOURCES:.c=.o)

all: $(SOURCES) $(LIBNAME) clean

$(LIBNAME): $(OBJECTS) 
$(AR) $(ARFLAGS) $@ $(OBJECTS) 

.cpp.o:
@echo Compiling ... 
$(CC) $(CFLAGS) $< -o $@
@echo done

clean:
@echo Cleaning up all the object files ...
rm *.o 
@echo done 
@sleep 5

所以 make-process 的输出是这样的:

gcc —c —Wall —c —o E2E_P01.o E2E_P01.c
gcc —c —Wall —c —o E2E_P02.o E2E_P02.c
gcc —c —Wall —c —o Crc.o Crc.c
gcc —c —Wall —c —o E2E.o E2E.c
ar rvs E2E.lib E2E_P01.o E2E_P02.o Crc.o E2E.o
r— E2E_P01.o
r— E2E_P02.o
r— Crc.o
r— E2E.o
Cleaning up all the object files ...
rm *.o
done

为什么不是所有的 echo 命令都在输出中?显然,每个正在编译的模块都应该打印一条消息(编译...完成)。为什么不是?

4

1 回答 1

1

你的规则根本没有被使用。相反,make 正在使用它的内置规则。

那是因为您的后缀规则.cpp.o告诉 make 如何.o从文件构建.cpp文件。但是,您要编译的文件都是.c文件,因此您定义的规则对此毫无用处。

.o相反,正在使用 make 用于从 a构建 a 的内置规则.c,当然,这些规则中没有您的 echo 命令。

于 2013-10-04T14:02:53.517 回答