summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authornobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2005-11-06 11:18:57 +0000
committernobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2005-11-06 11:18:57 +0000
commit6609fbb02b6d5f006860011b23f6d1154d0f35c3 (patch)
tree2683f9662256f7d9cb72c94282b2599fdbff4bf3
parent06980f4807e6970b919efb914c3070a3df90af4f (diff)
* file.c (rb_file_s_readlink): readlink(2) on AIX fails with ERANGE if
buffer size is less than required. fixed: [ruby-dev:27634] git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/branches/ruby_1_8@9505 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
-rw-r--r--ChangeLog9
-rw-r--r--file.c8
2 files changed, 14 insertions, 3 deletions
diff --git a/ChangeLog b/ChangeLog
index 489b08eac0..b00bbac01b 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,8 @@
+Sun Nov 6 20:13:27 2005 Nobuyoshi Nakada <nobu@ruby-lang.org>
+
+ * file.c (rb_file_s_readlink): readlink(2) on AIX fails with ERANGE if
+ buffer size is less than required. fixed: [ruby-dev:27634]
+
Wed Nov 2 20:25:28 2005 Hidetoshi NAGAI <nagai@ai.kyutech.ac.jp>
* ext/tk/extconf.rb: ext/tk/extconf.rb: change the check parameter
@@ -9,7 +14,7 @@ Wed Nov 2 20:14:53 2005 Hidetoshi NAGAI <nagai@ai.kyutech.ac.jp>
Wed Nov 2 19:03:06 2005 Hidetoshi NAGAI <nagai@ai.kyutech.ac.jp>
- * ext/tcltklib/tcltklib.c (ip_rbUpdateObjCmd,
+ * ext/tcltklib/tcltklib.c (ip_rbUpdateObjCmd,
ip_rb_threadUpdateObjCmd): passed improper flags to DoOneEvent().
* ext/tk/tkutil.c: use rb_obj_respond_to() instead of rb_respond_to().
@@ -61,7 +66,7 @@ Mon Oct 31 05:37:20 2005 GOTOU Yuuzou <gotoyuzo@notwork.org>
Mon Oct 31 03:19:36 2005 Yukihiro Matsumoto <matz@ruby-lang.org>
* ext/readline/readline.c (readline_readline): type check.
- [ruby-core:6089]
+ [ruby-core:6089]
* numeric.c (fix_rshift): RDoc fix. [ruby-core:6351]
diff --git a/file.c b/file.c
index 2e465e2d89..898c8009aa 100644
--- a/file.c
+++ b/file.c
@@ -2019,7 +2019,13 @@ rb_file_s_readlink(klass, path)
SafeStringValue(path);
buf = xmalloc(size);
- while ((rv = readlink(StringValueCStr(path), buf, size)) == size) {
+ for (;;) {
+ rv = readlink(RSTRING(path)->ptr, buf, size);
+#ifndef _AIX
+ if (rv != size) break;
+#else
+ if (rv > 0 || errno != ERANGE) break;
+#endif
size *= 2;
buf = xrealloc(buf, size);
}