the signed/unsigned change seems to have caused a logic bug on some
[rsync/rsync.git] / rsync.h
diff --git a/rsync.h b/rsync.h
index 9565ed7..a8325d0 100644 (file)
--- a/rsync.h
+++ b/rsync.h
@@ -298,9 +298,13 @@ enum logcode {FNONE=0, FERROR=1, FINFO=2, FLOG=3 };
  * major/minor, and transfer the two parts as 32-bit ints.  That gives
  * you somewhat more of a chance that they'll come from a big machine
  * to a little one in a useful way.
+ *
+ * FIXME: Really we need an unsigned type, and we perhaps ought to
+ * cope with platforms on which this is an unsigned int or even a
+ * struct.  Later.
  */ 
-#define INO64_T int64
-#define DEV64_T int64
+#define INO64_T unsigned int64
+#define DEV64_T unsigned int64
 
 #ifndef MIN
 #define MIN(a,b) ((a)<(b)?(a):(b))
@@ -373,11 +377,11 @@ struct sum_buf {
 };
 
 struct sum_struct {
-  OFF_T flength;               /* total file length */
-  size_t count;                        /* how many chunks */
-  size_t remainder;            /* flength % block_length */
-  size_t n;                    /* block_length */
-  struct sum_buf *sums;                /* points to info for each chunk */
+       OFF_T flength;          /* total file length */
+       size_t count;           /* how many chunks */
+       size_t remainder;       /* flength % block_length */
+       size_t n;               /* block_length */
+       struct sum_buf *sums;   /* points to info for each chunk */
 };
 
 struct map_struct {
@@ -418,11 +422,12 @@ static inline int flist_up(struct file_list *flist, int i)
 }
 
 #include "byteorder.h"
-#include "proto.h"
 #include "lib/mdfour.h"
 #include "lib/permstring.h"
 #include "lib/addrinfo.h"
 
+#include "proto.h"
+
 /* We have replacement versions of these if they're missing. */
 #ifndef HAVE_ASPRINTF
 int asprintf(char **ptr, const char *format, ...);