+
+ last_mode = file->mode;
+ last_dev = file->dev;
+ last_uid = file->uid;
+ last_gid = file->gid;
+ p = strrchr(file->name,'/');
+ if (p) {
+ int l = (int)(p - file->name) + 1;
+ strncpy(lastdir,file->name,l);
+ lastdir[l] = 0;
+ } else {
+ strcpy(lastdir,"");
+ }
+}
+
+
+
+static void receive_file_entry(struct file_struct *file,
+ unsigned char flags,int f)
+{
+ static mode_t last_mode=0;
+ static dev_t last_dev=0;
+ static uid_t last_uid=0;
+ static gid_t last_gid=0;
+ static char lastdir[MAXPATHLEN]="";
+ char *p=NULL;
+ int l1,l2;
+
+ l1 = read_byte(f);
+ if (flags & SAME_DIR)
+ l2 = strlen(lastdir);
+ else
+ l2 = 0;
+
+ file->name = (char *)malloc(l1+l2+1);
+ if (!file->name) out_of_memory("receive_file_entry");
+
+ strncpy(file->name,lastdir,l2);
+ read_buf(f,file->name+l2,l1);
+ file->name[l1+l2] = 0;
+
+ file->modtime = (time_t)read_int(f);
+ file->length = (off_t)read_int(f);
+ file->mode = (flags & SAME_MODE) ? last_mode : (mode_t)read_int(f);
+ if (preserve_uid)
+ file->uid = (flags & SAME_UID) ? last_uid : (uid_t)read_int(f);
+ if (preserve_gid)
+ file->gid = (flags & SAME_GID) ? last_gid : (gid_t)read_int(f);
+ if (preserve_devices && IS_DEVICE(file->mode))
+ file->dev = (flags & SAME_DEV) ? last_dev : (dev_t)read_int(f);
+
+#if SUPPORT_LINKS
+ if (preserve_links && S_ISLNK(file->mode)) {
+ int l = read_int(f);
+ file->link = (char *)malloc(l+1);
+ if (!file->link) out_of_memory("receive_file_entry");
+ read_buf(f,file->link,l);
+ file->link[l] = 0;
+ }
+#endif
+
+ if (always_checksum)
+ read_buf(f,file->sum,SUM_LENGTH);
+
+ last_mode = file->mode;
+ last_dev = file->dev;
+ last_uid = file->uid;
+ last_gid = file->gid;
+ p = strrchr(file->name,'/');
+ if (p) {
+ int l = (int)(p - file->name) + 1;
+ strncpy(lastdir,file->name,l);
+ lastdir[l] = 0;
+ } else {
+ strcpy(lastdir,"");
+ }