Bug #13863
closedRUBYLIB にカレントディレクトリを設定した場合、-E cp932:utf-8 を指定するとスクリプトが全く実行されない
Description
こんにちは。
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
<internal:enc/prelude>:4:in `require': stack level too deep (SystemStackError)
from <internal:enc/prelude>:4:in `<internal:enc/prelude>'
と表示され、即座に終了し、
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 側での対策が望ましいのではと思います。
いかがでしょうか。
市田
Updated by usa (Usaku NAKAMURA) over 7 years ago
私の手元にあるmswin32/mswin64/mingw32/mingw64の2.3.4/2.4.1/trunkではいずれでも再現しませんでした。
他に何か再現条件があるのでしょうか?
Updated by dogatana (Toshihiko Ichida) over 7 years ago
仕事で使用している 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
<internal:enc/prelude>:4:in `require': stack level too deep (SystemStackError)
from <internal:enc/prelude>:4:in `<internal:enc/prelude>'
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 `<main>'
以前報告されている事例の別パターンのように思われます。
Updated by usa (Usaku NAKAMURA) over 7 years ago
- Backport changed from 2.2: UNKNOWN, 2.3: UNKNOWN, 2.4: UNKNOWN to 2.2: WONTFIX, 2.3: REQUIRED, 2.4: REQUIRED
あー、再現しました。ありがとうございます。
カレントディレクトに日本語を含む
これがすっぽ抜けてました。
あとは、RUBYLIB
の場合だけで、-I
などでは問題ないようですね。なるほど。
Updated by dogatana (Toshihiko Ichida) over 7 years ago
あとは、RUBYLIB の場合だけで、-I などでは問題ないようですね。なるほど。
そうですね。
a2.rb で -I. を使用する場合だと、require が失敗するだけで、
いきなり終了する現象は出ません。
require が失敗するケースも対策されるとうれしいです。
Updated by nobu (Nobuyoshi Nakada) over 7 years ago
- Status changed from Open to Closed
Applied in changeset trunk|r60743.
load.c: cwd encoding
- load.c (rb_get_expanded_load_path): save cwd cache in OS path
encoding, to get rid of unnecessary conversion and infinite
loading when it needs encoding conversion.
[ruby-dev:50221] [Bug #13863]
Updated by nagachika (Tomoyuki Chikanaga) about 7 years ago
- Backport changed from 2.2: WONTFIX, 2.3: REQUIRED, 2.4: REQUIRED to 2.2: WONTFIX, 2.3: REQUIRED, 2.4: DONE
ruby_2_4 r62784 merged revision(s) 58745,58780,59040,60743.
Updated by nagachika (Tomoyuki Chikanaga) about 7 years ago
I backported additionally r57484,r58767,r58938,r59041 to try to get rid of CI failure.
http://mswinci.japaneast.cloudapp.azure.com/vc12-x64/ruby-2.4/log/20180316T201433Z.fail.html.gz
Updated by nagachika (Tomoyuki Chikanaga) about 7 years ago
- Backport changed from 2.2: WONTFIX, 2.3: REQUIRED, 2.4: DONE to 2.2: WONTFIX, 2.3: REQUIRED, 2.4: REQUIRED
テストが通らなかったので ruby_2_4 へのバックポート r62797, r62784 は revert しました。