diff options
author | ko1 <ko1@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2007-11-09 01:10:06 +0000 |
---|---|---|
committer | ko1 <ko1@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2007-11-09 01:10:06 +0000 |
commit | 0303c1d42b0dc8c8dfe96b885adb7f7ab9098e85 (patch) | |
tree | c16ed123e1e67f0f2c92546fbac44264d9d6267f | |
parent | 9099eab331f91a2c26c6722535193185e40e9296 (diff) | |
download | ruby-0303c1d42b0dc8c8dfe96b885adb7f7ab9098e85.tar.gz |
* ruby.c (set_arg0): fix breaking environ bugs.
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@13842 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
-rw-r--r-- | ChangeLog | 4 | ||||
-rw-r--r-- | ruby.c | 15 |
2 files changed, 13 insertions, 6 deletions
@@ -1,3 +1,7 @@ +Fri Nov 9 10:05:54 2007 Koichi Sasada <ko1@atdot.net> + + * ruby.c (set_arg0): fix breaking environ bugs. + Fri Nov 9 07:26:04 2007 Yukihiro Matsumoto <matz@ruby-lang.org> * random.c: update MT URL.[ruby-core:13305]. @@ -1173,7 +1173,7 @@ get_arglen(int argc, char **argv) static void set_arg0(VALUE val, ID id) { - char *s; + char *s, *t; long i; if (origarg.argv == 0) @@ -1204,13 +1204,16 @@ set_arg0(VALUE val, ID id) } memcpy(origarg.argv[0], s, i); - s = origarg.argv[0] + i; - *s = '\0'; - if (i + 1 < origarg.len) memset(s + 1, ' ', origarg.len - i - 1); + t = origarg.argv[0] + i; + *t = '\0'; + + if (i + 1 < origarg.len) memset(t + 1, ' ', origarg.len - i - 1); + { int j; - for (j = 1; j < origarg.argc; j++) - origarg.argv[i] = s; + for (j = 1; j < origarg.argc; j++) { + origarg.argv[j] = t; + } } #endif rb_progname = rb_tainted_str_new(s, i); |