如何附加到 Makefile 中的变量列表?

How to append to a list of variables in a Makefile?

我正在尝试为以下项目结构编写 Makefile

/project
  Makefile
  main.cpp
  test.hpp
  /a
    s1.cpp 
    s1.hpp 
    s2.cpp 
    s2.hpp
  /b
    s1.cpp 
    s1.hpp 
    s2.cpp 
    s2.hpp
  /c
    s1.cpp 
    s1.hpp 
    s2.cpp 
    s2.hpp

我有 3 个包含 .cpp 和 .hpp 文件的文件夹,我想在 INC 变量中包含所有 hpp 文件

DIRS = ./a ./b ./c
INC = $(wildcard *.hpp) # how to have here ./a/s1.hpp ./a/s2.hpp ./b/s1.hpp ./b/s2.hpp etc...?

INC 只抓取 Makefile 目录中的 .hpp 文件,而不抓取子目录中的 .hpp 文件。如何自动指定子目录下的所有headers?感谢提示。

wildcard 函数采用多种模式。 addsuffix 函数为列表中的每个单词附加一个后缀。所以:

INC = $(wildcard $(addsuffix /*.hpp,$(DIRS)))

应该做你想做的。还有其他方法,例如:

INC = $(foreach d,$(DIRS),$(wildcard $(d)/*.hpp))

或者,如果您有 find 实用程序并且想要在任何深度的任何子目录中找到所有 *.hpp 文件(而不仅仅是在 $(DIRS) 中):

INC = $(shell find . -type f -name '*.hpp')

最后一种形式可能更好,因为您不需要提供目录列表。