X-Git-Url: https://mattmccutchen.net/rsync/rsync.git/blobdiff_plain/24c906d3f7f4db31884d4262ddf9824d91ff4a76..71020fc3aafc1cea58188b261b0f9f5b0c29b5f8:/getgroups.c diff --git a/getgroups.c b/getgroups.c index 78e2a88f..8bb82f5d 100644 --- a/getgroups.c +++ b/getgroups.c @@ -26,23 +26,36 @@ #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 +main(UNUSED(int argc), UNUSED(char *argv[])) { int n, i; - gid_t list[NGROUPS]; + gid_t list[NGROUPS_MAX]; + gid_t gid = MY_GID(); + int gid_in_list = 0; - if ((n = getgroups(NGROUPS, list)) == -1) { +#ifdef HAVE_GETGROUPS + if ((n = getgroups(NGROUPS_MAX, list)) < 0) { perror("getgroups"); return 1; } +#else + n = 0; +#endif - for (i = 0; i < n; i++) - printf("%u ", list[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;