extern int cvs_exclude;
+extern int recurse;
+
extern int one_file_system;
extern int make_backups;
extern int preserve_links;
extern int preserve_uid;
extern int preserve_gid;
extern int preserve_times;
+extern int relative_paths;
static char **local_exclude_list = NULL;
if (l1 > 0) flags |= SAME_NAME;
if (l2 > 255) flags |= LONG_NAME;
-
+
write_byte(f,flags);
if (flags & SAME_NAME)
write_byte(f,l1);
last_gid = file->gid;
last_time = file->modtime;
- strcpy(lastname,file->name);
- lastname[255] = 0;
+ strncpy(lastname,file->name,MAXPATHLEN-1);
+ lastname[MAXPATHLEN-1] = 0;
}
void receive_file_entry_v11(struct file_struct *file,
unsigned char flags,int f)
{
- static mode_t last_time=0;
+ static time_t last_time=0;
static mode_t last_mode=0;
static dev_t last_rdev=0;
static uid_t last_uid=0;
last_gid = file->gid;
last_time = file->modtime;
- strcpy(lastname,file->name);
- lastname[255] = 0;
+ strncpy(lastname,file->name,MAXPATHLEN-1);
+ lastname[MAXPATHLEN-1] = 0;
}
-static struct file_struct *make_file(int recurse,char *fname)
+static struct file_struct *make_file(char *fname)
{
static struct file_struct file;
struct stat st;
-static void send_file_name(int f,struct file_list *flist,
- int recurse,char *fname)
+static void send_file_name(int f,struct file_list *flist,char *fname)
{
struct file_struct *file;
- file = make_file(recurse,fname);
+ file = make_file(fname);
if (!file) return;
if (flist->count >= flist->malloced) {
- flist->malloced += 100;
- flist->files = (struct file_struct *)realloc(flist->files,
- sizeof(flist->files[0])*
- flist->malloced);
- if (!flist->files)
- out_of_memory("send_file_name");
+ if (flist->malloced < 100)
+ flist->malloced += 100;
+ else
+ flist->malloced *= 1.8;
+ flist->files = (struct file_struct *)realloc(flist->files,
+ sizeof(flist->files[0])*
+ flist->malloced);
+ if (!flist->files)
+ out_of_memory("send_file_name");
}
- if (strcmp(file->name,".") && strcmp(file->name,"/")) {
+ if (strcmp(file->name,"/")) {
flist->files[flist->count++] = *file;
send_file_entry(file,f);
}
return;
}
- strcpy(fname,dir);
+ strncpy(fname,dir,MAXPATHLEN-1);
+ fname[MAXPATHLEN-1]=0;
l = strlen(fname);
if (fname[l-1] != '/')
strcat(fname,"/");
if (strcmp(di->d_name,".")==0 ||
strcmp(di->d_name,"..")==0)
continue;
- strcpy(p,di->d_name);
- send_file_name(f,flist,1,fname);
+ strncpy(p,di->d_name,MAXPATHLEN-l);
+ send_file_name(f,flist,fname);
}
closedir(d);
-struct file_list *send_file_list(int f,int recurse,int argc,char *argv[])
+struct file_list *send_file_list(int f,int argc,char *argv[])
{
int i,l;
struct stat st;
char dbuf[MAXPATHLEN];
struct file_list *flist;
- if (verbose && recurse) {
+ if (verbose && recurse && !am_server) {
fprintf(FINFO,"building file list ... ");
fflush(FINFO);
}
char fname2[MAXPATHLEN];
char *fname = fname2;
- strcpy(fname,argv[i]);
+ strncpy(fname,argv[i],MAXPATHLEN-1);
+ fname[MAXPATHLEN-1] = 0;
l = strlen(fname);
if (l != 1 && fname[l-1] == '/') {
}
dir = NULL;
- p = strrchr(fname,'/');
- if (p) {
- *p = 0;
- dir = fname;
- fname = p+1;
+
+ if (!relative_paths) {
+ p = strrchr(fname,'/');
+ if (p) {
+ *p = 0;
+ if (p == fname)
+ dir = "/";
+ else
+ dir = fname;
+ fname = p+1;
+ }
}
+
if (!*fname)
fname = ".";
flist_dir = dir;
if (one_file_system)
set_filesystem(fname);
- send_file_name(f,flist,recurse,fname);
+ send_file_name(f,flist,fname);
flist_dir = NULL;
if (chdir(dbuf) != 0) {
fprintf(FERROR,"chdir %s : %s\n",dbuf,strerror(errno));
if (one_file_system)
set_filesystem(fname);
- send_file_name(f,flist,recurse,fname);
+ send_file_name(f,flist,fname);
}
if (f != -1) {
write_flush(f);
}
- if (verbose && recurse)
+ if (verbose && recurse && !am_server)
fprintf(FINFO,"done\n");
clean_flist(flist);
struct file_list *flist;
unsigned char flags;
- if (verbose > 2)
- fprintf(FERROR,"recv_file_list starting\n");
+ if (verbose && recurse && !am_server) {
+ fprintf(FINFO,"receiving file list ... ");
+ fflush(FINFO);
+ }
flist = (struct file_list *)malloc(sizeof(flist[0]));
if (!flist)
int i = flist->count;
if (i >= flist->malloced) {
- flist->malloced += 100;
- flist->files =(struct file_struct *)realloc(flist->files,
- sizeof(flist->files[0])*
- flist->malloced);
- if (!flist->files)
- goto oom;
+ if (flist->malloced < 100)
+ flist->malloced += 100;
+ else
+ flist->malloced *= 1.8;
+ flist->files =(struct file_struct *)realloc(flist->files,
+ sizeof(flist->files[0])*
+ flist->malloced);
+ if (!flist->files)
+ goto oom;
}
receive_file_entry(&flist->files[i],flags,f);
clean_flist(flist);
+ if (verbose && recurse && !am_server) {
+ fprintf(FINFO,"done\n");
+ }
+
return flist;
oom:
int flist_find(struct file_list *flist,struct file_struct *f)
{
- int low=0,high=flist->count;
+ int low=0,high=flist->count-1;
while (low != high) {
int mid = (low+high)/2;