如何收集大型Makefile项目的所有依赖项?

在一个大型C项目中,我有一个顶级Makefile和许多子Makefile在不同的子目录中。 我需要收集编译的所有依赖项。 为此,我将-MMD添加到CFLAGS并获取一堆.d依赖文件。

这些.d文件分散在子目录中。 此外,依赖关系有时被写为绝对路径,有时作为与编译目录相关的路径,有时包含符号链接。 我编写了一个脚本,它可以找到所有.d文件,遍历它们的目录,并解析所有找到的路径。 这有效,但有数万个依赖项文件,这个依赖项集合与编译大致相同! (等待太长了:))

有没有更快的方法来获取单个文件中的所有依赖项? 如果这很重要,那就是ANSI C,GCC和Linux。 提前致谢。

您可以使用-MM代替-MMD ,它将依赖项发送到标准输出。

然后,您可以将所有输出收集到顶级目录中的某个依赖项文件中

 gcc -MM ... file.c >>$(top)/all.d 

如果后期处理是在一个文件中收集输出的唯一原因,则可以使用管道过滤输出

 gcc -MM ... file.c | sh filter.sh >file.d 

并将依赖项文件分开。

如果某些本地包含文件( defs.h )或主源的路径很重要,则可以通过提供适当的-I选项强制gcc包含路径,例如

 gcc -MM -I$(top)/path/to ... $(top)/path/to/file.c >>$(top)/all.d 

要么

 gcc -MM -I$(top)/path/to ... $(top)/path/to/file.c | sh filter.sh >file.d 

代替

 file.o: file.c defs.h 

gcc会发出

 file.o: /absolute/path/to/file.c /absolute/path/to/defs.h 

当然,这也适用于相对路径。

您可以创建依赖项文件以及第一次编译运行。

在第一次运行期间,对象尚不存在,因此无论如何都将调用编译器。 首先创建空的依赖项文件,然后在编译时更新它们。

应该可以扩展单目录C ++项目的最小Makefile以使用子目录。