X-Git-Url: https://mattmccutchen.net/rsync/rsync.git/blobdiff_plain/34ccb63e71367fb1f93530f60147ef6e4ac4e3e4..1b01b295c960fd6b9fb0c3fdb961010c22b2c898:/rsync.h diff --git a/rsync.h b/rsync.h index 3220e462..ce360185 100644 --- a/rsync.h +++ b/rsync.h @@ -23,9 +23,14 @@ #define RSYNC_NAME "rsync" #define BACKUP_SUFFIX "~" +/* a non-zero CHAR_OFFSET makes the rolling sum stronger, but is + imcompatible with older versions :-( */ +#define CHAR_OFFSET 0 + + #define FILE_VALID 1 #define SAME_MODE (1<<1) -#define SAME_DEV (1<<2) +#define SAME_RDEV (1<<2) #define SAME_UID (1<<3) #define SAME_GID (1<<4) #define SAME_DIR (1<<5) @@ -34,17 +39,19 @@ #define SAME_TIME (1<<7) /* update this if you make incompatible changes */ -#define PROTOCOL_VERSION 11 +#define PROTOCOL_VERSION 14 #define MIN_PROTOCOL_VERSION 10 #define MAX_PROTOCOL_VERSION 20 +#define SPARSE_WRITE_SIZE (4*1024) +#define WRITE_SIZE (32*1024) #define CHUNK_SIZE (32*1024) #define MAX_MAP_SIZE (4*1024*1024) #define BLOCKING_TIMEOUT 10 -/* do we try to create sparse files */ -#define SPARSE_FILES 1 +#define FERROR stderr +#define FINFO (am_server?stderr:stdout) #include "config.h" @@ -58,9 +65,12 @@ #include #endif -#ifdef STDC_HEADERS -# include -# include +#ifdef HAVE_STDLIB_H +#include +#endif + +#ifdef HAVE_STRING_H +#include #endif #ifdef HAVE_COMPAT_H @@ -165,6 +175,7 @@ #endif /* the length of the md4 checksum */ +#define MD4_SUM_LENGTH 16 #define SUM_LENGTH 16 #ifndef MAXPATHLEN @@ -175,13 +186,15 @@ struct file_struct { time_t modtime; off_t length; mode_t mode; + ino_t inode; dev_t dev; + dev_t rdev; uid_t uid; gid_t gid; char *name; char *dir; char *link; - char sum[SUM_LENGTH]; + char sum[MD4_SUM_LENGTH]; }; struct file_list { @@ -195,7 +208,7 @@ struct sum_buf { int len; /* length of chunk of file */ int i; /* index of this chunk */ uint32 sum1; /* simple checksum */ - char sum2[SUM_LENGTH]; /* md4 checksum */ + char sum2[SUM_LENGTH]; /* checksum */ }; struct sum_struct { @@ -206,6 +219,10 @@ struct sum_struct { struct sum_buf *sums; /* points to info for each chunk */ }; +struct map_struct { + char *map,*p; + int fd,size,p_size,p_offset,p_len; +}; #include "byteorder.h" #include "version.h" @@ -250,6 +267,7 @@ extern int errno; #endif #define SUPPORT_LINKS (HAVE_READLINK && defined(S_ISLNK)) +#define SUPPORT_HARD_LINKS HAVE_LINK #ifndef S_ISLNK #define S_ISLNK(x) 0