免费注册 查看新帖 |

ChinaUnix.net

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 1521 | 回复: 3

[Linux] 请教个linux makefile的foreach的问题 [复制链接]

论坛徽章:
0
发表于 2016-01-11 11:06 |显示全部楼层
其实我本来的目的是想include特定目录下(不是所有的目录,所以不能用通配符*)的makefile,所以想用foreach来实现,但是发现foreach好像不行。
比如
jeep=test1  test2
define  subdir2
        $(foreach something ,$(jeep),$(warning  ==$(something)===  ))
endef
$(eval  $(call subdir2))
但是执行的话
make]$ make
Makefile:16: =====  
Makefile:16: =====  

这个变量没有值。

我的最终目的是这个

define  subdir1
$(foreach dir ,$(jeep),$($(eval  $(call extend,include   ./$(dir)/test.mk))) )
endef

extend=$(1)

$(eval  $(call subdir1))
这个写法,我是照着openwrt下面的makefile写的,不知道为什么不行。求大神指点。

论坛徽章:
84
每日论坛发贴之星
日期:2015-12-29 06:20:00每日论坛发贴之星
日期:2016-01-16 06:20:00每周论坛发贴之星
日期:2016-01-17 22:22:00程序设计版块每日发帖之星
日期:2016-01-20 06:20:00每日论坛发贴之星
日期:2016-01-20 06:20:00程序设计版块每日发帖之星
日期:2016-01-21 06:20:00每日论坛发贴之星
日期:2016-01-21 06:20:00程序设计版块每日发帖之星
日期:2016-01-23 06:20:00程序设计版块每日发帖之星
日期:2016-01-31 06:20:00数据库技术版块每日发帖之星
日期:2016-01-16 06:20:00程序设计版块每日发帖之星
日期:2016-01-16 06:20:00程序设计版块每日发帖之星
日期:2016-01-14 06:20:00
发表于 2016-01-11 15:51 |显示全部楼层
  1. [yjh@fs-qe ci_scripts]$ make
  2. Makefile:3: ==test1===  
  3. Makefile:3: ==test2===  
  4. echo test
  5. test
  6. [yjh@fs-qe ci_scripts]$ cat Makefile

  7. jeep = test1 test2
  8. $(foreach something, $(jeep), $(warning  ==$(something)===  ))

  9. all:
  10.         echo test
复制代码
逗号位置不对,

论坛徽章:
0
发表于 2016-01-11 19:25 |显示全部楼层
感谢感谢,他把空格居然也算成有效字符了,所以要想打出来只能用$(something ),不过正常foreach函数里面这个是以,作为分隔符的。不过如果有方法,可以让makefile在函数中不在意这些空格就好了。回复 2# yjh777


   

论坛徽章:
84
每日论坛发贴之星
日期:2015-12-29 06:20:00每日论坛发贴之星
日期:2016-01-16 06:20:00每周论坛发贴之星
日期:2016-01-17 22:22:00程序设计版块每日发帖之星
日期:2016-01-20 06:20:00每日论坛发贴之星
日期:2016-01-20 06:20:00程序设计版块每日发帖之星
日期:2016-01-21 06:20:00每日论坛发贴之星
日期:2016-01-21 06:20:00程序设计版块每日发帖之星
日期:2016-01-23 06:20:00程序设计版块每日发帖之星
日期:2016-01-31 06:20:00数据库技术版块每日发帖之星
日期:2016-01-16 06:20:00程序设计版块每日发帖之星
日期:2016-01-16 06:20:00程序设计版块每日发帖之星
日期:2016-01-14 06:20:00
发表于 2016-01-12 11:03 |显示全部楼层
嗯,理解很到位!
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

基于案例的 SQL 优化实战训练营

讲师:中电福富特级专家梁敬彬,参与本次课程培训,你将收获:
1. 能编写出较为高效的 SQL;
2. 能解决70%以上的数据库常见优化问题;
3. 能得到老师提供的高效的相关工具和解决方案;
4. 能举一反三,收获不仅仅是 SQL 优化。
现在购票享受8.8折优惠!
----------------------------------------
优惠时间:2019年3月20日前

大会官网>>
  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP