summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorakr <akr@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2008-07-20 19:57:56 +0000
committerakr <akr@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2008-07-20 19:57:56 +0000
commit45d03ec20af23e0569c89f34c7f11b3839edc84b (patch)
treea78ba40835820f65c4a1489fed997f20363fcbd7
parent3c77d94be5b24a4d8946b672b838d797ff5fe192 (diff)
downloadruby-45d03ec20af23e0569c89f34c7f11b3839edc84b.tar.gz
ruby-45d03ec20af23e0569c89f34c7f11b3839edc84b.tar.xz
ruby-45d03ec20af23e0569c89f34c7f11b3839edc84b.zip
* dir.c (dir_initialize): use rb_convert_type instead of
rb_check_convert_type to prevent SEGV by Dir.new(".", true). (dir_initialize): use FilePathValue before rb_enc_get(dirname) to prevent SEGV by Dir.new(0). git-svn-id: http://svn.ruby-lang.org/repos/ruby/trunk@18139 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
-rw-r--r--ChangeLog7
-rw-r--r--dir.c4
2 files changed, 9 insertions, 2 deletions
diff --git a/ChangeLog b/ChangeLog
index a9f927239..3918ad5b4 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,10 @@
+Mon Jul 21 04:55:20 2008 Tanaka Akira <akr@fsij.org>
+
+ * dir.c (dir_initialize): use rb_convert_type instead of
+ rb_check_convert_type to prevent SEGV by Dir.new(".", true).
+ (dir_initialize): use FilePathValue before rb_enc_get(dirname) to
+ prevent SEGV by Dir.new(0).
+
Mon Jul 21 04:42:15 2008 Tanaka Akira <akr@fsij.org>
* re.c (rb_reg_s_union): useless rb_enc_get call removed to prevent
diff --git a/dir.c b/dir.c
index cf278dc4a..465f97c79 100644
--- a/dir.c
+++ b/dir.c
@@ -348,7 +348,7 @@ dir_initialize(int argc, VALUE *argv, VALUE dir)
if (!NIL_P(opt)) {
VALUE v, extenc=Qnil, intenc=Qnil;
- opt = rb_check_convert_type(opt, T_HASH, "Hash", "to_hash");
+ opt = rb_convert_type(opt, T_HASH, "Hash", "to_hash");
v = rb_hash_aref(opt, sym_intenc);
if (!NIL_P(v)) intenc = v;
@@ -372,6 +372,7 @@ dir_initialize(int argc, VALUE *argv, VALUE dir)
}
}
+ FilePathValue(dirname);
{
rb_encoding *dirname_encoding = rb_enc_get(dirname);
if (rb_usascii_encoding() != dirname_encoding
@@ -384,7 +385,6 @@ dir_initialize(int argc, VALUE *argv, VALUE dir)
dirname = rb_str_transcode(dirname, rb_enc_from_encoding(extencoding));
}
}
- FilePathValue(dirname);
Data_Get_Struct(dir, struct dir_data, dp);
if (dp->dir) closedir(dp->dir);