免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 2272 | 回复: 2
打印 上一主题 下一主题

求助:关于Makefile变量的问题 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2011-03-31 11:53 |只看该作者 |倒序浏览
请看看下面的 Makefile 脚本代码段:

  1. define DOSUBDIR
  2. $(foreach V,$(SUBDIR_VARS),$(eval $(call RESET,$(V))))

  3. $(warning "$(1)" is $(1))

  4. SUBDIR := $(1)/

  5. $(warning "SUBDIR" is $(SUBDIR) )

  6. include $(1)/Makefile

  7. endef



  8. $(foreach D,$(FFLIBS),$(eval $(call DOSUBDIR,lib$(D))))
复制代码



问题1、$(warning) 为什么没有输出?
问题2、SUBDIR的值到了被包含进来的那个Makefile中为什么访问不到在 DOSUBDIR 中赋的值?我在被包含进来的那个Makefile中用$(info $(SUBDIR))  结果输出的是空。Makefile 宏定义中的变量值是不是离开了宏就失效了?

论坛徽章:
0
2 [报告]
发表于 2011-03-31 17:42 |只看该作者
本帖最后由 wangfeifeiwc 于 2011-04-01 11:20 编辑

注意一下,include那一行。看一下看下一个makefile,是不是对你的问题有所帮助。


all:
    @echo 0

include all_test

all_test:
    @echo 1


你注释一下include行,看看其输出结果会有什么不一样。

我这边的情况是:
不注释include行:
1
0
注释include行:
0
1
具体make的工作机理也不是很清楚,gun的make读取makefile时,如果碰到include将暂停当前makefile的读取,但是这个makefile里面,include的子makefile(all_test)并不存在,所以它将把all_test当做一个目标。

论坛徽章:
0
3 [报告]
发表于 2011-04-01 11:49 |只看该作者
楼上,但这并没有解释为什么warning 没有输出啊。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP