xref: /minix3/usr.sbin/mtree/mtree.h (revision a8ef09103d69c11c99fe50ad80c7cac8bce3133d)
1*a8ef0910SBen Gras /*	$NetBSD: mtree.h,v 1.31 2012/10/05 09:17:29 wiz Exp $	*/
2d433a562SThomas Veerman 
3d433a562SThomas Veerman /*-
4d433a562SThomas Veerman  * Copyright (c) 1990, 1993
5d433a562SThomas Veerman  *	The Regents of the University of California.  All rights reserved.
6d433a562SThomas Veerman  *
7d433a562SThomas Veerman  * Redistribution and use in source and binary forms, with or without
8d433a562SThomas Veerman  * modification, are permitted provided that the following conditions
9d433a562SThomas Veerman  * are met:
10d433a562SThomas Veerman  * 1. Redistributions of source code must retain the above copyright
11d433a562SThomas Veerman  *    notice, this list of conditions and the following disclaimer.
12d433a562SThomas Veerman  * 2. Redistributions in binary form must reproduce the above copyright
13d433a562SThomas Veerman  *    notice, this list of conditions and the following disclaimer in the
14d433a562SThomas Veerman  *    documentation and/or other materials provided with the distribution.
15d433a562SThomas Veerman  * 3. Neither the name of the University nor the names of its contributors
16d433a562SThomas Veerman  *    may be used to endorse or promote products derived from this software
17d433a562SThomas Veerman  *    without specific prior written permission.
18d433a562SThomas Veerman  *
19d433a562SThomas Veerman  * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
20d433a562SThomas Veerman  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
21d433a562SThomas Veerman  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
22d433a562SThomas Veerman  * ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
23d433a562SThomas Veerman  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
24d433a562SThomas Veerman  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
25d433a562SThomas Veerman  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
26d433a562SThomas Veerman  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
27d433a562SThomas Veerman  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
28d433a562SThomas Veerman  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
29d433a562SThomas Veerman  * SUCH DAMAGE.
30d433a562SThomas Veerman  *
31d433a562SThomas Veerman  *	@(#)mtree.h	8.1 (Berkeley) 6/6/93
32d433a562SThomas Veerman  */
33d433a562SThomas Veerman 
34d433a562SThomas Veerman #ifndef _MTREE_H_
35d433a562SThomas Veerman #define	_MTREE_H_
36d433a562SThomas Veerman 
37d433a562SThomas Veerman #define	KEYDEFAULT	(F_GID | F_MODE | F_NLINK | F_SIZE | F_SLINK | \
38d433a562SThomas Veerman 			F_TIME | F_TYPE | F_UID | F_FLAGS)
39d433a562SThomas Veerman 
40d433a562SThomas Veerman #define	MISMATCHEXIT	2
41d433a562SThomas Veerman 
42d433a562SThomas Veerman typedef struct _node {
43d433a562SThomas Veerman 	struct _node	*parent, *child;	/* up, down */
44d433a562SThomas Veerman 	struct _node	*prev, *next;		/* left, right */
45d433a562SThomas Veerman 	off_t	st_size;			/* size */
46d433a562SThomas Veerman 	struct timespec	st_mtimespec;		/* last modification time */
47d433a562SThomas Veerman 	char	*slink;				/* symbolic link reference */
48d433a562SThomas Veerman 	uid_t	st_uid;				/* uid */
49d433a562SThomas Veerman 	gid_t	st_gid;				/* gid */
50d433a562SThomas Veerman #define	MBITS	(S_ISUID|S_ISGID|S_ISTXT|S_IRWXU|S_IRWXG|S_IRWXO)
51d433a562SThomas Veerman 	mode_t	st_mode;			/* mode */
52d433a562SThomas Veerman 	dev_t	st_rdev;			/* device type */
53d433a562SThomas Veerman 	u_long	st_flags;			/* flags */
54d433a562SThomas Veerman 	nlink_t	st_nlink;			/* link count */
55d433a562SThomas Veerman 	u_long	cksum;				/* check sum */
56d433a562SThomas Veerman 	char	*md5digest;			/* MD5 digest */
57d433a562SThomas Veerman 	char	*rmd160digest;			/* RMD-160 digest */
58d433a562SThomas Veerman 	char	*sha1digest;			/* SHA1 digest */
59d433a562SThomas Veerman 	char	*sha256digest;			/* SHA256 digest */
60d433a562SThomas Veerman 	char	*sha384digest;			/* SHA384 digest */
61d433a562SThomas Veerman 	char	*sha512digest;			/* SHA512 digest */
62d433a562SThomas Veerman 	char	*tags;				/* tags, comma delimited,
63d433a562SThomas Veerman 						 * also with leading and
64d433a562SThomas Veerman 						 * trailing commas */
65d433a562SThomas Veerman 	size_t	lineno;				/* line # entry came from */
66d433a562SThomas Veerman 
67d433a562SThomas Veerman #define	F_CKSUM		0x00000001		/* cksum(1) check sum */
68d433a562SThomas Veerman #define	F_DEV		0x00000002		/* device type */
69d433a562SThomas Veerman #define	F_DONE		0x00000004		/* directory done */
70d433a562SThomas Veerman #define	F_FLAGS		0x00000008		/* file flags */
71d433a562SThomas Veerman #define	F_GID		0x00000010		/* gid */
72d433a562SThomas Veerman #define	F_GNAME		0x00000020		/* group name */
73d433a562SThomas Veerman #define	F_IGN		0x00000040		/* ignore */
74d433a562SThomas Veerman #define	F_MAGIC		0x00000080		/* name has magic chars */
75d433a562SThomas Veerman #define	F_MD5		0x00000100		/* MD5 digest */
76d433a562SThomas Veerman #define	F_MODE		0x00000200		/* mode */
77d433a562SThomas Veerman #define	F_NLINK		0x00000400		/* number of links */
78d433a562SThomas Veerman #define	F_OPT		0x00000800		/* existence optional */
79d433a562SThomas Veerman #define	F_RMD160	0x00001000		/* RMD-160 digest */
80d433a562SThomas Veerman #define	F_SHA1		0x00002000		/* SHA1 digest */
81d433a562SThomas Veerman #define	F_SIZE		0x00004000		/* size */
82d433a562SThomas Veerman #define	F_SLINK		0x00008000		/* symbolic link */
83d433a562SThomas Veerman #define	F_TAGS		0x00010000		/* tags */
84d433a562SThomas Veerman #define	F_TIME		0x00020000		/* modification time */
85d433a562SThomas Veerman #define	F_TYPE		0x00040000		/* file type */
86d433a562SThomas Veerman #define	F_UID		0x00080000		/* uid */
87d433a562SThomas Veerman #define	F_UNAME		0x00100000		/* user name */
88d433a562SThomas Veerman #define	F_VISIT		0x00200000		/* file visited */
89*a8ef0910SBen Gras #define	F_NOCHANGE	0x00400000		/* check existence, but not */
90*a8ef0910SBen Gras 						/* other properties */
91d433a562SThomas Veerman #define	F_SHA256	0x00800000		/* SHA256 digest */
92d433a562SThomas Veerman #define	F_SHA384	0x01000000		/* SHA384 digest */
93d433a562SThomas Veerman #define	F_SHA512	0x02000000		/* SHA512 digest */
94d433a562SThomas Veerman 
95d433a562SThomas Veerman 	int	flags;				/* items set */
96d433a562SThomas Veerman 
97d433a562SThomas Veerman #define	F_BLOCK	0x001				/* block special */
98d433a562SThomas Veerman #define	F_CHAR	0x002				/* char special */
99d433a562SThomas Veerman #define	F_DIR	0x004				/* directory */
100d433a562SThomas Veerman #define	F_FIFO	0x008				/* fifo */
101d433a562SThomas Veerman #define	F_FILE	0x010				/* regular file */
102d433a562SThomas Veerman #define	F_LINK	0x020				/* symbolic link */
103d433a562SThomas Veerman #define	F_SOCK	0x040				/* socket */
104d433a562SThomas Veerman #define	F_DOOR	0x080				/* door */
105d433a562SThomas Veerman 	int	type;				/* file type */
106d433a562SThomas Veerman 
107d433a562SThomas Veerman 	char	name[1];			/* file name (must be last) */
108d433a562SThomas Veerman } NODE;
109d433a562SThomas Veerman 
110d433a562SThomas Veerman 
111d433a562SThomas Veerman typedef struct {
112d433a562SThomas Veerman 	char  **list;
113d433a562SThomas Veerman 	int	count;
114d433a562SThomas Veerman } slist_t;
115d433a562SThomas Veerman 
116d433a562SThomas Veerman 
117d433a562SThomas Veerman /*
118d433a562SThomas Veerman  * prototypes for functions published to other programs which want to use
119d433a562SThomas Veerman  * the specfile parser but don't want to pull in all of "extern.h"
120d433a562SThomas Veerman  */
121d433a562SThomas Veerman const char	*inotype(u_int);
122d433a562SThomas Veerman u_int		 nodetoino(u_int);
123d433a562SThomas Veerman int		 setup_getid(const char *);
124d433a562SThomas Veerman NODE		*spec(FILE *);
125*a8ef0910SBen Gras int		 mtree_specspec(FILE *, FILE *);
126d433a562SThomas Veerman void		 free_nodes(NODE *);
127d433a562SThomas Veerman char		*vispath(const char *);
128d433a562SThomas Veerman 
129*a8ef0910SBen Gras #ifdef __FreeBSD__
130*a8ef0910SBen Gras #define KEY_DIGEST "digest"
131*a8ef0910SBen Gras #else
132*a8ef0910SBen Gras #define KEY_DIGEST
133*a8ef0910SBen Gras #endif
134*a8ef0910SBen Gras 
135*a8ef0910SBen Gras #define	MD5KEY		"md5"		KEY_DIGEST
136*a8ef0910SBen Gras #ifdef __FreeBSD__
137*a8ef0910SBen Gras #define	RMD160KEY	"ripemd160"	KEY_DIGEST
138*a8ef0910SBen Gras #else
139*a8ef0910SBen Gras #define	RMD160KEY	"rmd160"	KEY_DIGEST
140*a8ef0910SBen Gras #endif
141*a8ef0910SBen Gras #define	SHA1KEY		"sha1"		KEY_DIGEST
142*a8ef0910SBen Gras #define	SHA256KEY	"sha256"	KEY_DIGEST
143*a8ef0910SBen Gras #define	SHA384KEY	"sha384"
144*a8ef0910SBen Gras #define	SHA512KEY	"sha512"
145d433a562SThomas Veerman 
146d433a562SThomas Veerman #define	RP(p)	\
147d433a562SThomas Veerman 	((p)->fts_path[0] == '.' && (p)->fts_path[1] == '/' ? \
148d433a562SThomas Veerman 	    (p)->fts_path + 2 : (p)->fts_path)
149d433a562SThomas Veerman 
150d433a562SThomas Veerman #define	UF_MASK ((UF_NODUMP | UF_IMMUTABLE |   \
151d433a562SThomas Veerman                   UF_APPEND | UF_OPAQUE)       \
152d433a562SThomas Veerman                     & UF_SETTABLE)              /* user settable flags */
153d433a562SThomas Veerman #define	SF_MASK ((SF_ARCHIVED | SF_IMMUTABLE | \
154d433a562SThomas Veerman                   SF_APPEND) & SF_SETTABLE)     /* root settable flags */
155d433a562SThomas Veerman #define	CH_MASK  (UF_MASK | SF_MASK)            /* all settable flags */
156d433a562SThomas Veerman #define	SP_FLGS  (SF_IMMUTABLE | SF_APPEND)     /* special flags */
157d433a562SThomas Veerman 
158d433a562SThomas Veerman #endif /* _MTREE_H_ */
159