Matt McCutchen's Web Site
/
rsync
/
rsync.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Improved the "use chroot" section to mention how to get user/group
[rsync/rsync.git]
/
tls.c
diff --git
a/tls.c
b/tls.c
index
d02a7a4
..
5facf2e
100644
(file)
--- a/
tls.c
+++ b/
tls.c
@@
-1,6
+1,6
@@
/* -*- c-file-style: "linux" -*-
*
/* -*- c-file-style: "linux" -*-
*
- * Copyright (C) 2001 by Martin Pool <mbp@samba.org>
+ * Copyright (C) 2001
, 2002
by Martin Pool <mbp@samba.org>
*
* This program is free software; you can redistribute it and/or
* modify it under the terms of the GNU General Public License version
*
* This program is free software; you can redistribute it and/or
* modify it under the terms of the GNU General Public License version
@@
-17,10
+17,9
@@
*/
/**
*/
/**
- *
\section tls
+ *
@file tls.c
*
*
- * tls -- Trivial recursive ls, for comparing two directories after
- * running an rsync.
+ * Trivial @c ls for comparing two directories after running an rsync.
*
* The problem with using the system's own ls is that some features
* have little quirks that make directories look different when for
*
* The problem with using the system's own ls is that some features
* have little quirks that make directories look different when for
@@
-39,7
+38,6
@@
**/
**/
-
#include "rsync.h"
#define PROGRAM "tls"
#include "rsync.h"
#define PROGRAM "tls"
@@
-48,6
+46,7
@@
int dry_run = 0;
int read_only = 1;
int list_only = 0;
int dry_run = 0;
int read_only = 1;
int list_only = 0;
+int preserve_perms = 0;
static void failed (char const *what,
static void failed (char const *what,
@@
-62,7
+61,7
@@
static void failed (char const *what,
static void list_file (const char *fname)
{
static void list_file (const char *fname)
{
-
struct stat
buf;
+
STRUCT_STAT
buf;
char permbuf[PERMSTRING_SIZE];
struct tm *mt;
char datebuf[50];
char permbuf[PERMSTRING_SIZE];
struct tm *mt;
char datebuf[50];
@@
-80,12
+79,18
@@
static void list_file (const char *fname)
* undefined. Also it tends not to be possible to reset a
* symlink's mtime, so we have to ignore it too. */
if (S_ISLNK(buf.st_mode)) {
* undefined. Also it tends not to be possible to reset a
* symlink's mtime, so we have to ignore it too. */
if (S_ISLNK(buf.st_mode)) {
+ int len;
buf.st_mode &= ~0777;
buf.st_mtime = (time_t)0;
buf.st_uid = buf.st_gid = 0;
strcpy(linkbuf, " -> ");
/* const-cast required for silly UNICOS headers */
buf.st_mode &= ~0777;
buf.st_mtime = (time_t)0;
buf.st_uid = buf.st_gid = 0;
strcpy(linkbuf, " -> ");
/* const-cast required for silly UNICOS headers */
- readlink((char *) fname, linkbuf+4, sizeof(linkbuf) - 4);
+ len = readlink((char *) fname, linkbuf+4, sizeof(linkbuf) - 4);
+ if (len == -1)
+ failed("readlink", fname);
+ else
+ /* it's not nul-terminated */
+ linkbuf[4+len] = 0;
} else {
linkbuf[0] = 0;
}
} else {
linkbuf[0] = 0;
}
@@
-111,14
+116,15
@@
static void list_file (const char *fname)
/* NB: need to pass size as a double because it might be be
* too large for a long. */
/* NB: need to pass size as a double because it might be be
* too large for a long. */
- printf("%s %12.0f %6
d.%-6
d %s %s%s\n",
- permbuf, (double)
buf.st_size
,
-
buf.st_uid, buf.st_gid
,
+ printf("%s %12.0f %6
ld.%-6ld %6l
d %s %s%s\n",
+ permbuf, (double)
buf.st_size, (long)buf.st_uid
,
+
(long)buf.st_gid, (long)buf.st_nlink
,
datebuf, fname, linkbuf);
}
datebuf, fname, linkbuf);
}
-int main (int argc, char *argv[])
+int
+main(int argc, char *argv[])
{
if (argc < 2) {
fprintf (stderr, "usage: " PROGRAM " DIR ...\n"
{
if (argc < 2) {
fprintf (stderr, "usage: " PROGRAM " DIR ...\n"