From: dogatana@... Date: 2017-09-05T04:14:09+00:00 Subject: [ruby-dev:50224] [Ruby trunk Bug#13863] RUBYLIB にカレントディレクトリを設定した場合、-E cp932:utf-8 を指定するとスクリプトが全く実行されない Issue #13863 has been updated by dogatana (Toshihiko Ichida). 仕事で使用している Windows 7 64bit の環境で試しましたが、現象発生します。 こちらで確認している条件は次の2点です。 * カレントディレクトに日本語を含む * RUBYLIB に . 設定されている ログを貼ります(プロンプトが2行になっています)が、どうでしょうか。 ~~~ C:\usr\sandbox\ruby\req\テスト $type a.rb puts 'a' require'./b' C:\usr\sandbox\ruby\req\テスト $type b.rb puts 'b' C:\usr\sandbox\ruby\req\テスト $ set RUBYLIB=. C:\usr\sandbox\ruby\req\テスト $ echo %RUBYLIB% . C:\usr\sandbox\ruby\req\テスト $ ruby -v ruby 2.3.3p222 (2016-11-21 revision 56859) [i386-mingw32] C:\usr\sandbox\ruby\req\テスト $ ruby a.rb a b C:\usr\sandbox\ruby\req\テスト $ ruby -E cp932:utf-8 a.rb :4:in `require': stack level too deep (SystemStackError) from :4:in `' C:\usr\sandbox\ruby\req\テスト $ set RUBYLIB= C:\usr\sandbox\ruby\req\テスト $ ruby -E cp932:utf-8 a.rb a b ~~~ なお、a.rb の require './b' を require 'b' と変更すると、 require が失敗します。 ~~~ C:\usr\sandbox\ruby\req\テスト $ type a2.rb puts 'a' require 'b' C:\usr\sandbox\ruby\req\テスト $ ruby -I. a2.rb a c:/programs/ruby/lib/ruby/2.3.0/rubygems/core_ext/kernel_require.rb:55:in `require': cannot load such file -- b (LoadError) from c:/programs/ruby/lib/ruby/2.3.0/rubygems/core_ext/kernel_require.rb:55:in `require' from a2.rb:2:in `
' ~~~ 以前報告されている事例の別パターンのように思われます。 ---------------------------------------- Bug #13863: RUBYLIB にカレントディレクトリを設定した場合、-E cp932:utf-8 を指定するとスクリプトが全く実行されない https://bugs.ruby-lang.org/issues/13863#change-66476 * Author: dogatana (Toshihiko Ichida) * Status: Open * Priority: Normal * Assignee: * Target version: * ruby -v: ruby 2.4.1p111 (2017-03-22 revision 58053) [i386-mingw32] * Backport: 2.2: UNKNOWN, 2.3: UNKNOWN, 2.4: UNKNOWN ---------------------------------------- こんにちは。 Windows 環境の ruby での話です。 [[http://blade.nagaokaut.ac.jp/cgi-bin/scat.rb/ruby/ruby-list/49186]] [[https://bugs.ruby-lang.org/issues/7881]] について、これは少なくとも * ruby 2.3.3p222 (2016-11-21 revision 56859) [i386-mingw32] * ruby 2.4.1p111 (2017-03-22 revision 58053) [i386-mingw32] では発生せず、対策されているようです。 ただし、 * 環境変数 RUBYLIBにカンレントディレクトリ(.)を設定 * E cp932:utf-8 を指定 して上のリンクにある a.rb を実行すると、 ruby 2.3.3p222 (2016-11-21 revision 56859) [i386-mingw32] では ~~~ > ruby -E cp932:utf-8 a.rb :4:in `require': stack level too deep (SystemStackError) from :4:in `' ~~~ と表示され、即座に終了し、 ruby 2.4.1p111 (2017-03-22 revision 58053) [i386-mingw32] では ~~~ > ruby -E cp932:utf-8 a.rb ~~~ と何も表示せず、ruby が終了します。 (内部では SystemStackError が発生?) -E オプションは標準出力を cp932 で出力したいためで、今はIO#set_encoding を使用するようにして対処していますが、 本質的には ruby 側での対策が望ましいのではと思います。 いかがでしょうか。 市田 -- https://bugs.ruby-lang.org/