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

ruby-changes:24771

From: nobu <ko1@a...>
Date: Sat, 25 Aug 2012 16:20:40 +0900 (JST)
Subject: [ruby-changes:24771] nobu:r36822 (trunk): generic_erb.rb: --vpath option

nobu	2012-08-25 16:20:29 +0900 (Sat, 25 Aug 2012)

  New Revision: 36822

  http://svn.ruby-lang.org/cgi-bin/viewvc.cgi?view=rev&revision=36822

  Log:
    generic_erb.rb: --vpath option
    
    * tool/generic_erb.rb (vpath.open): move --vpath option from
      template/id.h.tmpl.

  Modified files:
    trunk/common.mk
    trunk/template/id.h.tmpl
    trunk/tool/generic_erb.rb

Index: common.mk
===================================================================
--- common.mk	(revision 36821)
+++ common.mk	(revision 36822)
@@ -855,8 +855,8 @@
 $(ID_H_INCLUDES) $(ID_H_TARGET): {$(VPATH)}parse.h $(srcdir)/tool/generic_erb.rb $(srcdir)/template/id.h.tmpl
 	$(ECHO) generating id.h
 	$(Q) $(BASERUBY) $(srcdir)/tool/generic_erb.rb --if-change --output=id.h \
-		--timestamp=$@ \
-		$(srcdir)/template/id.h.tmpl --vpath=$(VPATH) parse.h
+		--vpath=$(VPATH) --timestamp \
+		$(srcdir)/template/id.h.tmpl parse.h
 
 node_name.inc: {$(VPATH)}node.h
 	$(ECHO) generating $@
Index: tool/generic_erb.rb
===================================================================
--- tool/generic_erb.rb	(revision 36821)
+++ tool/generic_erb.rb	(revision 36822)
@@ -2,13 +2,27 @@
 require 'optparse'
 require 'fileutils'
 
+vpath = ["."]
+def vpath.open(file, *rest)
+  find do |dir|
+    begin
+      path = File.join(dir, file)
+      return File.open(path, *rest) {|f| yield(f)}
+    rescue Errno::ENOENT
+      nil
+    end
+  end or raise(Errno::ENOENT, file)
+end
+
 timestamp = nil
 output = nil
 ifchange = nil
+
 opt = OptionParser.new do |o|
   o.on('-t', '--timestamp[=PATH]') {|v| timestamp = v || true}
   o.on('-o', '--output=PATH') {|v| output = v}
   o.on('-c', '--[no-]if-change') {|v| ifchange = v}
+  o.on('-v', '--vpath=DIR') {|dirs| vpath.concat dirs.split(File::PATH_SEPARATOR)}
   o.order!(ARGV)
 end
 template = ARGV.shift or abort opt.to_s
@@ -16,7 +30,7 @@
 erb.filename = template
 result = erb.result
 if output
-  if ifchange and (IO.read(output) rescue nil) == result
+  if ifchange and (vpath.open(output) {|f| f.read} rescue nil) == result
     puts "#{output} unchanged"
   else
     open(output, "wb") {|f| f.print result}
Index: template/id.h.tmpl
===================================================================
--- template/id.h.tmpl	(revision 36821)
+++ template/id.h.tmpl	(revision 36822)
@@ -12,24 +12,13 @@
 **********************************************************************/
 <%
 require 'optparse'
-vpath = ["."]
-input = nil
 
-opt = OptionParser.new do |o|
-  o.on('-v', '--vpath=DIR') {|dirs| vpath.concat dirs.split(File::PATH_SEPARATOR)}
-  input, = o.order!(ARGV)
-end or abort opt.opt_s
+input = ARGV.shift or abort opt.opt_s
 
 tokens = nil
-vpath.find do |dir|
-  begin
-    if line = File.read(File.join(dir, input))[/^\s*enum\s+yytokentype\s*\{([^{}]*)\s*\};/m, 1]
-      tokens = line.scan(/\b(t(?:LAST_TOKEN|U(?:PLUS|MINUS)|POW|CMP|EQQ?|[NGL]EQ|(?:AND|OR)OP|N?MATCH|DOT\d|AREF|ASET|[LR]SHFT|LAMBDA)|id\w+)\s*=\s*(\d+),?/m)
-    end
-  rescue Errno::ENOENT
-    nil
-  else
-    true
+vpath.open(input) do |f|
+  if line = f.read[/^\s*enum\s+yytokentype\s*\{([^{}]*)\s*\};/m, 1]
+    tokens = line.scan(/\b(t(?:LAST_TOKEN|U(?:PLUS|MINUS)|POW|CMP|EQQ?|[NGL]EQ|(?:AND|OR)OP|N?MATCH|DOT\d|AREF|ASET|[LR]SHFT|LAMBDA)|id\w+)\s*=\s*(\d+),?/m)
   end
 end
 

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

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