[前][次][番号順一覧][スレッド一覧]

ruby-changes:2776

From: ko1@a...
Date: 17 Dec 2007 17:48:25 +0900
Subject: [ruby-changes:2776] nobu - Ruby:r14267 (trunk): * common.mk (encs): new target to compile external encodings.

nobu	2007-12-17 17:47:28 +0900 (Mon, 17 Dec 2007)

  New Revision: 14267

  Added files:
    trunk/enc/make_encmake.rb
    trunk/tool/serb.rb
  Modified files:
    trunk/ChangeLog
    trunk/common.mk
    trunk/enc/Makefile.in
    trunk/ext/extmk.rb
    trunk/lib/mkmf.rb
    trunk/tool/compile_prelude.rb

  Log:
    * common.mk (encs): new target to compile external encodings.
    
    * enc/Makefile.in: became a serb template.
    
    * enc/make_encmake.rb: creates enc.mk from enc/Makefile.in using serb.
    
    * lib/mkmf.rb (relative_from): moved from ext/extmk.rb.
    
    * lib/mkmf.rb ($extmk): true if under to top source directory, not
      only ext.
    
    * lib/mkmf.rb (depend_rules): extracted from create_makefile.
    
    * tool/serb.rb (serb): splitted from tool/compile_prelude.rb.


  http://svn.ruby-lang.org/cgi-bin/viewvc.cgi/trunk/tool/serb.rb?revision=14267&view=markup
  http://svn.ruby-lang.org/cgi-bin/viewvc.cgi/trunk/tool/serb.rb?r1=14267&r2=14266
  http://svn.ruby-lang.org/cgi-bin/viewvc.cgi/trunk/enc/make_encmake.rb?revision=14267&view=markup
  http://svn.ruby-lang.org/cgi-bin/viewvc.cgi/trunk/enc/make_encmake.rb?r1=14267&r2=14266
  http://svn.ruby-lang.org/cgi-bin/viewvc.cgi/trunk/tool/compile_prelude.rb?r1=14267&r2=14266
  http://svn.ruby-lang.org/cgi-bin/viewvc.cgi/trunk/ChangeLog?r1=14267&r2=14266
  http://svn.ruby-lang.org/cgi-bin/viewvc.cgi/trunk/lib/mkmf.rb?r1=14267&r2=14266
  http://svn.ruby-lang.org/cgi-bin/viewvc.cgi/trunk/enc/Makefile.in?r1=14267&r2=14266
  http://svn.ruby-lang.org/cgi-bin/viewvc.cgi/trunk/ext/extmk.rb?r1=14267&r2=14266
  http://svn.ruby-lang.org/cgi-bin/viewvc.cgi/trunk/common.mk?r1=14267&r2=14266

Index: ChangeLog
===================================================================
--- ChangeLog	(revision 14266)
+++ ChangeLog	(revision 14267)
@@ -1,3 +1,20 @@
+Mon Dec 17 17:47:26 2007  Nobuyoshi Nakada  <nobu@r...>
+
+	* common.mk (encs): new target to compile external encodings.
+
+	* enc/Makefile.in: became a serb template.
+
+	* enc/make_encmake.rb: creates enc.mk from enc/Makefile.in using serb.
+
+	* lib/mkmf.rb (relative_from): moved from ext/extmk.rb.
+
+	* lib/mkmf.rb ($extmk): true if under to top source directory, not
+	  only ext.
+
+	* lib/mkmf.rb (depend_rules): extracted from create_makefile.
+
+	* tool/serb.rb (serb): splitted from tool/compile_prelude.rb.
+
 Mon Dec 17 17:32:55 2007  Nobuyoshi Nakada  <nobu@r...>
 
 	* configure.in (MAKEFILES): removed enc/Makefile.
Index: enc/Makefile.in
===================================================================
--- enc/Makefile.in	(revision 14266)
+++ enc/Makefile.in	(revision 14267)
@@ -4,7 +4,7 @@
 EXTOUT = @EXTOUT@
 hdrdir = $(top_srcdir)/include
 arch_hdrdir = $(EXTOUT)/include/$(arch)
