xref: /freebsd/usr.bin/find/extern.h (revision d0b2dbfa0ecf2bbc9709efc5e20baf8e4b44bbbf)
1 /*-
2  * SPDX-License-Identifier: BSD-3-Clause
3  *
4  * Copyright (c) 1991, 1993, 1994
5  *	The Regents of the University of California.  All rights reserved.
6  *
7  * Redistribution and use in source and binary forms, with or without
8  * modification, are permitted provided that the following conditions
9  * are met:
10  * 1. Redistributions of source code must retain the above copyright
11  *    notice, this list of conditions and the following disclaimer.
12  * 2. Redistributions in binary form must reproduce the above copyright
13  *    notice, this list of conditions and the following disclaimer in the
14  *    documentation and/or other materials provided with the distribution.
15  * 3. Neither the name of the University nor the names of its contributors
16  *    may be used to endorse or promote products derived from this software
17  *    without specific prior written permission.
18  *
19  * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
20  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
21  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
22  * ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
23  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
24  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
25  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
26  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
27  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
28  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
29  * SUCH DAMAGE.
30  *
31  *	@(#)extern.h	8.3 (Berkeley) 4/16/94
32  */
33 
34 #include <sys/cdefs.h>
35 
36 void	 brace_subst(char *, char **, char *, size_t);
37 PLAN	*find_create(char ***);
38 int	 find_execute(PLAN *, char **);
39 PLAN	*find_formplan(char **);
40 PLAN	*not_squish(PLAN *);
41 PLAN	*or_squish(PLAN *);
42 PLAN	*paren_squish(PLAN *);
43 time_t	 get_date(char *);
44 struct stat;
45 void	 printlong(char *, char *, struct stat *);
46 int	 queryuser(char **);
47 OPTION	*lookup_option(const char *);
48 void	 finish_execplus(void);
49 
50 creat_f	c_Xmin;
51 creat_f	c_Xtime;
52 creat_f	c_acl;
53 creat_f	c_and;
54 creat_f	c_delete;
55 creat_f	c_depth;
56 creat_f	c_empty;
57 creat_f	c_exec;
58 creat_f	c_flags;
59 creat_f	c_follow;
60 creat_f	c_fstype;
61 creat_f	c_group;
62 creat_f	c_ignore_readdir_race;
63 creat_f	c_inum;
64 creat_f	c_links;
65 creat_f	c_ls;
66 creat_f	c_mXXdepth;
67 creat_f	c_name;
68 creat_f	c_newer;
69 creat_f	c_nogroup;
70 creat_f	c_nouser;
71 creat_f	c_perm;
72 creat_f	c_print;
73 creat_f	c_regex;
74 creat_f	c_samefile;
75 creat_f	c_simple;
76 creat_f	c_size;
77 creat_f	c_sparse;
78 creat_f	c_type;
79 creat_f	c_user;
80 creat_f	c_xdev;
81 
82 exec_f	f_Xmin;
83 exec_f	f_Xtime;
84 exec_f	f_acl;
85 exec_f	f_always_true;
86 exec_f	f_closeparen;
87 exec_f	f_delete;
88 exec_f	f_depth;
89 exec_f	f_empty;
90 exec_f	f_exec;
91 exec_f	f_expr;
92 exec_f	f_false;
93 exec_f	f_flags;
94 exec_f	f_fstype;
95 exec_f	f_group;
96 exec_f	f_inum;
97 exec_f	f_links;
98 exec_f	f_ls;
99 exec_f	f_name;
100 exec_f	f_newer;
101 exec_f	f_nogroup;
102 exec_f	f_not;
103 exec_f	f_nouser;
104 exec_f	f_openparen;
105 exec_f	f_or;
106 exec_f	f_path;
107 exec_f	f_perm;
108 exec_f	f_print;
109 exec_f	f_print0;
110 exec_f	f_prune;
111 exec_f	f_quit;
112 exec_f	f_regex;
113 exec_f	f_size;
114 exec_f	f_sparse;
115 exec_f	f_type;
116 exec_f	f_user;
117 
118 extern int ftsoptions, ignore_readdir_race, isdepth, isoutput;
119 extern int issort, isxargs;
120 extern int mindepth, maxdepth;
121 extern int regexp_flags;
122 extern int exitstatus;
123 extern time_t now;
124 extern int dotfd;
125 extern FTS *tree;
126