From 54281916e9623b132b6745bdc9ee9a397eff7398 Mon Sep 17 00:00:00 2001 From: nagachika Date: Sat, 9 Mar 2013 12:26:17 +0000 Subject: [PATCH] merge revision(s) 39353: [Backport #8057] * file.c (rb_group_member): added an error check. SUS says, getgroups(small_value) may return EINVAL. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/branches/ruby_2_0_0@39653 b2dd03c8-39d4-4d8f-98ff-823fe69b080e --- ChangeLog | 5 +++++ file.c | 4 +++- version.h | 2 +- 3 files changed, 9 insertions(+), 2 deletions(-) diff --git a/ChangeLog b/ChangeLog index 9f95e3bc27..afc94179bb 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,3 +1,8 @@ +Sat Mar 9 21:25:45 2013 KOSAKI Motohiro + + * file.c (rb_group_member): added an error check. SUS says, + getgroups(small_value) may return EINVAL. + Sat Mar 9 21:23:36 2013 KOSAKI Motohiro * process.c (RB_MAX_GROUPS): moved to diff --git a/file.c b/file.c index 7d53f8d98f..44c019d7ae 100644 --- a/file.c +++ b/file.c @@ -1036,7 +1036,7 @@ rb_group_member(GETGROUPS_T gid) while (groups <= RB_MAX_GROUPS) { gary = ALLOCV_N(GETGROUPS_T, v, groups); anum = getgroups(groups, gary); - if (anum != groups) + if (anum != -1 && anum != groups) break; groups *= 2; if (v) { @@ -1044,6 +1044,8 @@ rb_group_member(GETGROUPS_T gid) v = 0; } } + if (anum == -1) + return FALSE; while (--anum >= 0) { if (gary[anum] == gid) { diff --git a/version.h b/version.h index b97bf507c0..cd112921ff 100644 --- a/version.h +++ b/version.h @@ -1,6 +1,6 @@ #define RUBY_VERSION "2.0.0" #define RUBY_RELEASE_DATE "2013-03-09" -#define RUBY_PATCHLEVEL 22 +#define RUBY_PATCHLEVEL 23 #define RUBY_RELEASE_YEAR 2013 #define RUBY_RELEASE_MONTH 3