条件执行
根据条件执行Makefile中的某一部分,舍弃其他部分。比如根据条件执行生成debug程序或者release程序。
关键字ifeq(或者ifneq)、else、endif
具体用法,看个示例就会明白。
示例:还是以上面博客用的Makefile为例,增加条件执行,如果定义变量DEBUG,则执行debug 模式,否则执行release模式。Makefile如下:
.PHONY:clean
DEBUG = true
OBJ = world
OBJS = world.o robot.o human.o animal.o
CC = gcc
ifeq ($(DEBUG), true)
VERSION = debug
CFLAGS = -c -g -o
else
VERSION = release
CFLAGS = -c -o
endif
$(OBJ): $(OBJS)
@echo"build $(VERSION) mode"
$(CC)$(OBJS) -o $(OBJ)
%.o: %.c
$(CC)$^ $(CFLAGS) $@
clean:
rm-f $(OBJ) $(OBJS)
这里补充一个知识点:
在Makefile中命令的执行过程也是打印出来的,如果不想显示命令的执行过程,可以在该命令前加@。