一个通用的Makefile框架

先做一个简单的记录,后续有时间再慢慢完善补充细节。

先上一个整体图片:

 

 

其中,最重要的文件就是:program_template.mk。

下面是program_template.mk最重要的内容:

$(1)_COBJS = $$(patsubst $$($(1)_SDIR)%.c,$$($(1)_BIN)/%.o,$$($(1)_CSRCS))
$(1)_OBJS = $$($(1)_COBJS)

$(1)_COBJDEPS = $$(patsubst $$($(1)_SDIR)%.c, $$($(1)_BIN)/%.d,$$($(1)_CSRCS))
$(1)_OBJDEPS = $$($(1)_COBJDEPS

$$($(1)_COBJS): $$($(1)_BIN)/%.o: $$($(1)_SDIR)%.c
    $$(CC) $$($(1)_CFLAGS) $$($(1)_CXXFLAGS) -c $$< -o $$@

$$($(1)_COBJDEPS): $$($(1)_BIN)/%.d: $$($(1)_SDIR)%.c
    [ -d $$(@D) ] || mkdir -p $$(@D) &&  \
    $$(CC) -M -MP $$($(1)_CFLAGS) $$($(1)_CXXFLAGS) $$< | \
    sed 's|\($$(notdir $$*)\)\.o[ :]*|$$(dir $$@)\1.o $$@ : |g' > $$@


$(1): $$($(1)_EXEC) ;

$$($(1)_EXEC): $$($(1)_OBJS) $$($(1)_LIBDEPS)
    $$(CC) -o $$@ $$($(1)_OBJS) $$($(1)_LDFLAGS)
    echo $$@ : $$^ > $$@_EXEC.dep

  

最重要的内容已列出,后续有时间再慢慢完善一些细节,有对Makefile有兴趣的朋友可以探讨交流。

 

posted on 2017-01-20 09:09  我是修行者  阅读(388)  评论(0编辑  收藏  举报