From 58743a87b8a6b8160c6bd562ed4dd8dcfcb2d4e2 Mon Sep 17 00:00:00 2001 From: Wayne Davison Date: Thu, 22 Jan 2004 09:13:36 +0000 Subject: [PATCH] Improved to add the default gid if it is missing from the list. --- getgroups.c | 18 +++++++++++++----- 1 file changed, 13 insertions(+), 5 deletions(-) diff --git a/getgroups.c b/getgroups.c index 3aa152fc..4a10fe7d 100644 --- a/getgroups.c +++ b/getgroups.c @@ -26,24 +26,32 @@ #include "rsync.h" -#ifndef NGROUPS +#ifndef NGROUPS_MAX /* It ought to be defined, but just in case. */ -# define NGROUPS 32 +# define NGROUPS_MAX 32 #endif int main(UNUSED(int argc), UNUSED(char *argv[])) { int n, i; - gid_t list[NGROUPS]; + gid_t list[NGROUPS_MAX]; + gid_t gid = getgid(); + int gid_in_list = 0; - if ((n = getgroups(NGROUPS, list)) == -1) { + if ((n = getgroups(NGROUPS_MAX, list)) < 0) { perror("getgroups"); return 1; } - for (i = 0; i < n; i++) + for (i = 0; i < n; i++) { printf("%lu ", (unsigned long)list[i]); + if (list[i] == gid) + gid_in_list = 1; + } + /* The default gid might not be in the list on some systems. */ + if (!gid_in_list) + printf("%lu", (unsigned long)gid); printf("\n"); return 0; -- 2.34.1