ruby-dev (Japanese) list archive (unofficial mirror)
 help / color / mirror / Atom feed
* [ruby-dev:50221] [Ruby trunk Bug#13863] RUBYLIB にカレントディレクトリを設定した場合、-E cp932:utf-8 を指定するとスクリプトが全く実行されない
       [not found] <redmine.issue-13863.20170904105927@ruby-lang.org>
@ 2017-09-04 10:59 ` dogatana
  2017-09-04 12:13 ` [ruby-dev:50222] " usa
                   ` (6 subsequent siblings)
  7 siblings, 0 replies; 8+ messages in thread
From: dogatana @ 2017-09-04 10:59 UTC (permalink / raw)
  To: ruby-dev

Issue #13863 has been reported by dogatana (Toshihiko Ichida).

----------------------------------------
Bug #13863: RUBYLIB にカレントディレクトリを設定した場合、-E cp932:utf-8 を指定するとスクリプトが全く実行されない
https://bugs.ruby-lang.org/issues/13863

* 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
<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 側での対策が望ましいのではと思います。

いかがでしょうか。


市田



-- 
https://bugs.ruby-lang.org/

^ permalink raw reply	[flat|nested] 8+ messages in thread

* [ruby-dev:50222] [Ruby trunk Bug#13863] RUBYLIB にカレントディレクトリを設定した場合、-E cp932:utf-8 を指定するとスクリプトが全く実行されない
       [not found] <redmine.issue-13863.20170904105927@ruby-lang.org>
  2017-09-04 10:59 ` [ruby-dev:50221] [Ruby trunk Bug#13863] RUBYLIB にカレントディレクトリを設定した場合、-E cp932:utf-8 を指定するとスクリプトが全く実行されない dogatana
@ 2017-09-04 12:13 ` usa
  2017-09-05  4:14 ` [ruby-dev:50224] " dogatana
                   ` (5 subsequent siblings)
  7 siblings, 0 replies; 8+ messages in thread
From: usa @ 2017-09-04 12:13 UTC (permalink / raw)
  To: ruby-dev

Issue #13863 has been updated by usa (Usaku NAKAMURA).


私の手元にあるmswin32/mswin64/mingw32/mingw64の2.3.4/2.4.1/trunkではいずれでも再現しませんでした。
他に何か再現条件があるのでしょうか?

----------------------------------------
Bug #13863: RUBYLIB にカレントディレクトリを設定した場合、-E cp932:utf-8 を指定するとスクリプトが全く実行されない
https://bugs.ruby-lang.org/issues/13863#change-66470

* 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
<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 側での対策が望ましいのではと思います。

いかがでしょうか。


市田



-- 
https://bugs.ruby-lang.org/

^ permalink raw reply	[flat|nested] 8+ messages in thread

* [ruby-dev:50224] [Ruby trunk Bug#13863] RUBYLIB にカレントディレクトリを設定した場合、-E cp932:utf-8 を指定するとスクリプトが全く実行されない
       [not found] <redmine.issue-13863.20170904105927@ruby-lang.org>
  2017-09-04 10:59 ` [ruby-dev:50221] [Ruby trunk Bug#13863] RUBYLIB にカレントディレクトリを設定した場合、-E cp932:utf-8 を指定するとスクリプトが全く実行されない dogatana
  2017-09-04 12:13 ` [ruby-dev:50222] " usa
@ 2017-09-05  4:14 ` dogatana
  2017-09-05  7:37 ` [ruby-dev:50225] " usa
                   ` (4 subsequent siblings)
  7 siblings, 0 replies; 8+ messages in thread
From: dogatana @ 2017-09-05  4:14 UTC (permalink / raw)
  To: ruby-dev

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
<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>'
~~~

以前報告されている事例の別パターンのように思われます。






----------------------------------------
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
<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 側での対策が望ましいのではと思います。

いかがでしょうか。


市田



-- 
https://bugs.ruby-lang.org/

^ permalink raw reply	[flat|nested] 8+ messages in thread

* [ruby-dev:50225] [Ruby trunk Bug#13863] RUBYLIB にカレントディレクトリを設定した場合、-E cp932:utf-8 を指定するとスクリプトが全く実行されない
       [not found] <redmine.issue-13863.20170904105927@ruby-lang.org>
                   ` (2 preceding siblings ...)
  2017-09-05  4:14 ` [ruby-dev:50224] " dogatana
@ 2017-09-05  7:37 ` usa
  2017-09-05 11:51 ` [ruby-dev:50228] " dogatana
                   ` (3 subsequent siblings)
  7 siblings, 0 replies; 8+ messages in thread
From: usa @ 2017-09-05  7:37 UTC (permalink / raw)
  To: ruby-dev

Issue #13863 has been updated by usa (Usaku NAKAMURA).

Backport changed from 2.2: UNKNOWN, 2.3: UNKNOWN, 2.4: UNKNOWN to 2.2: WONTFIX, 2.3: REQUIRED, 2.4: REQUIRED

あー、再現しました。ありがとうございます。

> カレントディレクトに日本語を含む

これがすっぽ抜けてました。

あとは、`RUBYLIB` の場合だけで、`-I` などでは問題ないようですね。なるほど。

----------------------------------------
Bug #13863: RUBYLIB にカレントディレクトリを設定した場合、-E cp932:utf-8 を指定するとスクリプトが全く実行されない
https://bugs.ruby-lang.org/issues/13863#change-66478

* 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: WONTFIX, 2.3: REQUIRED, 2.4: REQUIRED
----------------------------------------
こんにちは。

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 側での対策が望ましいのではと思います。

いかがでしょうか。


市田



-- 
https://bugs.ruby-lang.org/

^ permalink raw reply	[flat|nested] 8+ messages in thread

* [ruby-dev:50228] [Ruby trunk Bug#13863] RUBYLIB にカレントディレクトリを設定した場合、-E cp932:utf-8 を指定するとスクリプトが全く実行されない
       [not found] <redmine.issue-13863.20170904105927@ruby-lang.org>
                   ` (3 preceding siblings ...)
  2017-09-05  7:37 ` [ruby-dev:50225] " usa
@ 2017-09-05 11:51 ` dogatana
  2018-03-16 17:34 ` [ruby-dev:50500] " nagachika00
                   ` (2 subsequent siblings)
  7 siblings, 0 replies; 8+ messages in thread
From: dogatana @ 2017-09-05 11:51 UTC (permalink / raw)
  To: ruby-dev

Issue #13863 has been updated by dogatana (Toshihiko Ichida).


> あとは、RUBYLIB の場合だけで、-I などでは問題ないようですね。なるほど。

そうですね。
a2.rb で -I. を使用する場合だと、require が失敗するだけで、
いきなり終了する現象は出ません。

require が失敗するケースも対策されるとうれしいです。



----------------------------------------
Bug #13863: RUBYLIB にカレントディレクトリを設定した場合、-E cp932:utf-8 を指定するとスクリプトが全く実行されない
https://bugs.ruby-lang.org/issues/13863#change-66486

* 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: WONTFIX, 2.3: REQUIRED, 2.4: REQUIRED
----------------------------------------
こんにちは。

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 側での対策が望ましいのではと思います。

いかがでしょうか。


市田



-- 
https://bugs.ruby-lang.org/

^ permalink raw reply	[flat|nested] 8+ messages in thread

* [ruby-dev:50500] [Ruby trunk Bug#13863] RUBYLIB にカレントディレクトリを設定した場合、-E cp932:utf-8 を指定するとスクリプトが全く実行されない
       [not found] <redmine.issue-13863.20170904105927@ruby-lang.org>
                   ` (4 preceding siblings ...)
  2017-09-05 11:51 ` [ruby-dev:50228] " dogatana
@ 2018-03-16 17:34 ` nagachika00
  2018-03-17 14:24 ` [ruby-dev:50501] " nagachika00
  2018-03-18  3:58 ` [ruby-dev:50502] " nagachika00
  7 siblings, 0 replies; 8+ messages in thread
From: nagachika00 @ 2018-03-16 17:34 UTC (permalink / raw)
  To: ruby-dev

Issue #13863 has been updated by nagachika (Tomoyuki Chikanaga).

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.

----------------------------------------
Bug #13863: RUBYLIB にカレントディレクトリを設定した場合、-E cp932:utf-8 を指定するとスクリプトが全く実行されない
https://bugs.ruby-lang.org/issues/13863#change-71042

* Author: dogatana (Toshihiko Ichida)
* Status: Closed
* Priority: Normal
* Assignee: 
* Target version: 
* ruby -v: ruby 2.4.1p111 (2017-03-22 revision 58053) [i386-mingw32]
* Backport: 2.2: WONTFIX, 2.3: REQUIRED, 2.4: DONE
----------------------------------------
こんにちは。

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 側での対策が望ましいのではと思います。

いかがでしょうか。


市田



-- 
https://bugs.ruby-lang.org/

^ permalink raw reply	[flat|nested] 8+ messages in thread

* [ruby-dev:50501] [Ruby trunk Bug#13863] RUBYLIB にカレントディレクトリを設定した場合、-E cp932:utf-8 を指定するとスクリプトが全く実行されない
       [not found] <redmine.issue-13863.20170904105927@ruby-lang.org>
                   ` (5 preceding siblings ...)
  2018-03-16 17:34 ` [ruby-dev:50500] " nagachika00
@ 2018-03-17 14:24 ` nagachika00
  2018-03-18  3:58 ` [ruby-dev:50502] " nagachika00
  7 siblings, 0 replies; 8+ messages in thread
From: nagachika00 @ 2018-03-17 14:24 UTC (permalink / raw)
  To: ruby-dev

Issue #13863 has been updated by nagachika (Tomoyuki Chikanaga).


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

----------------------------------------
Bug #13863: RUBYLIB にカレントディレクトリを設定した場合、-E cp932:utf-8 を指定するとスクリプトが全く実行されない
https://bugs.ruby-lang.org/issues/13863#change-71053

* Author: dogatana (Toshihiko Ichida)
* Status: Closed
* Priority: Normal
* Assignee: 
* Target version: 
* ruby -v: ruby 2.4.1p111 (2017-03-22 revision 58053) [i386-mingw32]
* Backport: 2.2: WONTFIX, 2.3: REQUIRED, 2.4: DONE
----------------------------------------
こんにちは。

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 側での対策が望ましいのではと思います。

いかがでしょうか。


市田



-- 
https://bugs.ruby-lang.org/

^ permalink raw reply	[flat|nested] 8+ messages in thread

* [ruby-dev:50502] [Ruby trunk Bug#13863] RUBYLIB にカレントディレクトリを設定した場合、-E cp932:utf-8 を指定するとスクリプトが全く実行されない
       [not found] <redmine.issue-13863.20170904105927@ruby-lang.org>
                   ` (6 preceding siblings ...)
  2018-03-17 14:24 ` [ruby-dev:50501] " nagachika00
@ 2018-03-18  3:58 ` nagachika00
  7 siblings, 0 replies; 8+ messages in thread
From: nagachika00 @ 2018-03-18  3:58 UTC (permalink / raw)
  To: ruby-dev

Issue #13863 has been updated by nagachika (Tomoyuki Chikanaga).

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 しました。

----------------------------------------
Bug #13863: RUBYLIB にカレントディレクトリを設定した場合、-E cp932:utf-8 を指定するとスクリプトが全く実行されない
https://bugs.ruby-lang.org/issues/13863#change-71056

* Author: dogatana (Toshihiko Ichida)
* Status: Closed
* Priority: Normal
* Assignee: 
* Target version: 
* ruby -v: ruby 2.4.1p111 (2017-03-22 revision 58053) [i386-mingw32]
* Backport: 2.2: WONTFIX, 2.3: REQUIRED, 2.4: REQUIRED
----------------------------------------
こんにちは。

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 側での対策が望ましいのではと思います。

いかがでしょうか。


市田



-- 
https://bugs.ruby-lang.org/

^ permalink raw reply	[flat|nested] 8+ messages in thread

end of thread, other threads:[~2018-03-18  3:58 UTC | newest]

Thread overview: 8+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
     [not found] <redmine.issue-13863.20170904105927@ruby-lang.org>
2017-09-04 10:59 ` [ruby-dev:50221] [Ruby trunk Bug#13863] RUBYLIB にカレントディレクトリを設定した場合、-E cp932:utf-8 を指定するとスクリプトが全く実行されない dogatana
2017-09-04 12:13 ` [ruby-dev:50222] " usa
2017-09-05  4:14 ` [ruby-dev:50224] " dogatana
2017-09-05  7:37 ` [ruby-dev:50225] " usa
2017-09-05 11:51 ` [ruby-dev:50228] " dogatana
2018-03-16 17:34 ` [ruby-dev:50500] " nagachika00
2018-03-17 14:24 ` [ruby-dev:50501] " nagachika00
2018-03-18  3:58 ` [ruby-dev:50502] " nagachika00

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).