- write_int(f, sum->count);
- write_int(f, sum->blength);
- if (remote_version >= 27)
- write_int(f, sum->s2length);
- write_int(f, sum->remainder);
+void itemize(struct file_struct *file, int ndx, int statret, STRUCT_STAT *st,
+ int32 iflags, char *hlink)
+{
+ if (statret == 0) {
+ if (S_ISREG(file->mode) && file->length != st->st_size)
+ iflags |= ITEM_REPORT_SIZE;
+ if (!(iflags & ITEM_NO_DEST_AND_NO_UPDATE)) {
+ int keep_time = !preserve_times ? 0
+ : S_ISDIR(file->mode) ? !omit_dir_times
+ : !S_ISLNK(file->mode);
+
+ if ((iflags & (ITEM_TRANSFER|ITEM_LOCAL_CHANGE) && !keep_time)
+ || (keep_time && file->modtime != st->st_mtime))
+ iflags |= ITEM_REPORT_TIME;
+ if (preserve_perms && file->mode != st->st_mode)
+ iflags |= ITEM_REPORT_PERMS;
+ if (preserve_uid && am_root && file->uid != st->st_uid)
+ iflags |= ITEM_REPORT_OWNER;
+ if (preserve_gid && file->gid != GID_NONE
+ && st->st_gid != file->gid)
+ iflags |= ITEM_REPORT_GROUP;
+ }
+ } else {
+ iflags |= ITEM_IS_NEW;
+ if (!(iflags & (ITEM_HARD_LINKED|ITEM_LOCAL_CHANGE)))
+ iflags |= ITEM_TRANSFER;
+ }
+
+ iflags &= 0xffff;
+ if ((iflags & SIGNIFICANT_ITEM_FLAGS || verbose > 1
+ || (hlink && *hlink)) && !read_batch) {
+ if (protocol_version >= 29) {
+ if (ndx >= 0)
+ write_int(sock_f_out, ndx);
+ write_shortint(sock_f_out, iflags);
+ if (hlink)
+ write_vstring(sock_f_out, hlink, strlen(hlink));
+ } else if (ndx >= 0)
+ log_item(file, &stats, iflags, hlink);
+ }