12

几天前,我在堆栈溢出中发布了一个关于如何编写分层 make 的答案(http://stackoverflow.com/questions/1498213/make-hierarchical-make-file)。答案已被删除,因此我认为它完全错误或偏离主题(或两者兼而有之)。

我想知道如何编写分层 Makefile。这是一个在子目录中调用多个 Makefile 的 Makefile。我假设一个目录结构,如:

- project
  |--module1
      |--Makefile
      |--...
  |--module2
     |--Makefile
     |--module2.1
     |--module2.2  
     |--...
  |--module3
     |--Makefile
     |--...
  |--etc

我还假设项目成员只同意一组最小的 makefile 目标,例如:all(默认)、clean、install 等。因此,包括 make 标志在内的以下命令将传播到模块:

cd project
make clean  
make -k
make install
#etc

以下项目 Makefile 有什么问题:

PACKAGES = \
    module1 \
    module2 \
    emodule3

VIRTUAL_PACKAGES = $(addsuffix /.virtual.Makefile,${PACKAGES})

TARGETS=clean install all

.PHONY: $(TARGETS)
default: all

FLAGS = $(ifeq $(MAKEFLAGS) "","",-$(MAKEFLAGS))

$(TARGETS): $(VIRTUAL_PACKAGES)

$(VIRTUAL_PACKAGES): 
    $(MAKE) $(FLAGS) -C $(@D) $(MAKECMDGOALS)

是的,Makefile 中的 $VIRTUAL_PACKAGES 看起来很奇怪。混合 for 循环的替代方法有点短,但我不确定它是否更好(因为我需要依赖 bash): PACKAGES = \ module1 \ module2 \ emodule3

TARGETS=clean install all

.PHONY: $(TARGETS)
default: all

FLAGS = $(ifeq $(MAKEFLAGS) "","",-$(MAKEFLAGS))

$(TARGETS): 
    for p in $(PACKAGES) ; do $(MAKE) $(FLAGS) -C $$p $@ || break; done

谢谢!

4

1 回答 1

10

这里有“龙”。可以做到,但其含义可能很棘手。

谷歌,“Recursive Make Considered Harmful”。你会得到很好的(简单的)说明你想要什么(例如,分层制作),以及对陷阱/担忧的很好的解释。一些“回应”将讨论可能的“最佳实践”,以及缓解问题的方法。然后,您可以决定提出的问题是否对您的应用程序有吸引力。

原论文:

http://miller.emu.id.au/pmiller/books/rmch/

其他一些链接:

http://c2.com/cgi/wiki?RecursiveMakeConsideredHarmful

http://dbaspot.com/configuration-management/194597-thoughts-recursive-make-considered-harmful.html

于 2012-07-09T14:00:06.230 回答