-VPATH = $(arch_hdrdir)/ruby:$(hdrdir)/ruby:$(top_srcdir):$(srcdir)
+VPATH = <% %w[$(arch_hdrdir)/ruby $(hdrdir)/ruby $(top_srcdir) $(srcdir)].join("@PATH_SEPARATOR@") %>
 ENCSODIR = $(EXTOUT)/$(arch)/enc
 DLEXT = @DLEXT@
 OBJEXT = @OBJEXT@
@@ -13,8 +13,8 @@
 		  euc_jp.c sjis.c \
 		  unicode.c utf8.c
 
-ENCOBJS = @EXTERNAL_ENCOBJS@
-ENCSOS = @ENCSOS@
+ENCOBJS = <%encs.map {|e|"#{e}.$(OBJEXT)"}.join(" \\\n\t  ")+"\n"%>
+ENCSOS = <%encs.map {|e|"$(ENCSODIR)/#{e}.$(DLEXT)"}.join(" \\\n\t ")+"\n"%>
 empty =
 CC = @CC@
 OUTFLAG = @OUTFLAG@$(empty)
@@ -26,3 +26,17 @@
 LIBS = @LIBS@ $(EXTLIBS)
 LDSHARED = @LDSHARED@
 DLDFLAGS = @DLDFLAGS@ $(EXTLDFLAGS) @ARCH_FLAG@
