summaryrefslogtreecommitdiff
path: root/process.c
diff options
context:
space:
mode:
authoryugui <yugui@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2011-05-11 21:23:31 +0000
committeryugui <yugui@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2011-05-11 21:23:31 +0000
commitfbb6e25a4dd755586fdb213c584d33e0e5bd35e6 (patch)
tree1f2917b1b20ef41f70b504cfbc0fcde3ab778206 /process.c
parent8c7f9f5cdd0ade7442d4e341093ecf1b8e2f4690 (diff)
merges r30820 from trunk into ruby_1_9_2.
-- * process.c (proc_setgroups): add GC guard to prevent intermediate variable from GC. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/branches/ruby_1_9_2@31512 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'process.c')
-rw-r--r--process.c4
1 files changed, 3 insertions, 1 deletions
diff --git a/process.c b/process.c
index e8830504ff..c1804922e1 100644
--- a/process.c
+++ b/process.c
@@ -4464,9 +4464,11 @@ proc_setgroups(VALUE obj, VALUE ary)
}
else {
gr = getgrnam(RSTRING_PTR(tmp));
- if (gr == NULL)
+ if (gr == NULL) {
+ RB_GC_GUARD(tmp);
rb_raise(rb_eArgError,
"can't find group for %s", RSTRING_PTR(tmp));
+ }
groups[i] = gr->gr_gid;
}
}