【win32】makefile


转自:http://blog.csdn.net/denglei265/article/details/3951599


请注意(提示):


gcc,rm等操作语句的开头必须要添加一个tab空格,否则会报错 missing separator。







//第一次基本的

#生成test可执行文件,它的依赖于main.o func.o,也就是说生成test你得先生成它们
#2行:gcc前边必须是tab(Tab键空格),表示编译生成test
test:func.o main.o
gcc -o test func.o main.o

func.o:func.c
gcc -c func.c

main.o:main.c
gcc -c main.c

clean:
rm func.o main.o

注意可能没有编译到clean来,需要make clean

//第二次 :宏来替代N个

#定义一个宏
objects = main.o func.o

test: $(objects)
gcc -o test $(objects)

func.o:func.c
gcc -c func.c

main.o:main.c
gcc -c main.c

clean:
rm $(objects)

第三次:make的“隐晦规则”。
objects = main.o func.o

test: $(objects)
gcc -o test $(objects)

main.o:func.h
func.o:func.h

.PHONY : clean
clean:
rm $(objects)

.PHONY表示:clean是个伪目标文件。
向make说明,不管是否有这个文件,这个目标就是 伪目标
表示仅仅删除该伪目标
---未成功


第四次:替代
objects = main.o func.o
test: $(objects)

$(objects):%.o:%.c
gcc -c $< -o $@
#gcc -c test $(objects)
#.PHONY : clean
clean :
rm $(objects)

$<:表示源文件 *.c
$@:表示目标文件 *.o

也可以将第一行 objects = main.o func.o
替换为:
objects_all = main.o func.o func.h
objects = $(filter %.o,$(objects_all))

$(filter %.o,$(objects_all))
表示用makefile中的filter函数,只取objects_all中的*.o文件


说明:
如果你想让make不理那些无法读取的文件,而继续执行,你可以在include前加一个减号“-”。如:
-include <filename>

GNU的make工作时的执行步骤入下:
读入所有的Makefile。
读入被include的其它Makefile。
初始化文件中的变量。
推导隐晦规则,并分析所有规则。
为所有的目标文件创建依赖关系链。
根据依赖关系,决定哪些目标要重新生成。
执行生成命令。
1-5步为第一个阶段,6-7为第二个阶段。第一个阶段中,如果定义的变量被使用了,那么,make会把其展开在使用的位置。但make并不会完全马上展开,make使用的是拖延战术,如果变量出现在依赖关系的规则中,那么仅当这条依赖被决定要使用了,变量才会在其内部展开。


targets : prerequisites
command
...
或是这样: targets : prerequisites ; command
command
command是命令行,如果其不与“target:prerequisites”在一行,那么,必须以[Tab键]开头,如果和prerequisites在一行,那么可以用分号做为分隔。
如果命令太长,你可以使用反斜框(‘/’)作为换行符。make对一行上有多少个字符没有限制。规则告诉make两件事,文件的依赖关系和如何成成目标文件。


波浪号(“~”)字符在文件名中也有比较特殊的用途。如果是“~/test”,这就表示当前用户的$HOME目录下的test目录。而“~hchen/test”则表示用户hchen的宿主目录下的test目录。(这些都是Unix下的小知识了,make也支持)而在Windows或是MS-DOS下,用户没有宿主目录,那么波浪号所指的目录则根据环境变量“HOME”而定。


objects = *.o
上面这个例子,表示了,通符同样可以用在变量中。并不是说[*.o]会展开,不!objects的值就是“*.o”。Makefile中的变量其实就是C/C++中的宏。如果你要让通配符在变量中展开,也就是让objects的值是所有[.o]的文件名的集合,那么,你可以这样: objects := $(wildcard *.o)


.PHONY: cleanall cleanobj cleandiff
cleanall : cleanobj cleandiff
rm program

cleanobj :
rm *.o

cleandiff :
rm *.diff
使用:
make cleanall
make cleanobj
make cleandiff



bigoutput littleoutput : text.g
generate text.g -$(subst output,,$@) > $@
上述规则等价于:

bigoutput : text.g
generate text.g -big > bigoutput
littleoutput : text.g
generate text.g -little > littleoutput
其中,-$(subst output,,$@)中的“$”表示执行一个Makefile的函数,函数名为subst,后面的为参数。关于函数,将在后面讲述。这里的这个函数是截取字符串的意思,“$@”表示目标的集合,就像一个数组,“$@”依次取出目标,并执于命令。









他人的:
CFLAGS
:
=

-
g
-
Wall
-
fPIC
-
DPIC
-
I
./





SOFLAGS
:
=

-
shared
-
Wl
,-
E




LDFLAGS
:
=

-
L
./

-
pthread




GCC
=
gcc




TARGET
:
=
sip
.
so




COBJS
=

./
Md5Codec
.
o/



./
SipApi
.
o/



./
SipHandle
.
o/



./
SipMessage
.
o/



./
SipStack
.
o/



./
SipCall
.
o/



./
SipLine
.
o/



./
SipSender
.
o/



./
SipRecvhandle
.
o/



./
sdp
.
o/



./
log
.
o/




#module sip


$
(
TARGET
):
$
(
COBJS
)



$
(
GCC
)

$
(
SOFLAGS
)

$
(
COBJS
)

-
o
$
(
TARGET
)




$
(
COBJS
):
%.
o
:
%.
c



$
(
GCC
)

$
(
CFLAGS
)

-
c
$<

-
o
$
@




$
(
LOGOBJS
):
%.
o
:
%.
c



$
(
GCC
)

$
(
CFLAGS
)

-
c
$<

-
o
$
@





clean
:


rm
$
(
COBJS
)

$
(
TARGET
)

-
rf
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值