请问为什么“make clean”要先加上前缀然后再替换掉呢?

hyw323 2018-08-01 01:54:32
# Directories & files removed with 'make clean'
CLEAN_DIRS +=
CLEAN_FILES += myapp

# clean - Delete most
#
clean: rm-dirs := $(CLEAN_DIRS)
clean: rm-files := $(CLEAN_FILES)
clean-dirs := $(addprefix _clean_, . $(myapp-dirs))

PHONY += $(clean-dirs) clean archclean
$(clean-dirs):
$(Q)$(MAKE) $(clean)=$(patsubst _clean_%,%,$@)

clean: $(clean-dirs)
$(call cmd,rmdirs)
$(call cmd,rmfiles)
@find . $(RCS_FIND_IGNORE) \
\( -name '*.[oas]' -o -name '.*.cmd' \
-o -name '.*.d' -o -name '.*.tmp' \
-o -name '.tmp_*.o.*' \
-o -name '*.gcno' \) -type f -print | xargs rm -f


clean-dirs := $(addprefix _clean_, . $(myapp-dirs)),这句给clean-dirs加上了前缀_clean_

$(clean-dirs):
$(Q)$(MAKE) $(clean)=$(patsubst _clean_%,%,$@),这句又把前缀_clean_替换掉了

请问这样先加前缀,后替换掉是为了什么呢?谢谢先!
...全文
667 1 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
1 条回复
切换为时间正序
请发表友善的回复…
发表回复
nes-c 2018-08-01
  • 打赏
  • 举报
回复
$(clean-dirs):
$(Q)$(MAKE) $(clean)=$(patsubst _clean_%,%,$@)
这是个依赖的规则吧,先patsubst 掉_clean_,然后再执行${clean-dirs} ,也就是说是先去除_clean_,再加上 ,这个地方的目的保证避免二次添加前缀
至于这个前缀是干嘛的就要看整个Makefile了

4,465

社区成员

发帖
与我相关
我的任务
社区描述
Linux/Unix社区 内核源代码研究区
社区管理员
  • 内核源代码研究区社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