a9d8f38121b5b5816a4e54ec73038116501648c0
[dragonfly.git] / usr.sbin / mtree / mtree.h
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
9  *    notice, this list of conditions and the following disclaimer.
10  * 2. Redistributions in binary form must reproduce the above copyright
11  *    notice, this list of conditions and the following disclaimer in the
12  *    documentation and/or other materials provided with the distribution.
13  * 3. All advertising materials mentioning features or use of this software
14  *    must display the following acknowledgement:
15  *      This product includes software developed by the University of
16  *      California, Berkeley and its contributors.
17  * 4. Neither the name of the University nor the names of its contributors
18  *    may be used to endorse or promote products derived from this software
19  *    without specific prior written permission.
20  *
21  * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
22  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
23  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
24  * ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
25  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
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: src/usr.sbin/mtree/mtree.h,v 1.5 1999/12/09 20:38:35 joe Exp $
35  * $DragonFly: src/usr.sbin/mtree/mtree.h,v 1.2 2003/06/17 04:29:57 dillon Exp $
36  */
37
38 #include <string.h>
39 #include <stdlib.h>
40
41 #define KEYDEFAULT \
42         (F_GID | F_MODE | F_NLINK | F_SIZE | F_SLINK | F_TIME | F_UID | F_FLAGS)
43
44 #define MISMATCHEXIT    2
45
46 typedef struct _node {
47         struct _node    *parent, *child;        /* up, down */
48         struct _node    *prev, *next;           /* left, right */
49         off_t   st_size;                        /* size */
50         struct timespec st_mtimespec;           /* last modification time */
51         u_long  cksum;                          /* check sum */
52         char    *md5digest;                     /* MD5 digest */
53         char    *sha1digest;                    /* SHA-1 digest */
54         char    *rmd160digest;                  /* RIPEMD160 digest */
55         char    *slink;                         /* symbolic link reference */
56         uid_t   st_uid;                         /* uid */
57         gid_t   st_gid;                         /* gid */
58 #define MBITS   (S_ISUID|S_ISGID|S_ISTXT|S_IRWXU|S_IRWXG|S_IRWXO)
59         mode_t  st_mode;                        /* mode */
60         u_long  st_flags;                       /* flags */
61         nlink_t st_nlink;                       /* link count */
62
63 #define F_CKSUM 0x0001                          /* check sum */
64 #define F_DONE  0x0002                          /* directory done */
65 #define F_GID   0x0004                          /* gid */
66 #define F_GNAME 0x0008                          /* group name */
67 #define F_IGN   0x0010                          /* ignore */
68 #define F_MAGIC 0x0020                          /* name has magic chars */
69 #define F_MODE  0x0040                          /* mode */
70 #define F_NLINK 0x0080                          /* number of links */
71 #define F_SIZE  0x0100                          /* size */
72 #define F_SLINK 0x0200                          /* link count */
73 #define F_TIME  0x0400                          /* modification time */
74 #define F_TYPE  0x0800                          /* file type */
75 #define F_UID   0x1000                          /* uid */
76 #define F_UNAME 0x2000                          /* user name */
77 #define F_VISIT 0x4000                          /* file visited */
78 #define F_MD5   0x8000                          /* MD5 digest */
79 #define F_NOCHANGE 0x10000                      /* If owner/mode "wrong", do */
80                                                 /* not change */
81 #define F_SHA1  0x20000                         /* SHA-1 digest */
82 #define F_RMD160 0x40000                        /* RIPEMD160 digest */
83 #define F_FLAGS 0x80000                         /* file flags */
84         u_int   flags;                          /* items set */
85
86 #define F_BLOCK 0x001                           /* block special */
87 #define F_CHAR  0x002                           /* char special */
88 #define F_DIR   0x004                           /* directory */
89 #define F_FIFO  0x008                           /* fifo */
90 #define F_FILE  0x010                           /* regular file */
91 #define F_LINK  0x020                           /* symbolic link */
92 #define F_SOCK  0x040                           /* socket */
93         u_char  type;                           /* file type */
94
95         char    name[1];                        /* file name (must be last) */
96 } NODE;
97
98 #define RP(p)   \
99         ((p)->fts_path[0] == '.' && (p)->fts_path[1] == '/' ? \
100             (p)->fts_path + 2 : (p)->fts_path)