Makefile中使用foreach生成一类规则

CSDN上,有朋友发帖问了这样一个问题(我按自己的理解翻译一下):

当前目录下有四个静态库文件:  liba.a libb.a libc.a libd.a。现在想将它们做成一个动态库libp.so。

怎样实现一个方法,在Makefile 能将列表里的.a文件逐个取出来, 分别执行$(AR) -x。

我的做法是:

1 用define定义一种可通用的规则形式
2 用foreach遍历列表,配合eval和define,实现自动扩展出每个文件的依赖规则
3 用一个伪目标去定义把所有静态库解开的行为,以确保可以正确的生成动态库

后来又增加了一条规则,去生成静态库。

 

在实际使用中,如果静态库与动态库是在同一个makefile(或者说同一个工程)中的,不太可能使用这种

解包静态库之后再打包成动态库的用法。而是直接使用相关的.o文件生成动态库。

原文地址:https://www.cnblogs.com/keanuyaoo/p/3343432.html