makefile这样写:bash
ifdef DEBUG CFLAGS += -DDEBUG=1 -O0 -ggdb RELMODE = debug else CFLAGS += -DDEBUG=0 -O0 -s RELMODE = release endif
编译能够这样:spa
make DEBUG=1
#能够用命令行传递变量
RELEASE = abc
#ifdef 变量名称不能加$()
ifdef RELEASE
$(warning RELEASE defined)
else
$(warning RELEASE not defined)
endif
#ifeq 后面参数要叫$(), 由于是值引用, 值能够为数值或字符串
ifeq ($(RELEASE),abc)
$(warning RELEASE eqal abc)
else
$(warning RELEASE not equal abc)
endif
all:
@echo ok!
**************************************************
make 编译不一样版本,例如debug, release 的简单示例。
用make 变量ver, 控制CFLAGS 变量,从而编译出不一样版本。
[/pts/2@hjj ~/test]$ cat test.c
#include <stdio.h>
#include <unistd.h>
int main(int argc,char *argv[])
{
char *tty=ttyname(0);
printf("tty is %s\n",tty);
return 0;
}
[/pts/2@hjj ~/test]$ cat Makefile
CC = gcc
TARGET = test
OBJS = test.o
ifeq ($(ver), debug)
$(warning ver is debug)
CFLAGS = -g -Ddebug
else
$(warning ver is not debug)
CFLAGS = -c -O3
endif
$(TARGET): $(OBJS)
$(CC) -o $@ $^
clean:
rm test test.o
注释: makefile 采用了ifeq-else-endif 结构
能够判别莫个make变量是否认义。
make变量能够在makefile中定义,也能够由make命令行传递。
因为makefile 支持环境变量,因此你预先定义了环境变量,也能够不在命令行中传递而直接使用环境变量
这种机制使得编写脚本控制不一样的复杂的编译成为可能,
例如支持各类地域的不一样的版本。用地域变量,控制make的编译选项/D,控制编译出不一样的版本
----------------------------------------
编译debug 版本, 从命令行传递变量
----------------------------------------
[/pts/2@hjj ~/test]$ make ver=debug
Makefile:6: ver is debug
gcc -g -Ddebug -c -o test.o test.c
gcc -o test test.o
----------------------------------------
清理,无所谓版本信息
----------------------------------------
[/pts/2@hjj ~/test]$ make clean
Makefile:9: ver is not debug
rm test test.o
----------------------------------------
编译release 版本
----------------------------------------
[/pts/2@hjj ~/test]$ make
Makefile:9: ver is not debug
gcc -c -O3 -c -o test.o test.c
gcc -o test test.o
.net
**************************************************命令行
有时候,咱们仍是须要让make命令带入一些参数给makefile脚本。 好比,你在代码里面须要定义一个宏DEBUG来打开调试开关,代码以下:int main(){int i=9;#ifdef DEBUGi=1;#elsei=0;#endifprintf("i=%d\n", i);return 0;}通常来讲,这个宏定义能够经过直接修改源代码进行,但这样显然不是很好的办法。另一个办法是经过makefile修改,好比: CFLAGS=-g -Wall -DDEBUG object=myprog all:$objectmyprog:a.c gcc ${CFLAGS} a.c -o ${object} 若是更进一步,连makefile都不想修改,咱们能够经过向make命令传递参数来进行,为此,咱们须要适当的修改makefile以下: CFLAGS=CFLAG CFLAGS+=-g -Wall -DDEBUG object=myprog all:$objectmyprog:a.c gcc ${CFLAGS} a.c -o ${object} 此时,若是想打开DEBUG宏,咱们能够这样输入make命令: [ychq@ICM3-2 net]$ make CFLAG=-DDEBUG gcc -g -Wall -DDEBUG a.c a.c: In function `main': a.c:9: warning: implicit declaration of function `printf' [ychq@ICM3-2 net]$ 咱们能够发现,DEBUG宏已经被正确的传入。 更进一步的,咱们能够经过传递不一样的参数给make,让make编译不一样的模块。