ruby-dev (Japanese) list archive (unofficial mirror)
 help / color / mirror / Atom feed
* [ruby-dev:51086] [Ruby master Bug#18052] Find のignore_error オプションが、文字化けファイル遭遇時の例外に対応していない  (Windows)
@ 2021-07-29 13:55 dexmerry-mx
  2021-07-29 16:48 ` [ruby-dev:51087] " merch-redmine
  0 siblings, 1 reply; 2+ messages in thread
From: dexmerry-mx @ 2021-07-29 13:55 UTC (permalink / raw)
  To: ruby-dev

Issue #18052 has been reported by araragi (Nagisawa Minoru).

----------------------------------------
Bug #18052: Find のignore_error オプションが、文字化けファイル遭遇時の例外に対応していない (Windows)
https://bugs.ruby-lang.org/issues/18052

* Author: araragi (Nagisawa Minoru)
* Status: Open
* Priority: Normal
* ruby -v: ruby 2.6.6p146 (2020-03-31 revision 67876) [x64-mingw32]
* Backport: 2.6: UNKNOWN, 2.7: UNKNOWN, 3.0: UNKNOWN
----------------------------------------

Find.find(".", ignore_error: true ) を指定しても、文字化けするファイルに出会った場合には、
ignore せずに例外を起こしてしまうようです。

https://docs.ruby-lang.org/ja/latest/class/Find.html

# Background

C:\>ver
Microsoft Windows [Version 10.0.19043.1110]

C:\ruby -v
ruby 2.6.6p146 (2020-03-31 revision 67876) [x64-mingw32]

# Input 

	# coding:cp932
	p __ENCODING__

	# cp932 では表現できないファイル名を作る(例はハングル文字)。
	open("testfile-\uD7A3 .jpg", "w")

	require "find"
	Find.find(".", ignore_error: true ) {|f|
		p f
	}

# Output 

	#<Encoding:Windows-31J>
	"."
	"./testfile-???R?s?[.jpg"
	Traceback (most recent call last):
			25: from d:/opt/ruby/bin/irb:23:in `<main>'
			24: from d:/opt/ruby/bin/irb:23:in `load'
			23: from d:/opt/ruby/lib/ruby/gems/2.6.0/gems/irb-1.3.2/exe/irb:11:in `<top (required)>'
			6: from (irb):10:in `<main>'
			5: from d:/opt/ruby/lib/ruby/2.6.0/find.rb:43:in `find'
			4: from d:/opt/ruby/lib/ruby/2.6.0/find.rb:43:in `each'
			3: from d:/opt/ruby/lib/ruby/2.6.0/find.rb:48:in `block in find'
			2: from d:/opt/ruby/lib/ruby/2.6.0/find.rb:48:in `catch'
			1: from d:/opt/ruby/lib/ruby/2.6.0/find.rb:51:in `block (2 levels) in find'
	d:/opt/ruby/lib/ruby/2.6.0/find.rb:51:in `lstat': Invalid argument @ rb_file_s_lstat - ./testfile-?[.jpg (Errno::EINVAL)

# Assessment 

lib/ruby/3.0.0/find.rb:51 では以下となっていますが、

       begin
            s = File.lstat(file)
          rescue Errno::ENOENT, Errno::EACCES, Errno::ENOTDIR, Errno::ELOOP, Errno::ENAMETOOLONG
            raise unless ignore_error
            next
          end

文字化けしたファイルに遭遇した場合には、Errno::EINVAL が発生するのですが、それを考慮して ignore できていないように思われます。




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

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

* [ruby-dev:51087] [Ruby master Bug#18052] Find のignore_error オプションが、文字化けファイル遭遇時の例外に対応していない  (Windows)
  2021-07-29 13:55 [ruby-dev:51086] [Ruby master Bug#18052] Find のignore_error オプションが、文字化けファイル遭遇時の例外に対応していない (Windows) dexmerry-mx
@ 2021-07-29 16:48 ` merch-redmine
  0 siblings, 0 replies; 2+ messages in thread
From: merch-redmine @ 2021-07-29 16:48 UTC (permalink / raw)
  To: ruby-dev

Issue #18052 has been updated by jeremyevans0 (Jeremy Evans).

Status changed from Open to Closed

This was fixed in commit:230111802c2b9dcb8f391b489ff52a9dc0b41b87.

----------------------------------------
Bug #18052: Find のignore_error オプションが、文字化けファイル遭遇時の例外に対応していない (Windows)
https://bugs.ruby-lang.org/issues/18052#change-93054

* Author: araragi (Nagisawa Minoru)
* Status: Closed
* Priority: Normal
* ruby -v: ruby 2.6.6p146 (2020-03-31 revision 67876) [x64-mingw32]
* Backport: 2.6: UNKNOWN, 2.7: UNKNOWN, 3.0: UNKNOWN
----------------------------------------

Find.find(".", ignore_error: true ) を指定しても、文字化けするファイルに出会った場合には、
ignore せずに例外を起こしてしまうようです。

https://docs.ruby-lang.org/ja/latest/class/Find.html

# Background

C:\>ver
Microsoft Windows [Version 10.0.19043.1110]

C:\ruby -v
ruby 2.6.6p146 (2020-03-31 revision 67876) [x64-mingw32]

# Input 

	# coding:cp932
	p __ENCODING__

	# cp932 では表現できないファイル名を作る(例はハングル文字)。
	open("testfile-\uD7A3 .jpg", "w")

	require "find"
	Find.find(".", ignore_error: true ) {|f|
		p f
	}

# Output 

	#<Encoding:Windows-31J>
	"."
	"./testfile-???R?s?[.jpg"
	Traceback (most recent call last):
			25: from d:/opt/ruby/bin/irb:23:in `<main>'
			24: from d:/opt/ruby/bin/irb:23:in `load'
			23: from d:/opt/ruby/lib/ruby/gems/2.6.0/gems/irb-1.3.2/exe/irb:11:in `<top (required)>'
			6: from (irb):10:in `<main>'
			5: from d:/opt/ruby/lib/ruby/2.6.0/find.rb:43:in `find'
			4: from d:/opt/ruby/lib/ruby/2.6.0/find.rb:43:in `each'
			3: from d:/opt/ruby/lib/ruby/2.6.0/find.rb:48:in `block in find'
			2: from d:/opt/ruby/lib/ruby/2.6.0/find.rb:48:in `catch'
			1: from d:/opt/ruby/lib/ruby/2.6.0/find.rb:51:in `block (2 levels) in find'
	d:/opt/ruby/lib/ruby/2.6.0/find.rb:51:in `lstat': Invalid argument @ rb_file_s_lstat - ./testfile-?[.jpg (Errno::EINVAL)

# Assessment 

lib/ruby/3.0.0/find.rb:51 では以下となっていますが、

       begin
            s = File.lstat(file)
          rescue Errno::ENOENT, Errno::EACCES, Errno::ENOTDIR, Errno::ELOOP, Errno::ENAMETOOLONG
            raise unless ignore_error
            next
          end

文字化けしたファイルに遭遇した場合には、Errno::EINVAL が発生するのですが、それを考慮して ignore できていないように思われます。




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

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

end of thread, other threads:[~2021-07-29 16:48 UTC | newest]

Thread overview: 2+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2021-07-29 13:55 [ruby-dev:51086] [Ruby master Bug#18052] Find のignore_error オプションが、文字化けファイル遭遇時の例外に対応していない (Windows) dexmerry-mx
2021-07-29 16:48 ` [ruby-dev:51087] " merch-redmine

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 NNTP newsgroup(s).