Deleted Added
full compact
mtree.h (44303) mtree.h (54375)
1/*-
2 * Copyright (c) 1990, 1993
3 * The Regents of the University of California. All rights reserved.
4 *
5 * Redistribution and use in source and binary forms, with or without
6 * modification, are permitted provided that the following conditions
7 * are met:
8 * 1. Redistributions of source code must retain the above copyright

--- 17 unchanged lines hidden (view full) ---

26 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
27 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
28 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
29 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
30 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
31 * SUCH DAMAGE.
32 *
33 * @(#)mtree.h 8.1 (Berkeley) 6/6/93
1/*-
2 * Copyright (c) 1990, 1993
3 * The Regents of the University of California. All rights reserved.
4 *
5 * Redistribution and use in source and binary forms, with or without
6 * modification, are permitted provided that the following conditions
7 * are met:
8 * 1. Redistributions of source code must retain the above copyright

--- 17 unchanged lines hidden (view full) ---

26 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
27 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
28 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
29 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
30 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
31 * SUCH DAMAGE.
32 *
33 * @(#)mtree.h 8.1 (Berkeley) 6/6/93
34 * $FreeBSD: head/usr.sbin/mtree/mtree.h 54375 1999-12-09 20:38:36Z joe $
34 */
35
36#include <string.h>
37#include <stdlib.h>
38
39#define KEYDEFAULT \
35 */
36
37#include <string.h>
38#include <stdlib.h>
39
40#define KEYDEFAULT \
40 (F_GID | F_MODE | F_NLINK | F_SIZE | F_SLINK | F_TIME | F_UID)
41 (F_GID | F_MODE | F_NLINK | F_SIZE | F_SLINK | F_TIME | F_UID | F_FLAGS)
41
42#define MISMATCHEXIT 2
43
44typedef struct _node {
45 struct _node *parent, *child; /* up, down */
46 struct _node *prev, *next; /* left, right */
47 off_t st_size; /* size */
48 struct timespec st_mtimespec; /* last modification time */
49 u_long cksum; /* check sum */
50 char *md5digest; /* MD5 digest */
51 char *sha1digest; /* SHA-1 digest */
52 char *rmd160digest; /* RIPEMD160 digest */
53 char *slink; /* symbolic link reference */
54 uid_t st_uid; /* uid */
55 gid_t st_gid; /* gid */
56#define MBITS (S_ISUID|S_ISGID|S_ISTXT|S_IRWXU|S_IRWXG|S_IRWXO)
57 mode_t st_mode; /* mode */
42
43#define MISMATCHEXIT 2
44
45typedef struct _node {
46 struct _node *parent, *child; /* up, down */
47 struct _node *prev, *next; /* left, right */
48 off_t st_size; /* size */
49 struct timespec st_mtimespec; /* last modification time */
50 u_long cksum; /* check sum */
51 char *md5digest; /* MD5 digest */
52 char *sha1digest; /* SHA-1 digest */
53 char *rmd160digest; /* RIPEMD160 digest */
54 char *slink; /* symbolic link reference */
55 uid_t st_uid; /* uid */
56 gid_t st_gid; /* gid */
57#define MBITS (S_ISUID|S_ISGID|S_ISTXT|S_IRWXU|S_IRWXG|S_IRWXO)
58 mode_t st_mode; /* mode */
59 u_long st_flags; /* flags */
58 nlink_t st_nlink; /* link count */
59
60#define F_CKSUM 0x0001 /* check sum */
61#define F_DONE 0x0002 /* directory done */
62#define F_GID 0x0004 /* gid */
63#define F_GNAME 0x0008 /* group name */
64#define F_IGN 0x0010 /* ignore */
65#define F_MAGIC 0x0020 /* name has magic chars */

--- 6 unchanged lines hidden (view full) ---

72#define F_UID 0x1000 /* uid */
73#define F_UNAME 0x2000 /* user name */
74#define F_VISIT 0x4000 /* file visited */
75#define F_MD5 0x8000 /* MD5 digest */
76#define F_NOCHANGE 0x10000 /* If owner/mode "wrong", do */
77 /* not change */
78#define F_SHA1 0x20000 /* SHA-1 digest */
79#define F_RMD160 0x40000 /* RIPEMD160 digest */
60 nlink_t st_nlink; /* link count */
61
62#define F_CKSUM 0x0001 /* check sum */
63#define F_DONE 0x0002 /* directory done */
64#define F_GID 0x0004 /* gid */
65#define F_GNAME 0x0008 /* group name */
66#define F_IGN 0x0010 /* ignore */
67#define F_MAGIC 0x0020 /* name has magic chars */

--- 6 unchanged lines hidden (view full) ---

74#define F_UID 0x1000 /* uid */
75#define F_UNAME 0x2000 /* user name */
76#define F_VISIT 0x4000 /* file visited */
77#define F_MD5 0x8000 /* MD5 digest */
78#define F_NOCHANGE 0x10000 /* If owner/mode "wrong", do */
79 /* not change */
80#define F_SHA1 0x20000 /* SHA-1 digest */
81#define F_RMD160 0x40000 /* RIPEMD160 digest */
82#define F_FLAGS 0x80000 /* file flags */
80 u_int flags; /* items set */
81
82#define F_BLOCK 0x001 /* block special */
83#define F_CHAR 0x002 /* char special */
84#define F_DIR 0x004 /* directory */
85#define F_FIFO 0x008 /* fifo */
86#define F_FILE 0x010 /* regular file */
87#define F_LINK 0x020 /* symbolic link */
88#define F_SOCK 0x040 /* socket */
89 u_char type; /* file type */
90
91 char name[1]; /* file name (must be last) */
92} NODE;
93
94#define RP(p) \
95 ((p)->fts_path[0] == '.' && (p)->fts_path[1] == '/' ? \
96 (p)->fts_path + 2 : (p)->fts_path)
83 u_int flags; /* items set */
84
85#define F_BLOCK 0x001 /* block special */
86#define F_CHAR 0x002 /* char special */
87#define F_DIR 0x004 /* directory */
88#define F_FIFO 0x008 /* fifo */
89#define F_FILE 0x010 /* regular file */
90#define F_LINK 0x020 /* symbolic link */
91#define F_SOCK 0x040 /* socket */
92 u_char type; /* file type */
93
94 char name[1]; /* file name (must be last) */
95} NODE;
96
97#define RP(p) \
98 ((p)->fts_path[0] == '.' && (p)->fts_path[1] == '/' ? \
99 (p)->fts_path + 2 : (p)->fts_path)