+
+#!#! if File.exist?(depend = File.join($srcdir, "depend"))
+#### depend ####
+#!#<%  depend_rules(depend).join%>
+#!#! end
+#!#! encs.each do |e|
+#!#
+#!#$(ENCSODIR)/<%e%>.$(DLEXT): <%e%>.$(OBJEXT)
+#!#	<%LINK_SO.gsub(/\n/, "\n\t")%>
+#!#! end
+#!#! encs.each do |e|
+#!#
+#!#<%e%>.$(OBJEXT): <% (RULE_SUBST || "%s") % "#{e}.c" %>
+#!#! end
Index: enc/make_encmake.rb
===================================================================
--- enc/make_encmake.rb	(revision 0)
+++ enc/make_encmake.rb	(revision 14267)
@@ -0,0 +1,23 @@
+#! ./miniruby
+
+dir = File.expand_path("../..", __FILE__)
+$:.unshift(File.join(dir, "lib"))
+$:.unshift(dir)
+File.directory?("enc") || File.mkdir("enc")
+$:.unshift(".")
+require 'mkmf'
+require 'tool/serb'
+
+encdir = File.join($top_srcdir, "enc")
+
+encs = Dir.open(encdir) {|d| d.grep(/.+\.c\z/)}
+encs -= CONFIG["BUILTIN_ENCS"].split
+encs.each {|e| e.chomp!(".c")}
+mkin = File.read(File.join(encdir, "Makefile.in"))
+mkin.gsub!(/^\#!\# ?/, '')
+mkin.gsub!(/@(#{RbConfig::MAKEFILE_CONFIG.keys.join('|')})@/) {CONFIG[$1]}
+tmp = ''
+eval(serb(mkin, 'tmp'))
+open(ARGV[0], 'w') {|f|
+  f.puts tmp
+}

Property changes on: enc/make_encmake.rb
___________________________________________________________________
Name: svn:keywords
   + Author Date Id Revision
Name: svn:eol-style
   + LF

Index: lib/mkmf.rb
===================================================================
--- lib/mkmf.rb	(revision 14266)
+++ lib/mkmf.rb	(revision 14267)
@@ -74,6 +74,15 @@
   Regexp.new('\$(?:\('+dir+'\)|\{'+dir+'\})(?:\$(?:\(target_prefix\)|\{target_prefix\}))?')
 end
 
+def relative_from(path, base)
+  dir = File.join(path, "")
+  if File.expand_path(dir) == File.expand_path(dir, base)
+    path
+  else
+    File.join(base, path)
+  end
+end
+
 INSTALL_DIRS = [
   [dir_re('commondir'), "$(RUBYCOMMONDIR)"],
   [dir_re('sitedir'), "$(RUBYCOMMONDIR)"],
@@ -136,7 +145,7 @@
 
 topdir = File.dirname(libdir = File.dirname(__FILE__))
 extdir = File.expand_path("ext", topdir)
-$extmk = File.expand_path($0)[0, extdir.size+1] == extdir+"/"
+$extmk = File.expand_path($0)[0, topdir.size+1] == topdir+"/"
 if not $extmk and File.exist?(($hdrdir = RbConfig::CONFIG["rubyhdrdir"]) + "/ruby/ruby.h")
   $topdir = $hdrdir
   $top_srcdir = $hdrdir
@@ -1257,6 +1266,60 @@
 RULES
 end
 
+def depend_rules(depend)
+  suffixes = []
+  depout = []
+  depout << "$(OBJS): $(RUBY_EXTCONF_H)\n\n" if $extconf_h
+  unless suffixes.empty?
+     depout << ".SUFFIXES: ." + suffixes.uniq.join(" .") + "\n\n"
+  end
+  open(depend, "r") do |dfile|
+    cont = implicit = nil
+    impconv = proc do
+      COMPILE_RULES.each {|rule| depout << (rule % implicit[0]) << implicit[1]}
+      implicit = nil
+    end
+    ruleconv = proc do |line|
+      if implicit
+        if /\A\t/ =~ line
+          implicit[1] << line
+          next
+        else
+          impconv[]
+        end
+      end
+      if m = /\A\.(\w+)\.(\w+)(?:\s*:)/.match(line)
+        suffixes << m[1] << m[2]
+        implicit = [[m[1], m[2]], [m.post_match]]
+        next
+      elsif RULE_SUBST and /\A(?!\s*\w+\s*=)[$\w][^#]*:/ =~ line
+        line.gsub!(%r"(?<=\s)(?!\.)([^$(){}+=:\s\/\\,]+)(?=\s|\z)", &RULE_SUBST.method(:%))
+      end
+      depout << line
+    end
+    while line = dfile.gets()
+      line.gsub!(/\.o\b/, ".#{$OBJEXT}")
+      line.gsub!(/\$\((?:hdr|top)dir\)\/config.h/, $config_h) if $config_h
+      line.gsub!(%r"\$\(hdrdir\)/(?!ruby/)", '\&ruby/')
+      if /(?:^|[^\\])(?:\\\\)*\\$/ =~ line
+        (cont ||= []) << line
+        next
+      elsif cont
+        line = (cont << line).join
+        cont = nil
+      end
+      ruleconv.call(line)
+    end
+    if cont
+      ruleconv.call(cont.join)
+    elsif implicit
+      impconv.call
+    end
+  end
+  depout.flatten!
+  depout
+end
+
 # Generates the Makefile for your extension, passing along any options and
 # preprocessor constants that you may have generated through other methods.
 #
@@ -1518,57 +1581,7 @@
 
   depend = File.join(srcdir, "depend")
   if File.exist?(depend)
-    suffixes = []
-    depout = []
-    open(depend, "r") do |dfile|
-      mfile.printf "###\n"
-      cont = implicit = nil
-      impconv = proc do
-	COMPILE_RULES.each {|rule| depout << (rule % implicit[0]) << implicit[1]}
-	implicit = nil
-      end
-      ruleconv = proc do |line|
-	if implicit
-	  if /\A\t/ =~ line
-	    implicit[1] << line
-	    next
-	  else
-	    impconv[]
-	  end
-	end
-	if m = /\A\.(\w+)\.(\w+)(?:\s*:)/.match(line)
-          suffixes << m[1] << m[2]
-	  implicit = [[m[1], m[2]], [m.post_match]]
-	  next
-	elsif RULE_SUBST and /\A(?!\s*\w+\s*=)[$\w][^#]*:/ =~ line
-	  line.gsub!(%r"(?<=\s)(?!\.)([^$(){}+=:\s\/\\,]+)(?=\s|\z)", &RULE_SUBST.method(:%))
-	end
-	depout << line
-      end
-      while line = dfile.gets()
-	line.gsub!(/\.o\b/, ".#{$OBJEXT}")
-	line.gsub!(/\$\((?:hdr|top)dir\)\/config.h/, $config_h) if $config_h
-	line.gsub!(%r"\$\(hdrdir\)/(?!ruby/)", '\&ruby/')
-	if /(?:^|[^\\])(?:\\\\)*\\$/ =~ line
-	  (cont ||= []) << line
-	  next
-	elsif cont
-	  line = (cont << line).join
-	  cont = nil
-	end
-	ruleconv.call(line)
-      end
-      if cont
-	ruleconv.call(cont.join)
-      elsif implicit
-	impconv.call
-      end
-    end
-    unless suffixes.empty?
-      mfile.print ".SUFFIXES: .", suffixes.uniq.join(" ."), "\n\n"
-    end
-    mfile.print "$(OBJS): $(RUBY_EXTCONF_H)\n\n" if $extconf_h
-    mfile.print(*depout.flatten)
+    mfile.print("###\n", *depend_rules(depend))
   else
     headers = %w[ruby.h defines.h]
     if RULE_SUBST
Index: common.mk
===================================================================
--- common.mk	(revision 14266)
+++ common.mk	(revision 14267)
@@ -96,7 +96,7 @@
 
 BOOTSTRAPRUBY = $(BASERUBY)
 
-all: $(MKFILES) $(PREP) $(RBCONFIG) $(LIBRUBY)
+all: $(MKFILES) $(PREP) $(RBCONFIG) $(LIBRUBY) encs
 	@$(MINIRUBY) $(srcdir)/ext/extmk.rb $(EXTMK_ARGS)
 prog: $(PROGRAM) $(WPROGRAM)
 
@@ -339,6 +339,12 @@
 		-install_name=$(RUBY_INSTALL_NAME) \
 		-so_name=$(RUBY_SO_NAME) rbconfig.rb
 
+encs: enc.mk
+	$(MAKE) -f enc.mk
+
+enc.mk: miniruby$(EXEEXT)
+	$(MINIRUBY) $(srcdir)/enc/make_encmake.rb $@
+
 .PRECIOUS: $(MKFILES)
 
 .PHONY: test install install-nodoc install-doc dist
Index: ext/extmk.rb
===================================================================
--- ext/extmk.rb	(revision 14266)
+++ ext/extmk.rb	(revision 14267)
@@ -42,15 +42,6 @@
   @quote ? x.quote : x
 end
 
-def relative_from(path, base)
-  dir = File.join(path, "")
-  if File.expand_path(dir) == File.expand_path(dir, base)
-    path
-  else
-    File.join(base, path)
-  end
-end
-
 def extract_makefile(makefile, keep = true)
   m = File.read(makefile)
   if !(target = m[/^TARGET[ \t]*=[ \t]*(\S*)/, 1])
Index: tool/compile_prelude.rb
===================================================================
--- tool/compile_prelude.rb	(revision 14266)
+++ tool/compile_prelude.rb	(revision 14267)
@@ -54,23 +54,7 @@
   [setup_lines, lines]
 }
 
-def serb(str, var)
-  result = ''
-  str.each_line {|line|
-    if /\A!/ =~ line
-      result << $'
-    else
-      line.split(/(<%.*?%>)/).each {|x|
-        if /\A<%(.*)%>\z/ =~ x
-          result << "#{var} << (#{$1}).to_s\n"
-        else
-          result << "#{var} << #{x.dump}\n"
-        end
-      }
-    end
-  }
-  result
-end
+require 'tool/serb'
 
 tmp = ''
 eval(serb(<<'EOS', 'tmp'))
Index: tool/serb.rb
===================================================================
--- tool/serb.rb	(revision 0)
+++ tool/serb.rb	(revision 14267)
@@ -0,0 +1,17 @@
+def serb(str, var)
+  result = ''
+  str.each_line {|line|
+    if /\A!/ =~ line
+      result << $'
+    else
+      line.split(/(<%.*?%>)/).each {|x|
+        if /\A<%(.*)%>\z/ =~ x
+          result << "#{var} << (#{$1}).to_s\n"
+        else
+          result << "#{var} << #{x.dump}\n"
+        end
+      }
+    end
+  }
+  result
+end

Property changes on: tool/serb.rb
___________________________________________________________________
Name: svn:keywords
   + Author Date Id Revision
Name: svn:eol-style
   + LF


--
ML: ruby-changes@q...
Info: http://www.atdot.net/~ko1/quickml

[前][次][番号順一覧][スレッド一覧]