From 21704f2269093ff8b80f32e07a1cb6ad4d8f6896 Mon Sep 17 00:00:00 2001 From: kosaki Date: Sun, 18 Oct 2015 00:33:44 +0000 Subject: [PATCH] * file.c (ruby_is_fd_loadable): this should be fail if st_mode is not regular file nor FIFO. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@52158 b2dd03c8-39d4-4d8f-98ff-823fe69b080e --- ChangeLog | 5 +++++ file.c | 10 +++++++--- 2 files changed, 12 insertions(+), 3 deletions(-) diff --git a/ChangeLog b/ChangeLog index 46ab1fcede..5e9ae54bc7 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,3 +1,8 @@ +Sun Oct 18 09:32:58 2015 KOSAKI Motohiro + + * file.c (ruby_is_fd_loadable): this should be fail if st_mode is + not regular file nor FIFO. + Sun Oct 18 09:20:17 2015 KOSAKI Motohiro * ruby.c (open_load_file): use rb_thread_wait_fd() instead of reopen. diff --git a/file.c b/file.c index b2ad989df6..784b003274 100644 --- a/file.c +++ b/file.c @@ -5680,13 +5680,17 @@ ruby_is_fd_loadable(int fd) if (fstat(fd, &st) < 0) return 0; - if (S_ISREG(st.st_mode)) return 1; - if (!S_ISDIR(st.st_mode)) + + if (S_ISFIFO(st.st_mode)) return 1; - errno = EISDIR; + if (S_ISDIR(st.st_mode)) + errno = EISDIR; + else + errno = ENXIO; + return 0; #endif }