From 5cae104e51be9cbf524b7d953b33d0909c46d006 Mon Sep 17 00:00:00 2001 From: mrkn Date: Sat, 1 Dec 2018 09:29:14 +0000 Subject: Let sub-directory exts depend on their parent ext * ext/extmk.rb: Let sub-directory exts depend on their parent ext. * template/exts.mk.tmpl: ditto. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@66117 b2dd03c8-39d4-4d8f-98ff-823fe69b080e --- template/exts.mk.tmpl | 21 ++++++++++++++++----- 1 file changed, 16 insertions(+), 5 deletions(-) (limited to 'template') diff --git a/template/exts.mk.tmpl b/template/exts.mk.tmpl index e35c28294e..ea1219805b 100644 --- a/template/exts.mk.tmpl +++ b/template/exts.mk.tmpl @@ -128,14 +128,25 @@ libencs: ext/extinit.<%=objext%>: $(Q)$(MAKE)<%=mflags%> V=$(V) EXTINITS="$(EXTINITS)" $@ -% targets.product(macros["extensions"].map {|e|e.chomp("/.")}) do |t, e| -<%=e%>/<%=t%>: -% if /^(dist|real)clean$/ =~ t +% exts = macros["extensions"].map {|e|e.chomp("/.")}.sort +% targets.each do |tgt| +% exts.each do |d| +% t = "#{d}/#{tgt}" +% if /^(dist|real)?clean$/ =~ tgt +% deps = exts.select {|e|e.start_with?("#{d}/")}.map {|e|"#{e}/#{tgt}"} +% pd = ' ' + deps.join(' ') unless deps.empty? +% else +% pext = File.dirname(d) +% pd = " #{pext}/#{tgt}" if exts.include?(pext) +% end +<%=t%>:<%=pd%> +% if /^(dist|real)clean$/ =~ tgt $(ECHO) $(@F)ing $(@D) -% end +% end $(Q)<%= submake %><%=mflags%> V=$(V) $(@F) -% if /^(dist|real)clean$/ =~ t +% if /^(dist|real)clean$/ =~ tgt $(Q)$(RMDIRS) $(@D) +% end % end % end -- cgit v1.2.3