When comparing -1 to a group id, cast -1 with gid_t because on some systems
authorDavid Dykstra <dwd@samba.org>
Mon, 1 Mar 1999 21:16:49 +0000 (21:16 +0000)
committerDavid Dykstra <dwd@samba.org>
Mon, 1 Mar 1999 21:16:49 +0000 (21:16 +0000)
such as sunos4 gid_t is an unsigned short.  This prevented the just-added
non-mapped group test from working on sunos4.

rsync.c
uidlist.c

diff --git a/rsync.c b/rsync.c
index ceabfda..178dc52 100644 (file)
--- a/rsync.c
+++ b/rsync.c
@@ -180,8 +180,8 @@ int set_perms(char *fname,struct file_struct *file,STRUCT_STAT *st,
        }
 
        change_uid = am_root && preserve_uid && st->st_uid != file->uid;
-       change_gid = !am_daemon && preserve_gid && file->gid != -1 \
-                               && st->st_gid != file->gid;
+       change_gid = !am_daemon && preserve_gid && file->gid != (gid_t) -1 && \
+                               st->st_gid != file->gid;
        if (change_gid && !am_root) {
                /* enforce bsd-style group semantics: non-root can only
                    change to groups that the user is a member of */
index e4b61b8..14611a5 100644 (file)
--- a/uidlist.c
+++ b/uidlist.c
@@ -126,7 +126,7 @@ static gid_t match_gid(gid_t gid)
        if (am_root)
                last_out = gid;
        else
-               last_out = -1;
+               last_out = (gid_t) -1;
        return last_out;
 }