xref: /freebsd/usr.bin/find/find.1 (revision 56b17de1e8360fe131d425de20b5e75ff3ea897c)
1.\" Copyright (c) 1990, 1993
2.\"	The Regents of the University of California.  All rights reserved.
3.\"
4.\" This code is derived from software contributed to Berkeley by
5.\" the Institute of Electrical and Electronics Engineers, Inc.
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.Dd January 21, 2024
32.Dt FIND 1
33.Os
34.Sh NAME
35.Nm find
36.Nd walk a file hierarchy
37.Sh SYNOPSIS
38.Nm
39.Op Fl H | Fl L | Fl P
40.Op Fl EXdsx
41.Op Fl f Ar path
42.Ar path ...
43.Op Ar expression
44.Nm
45.Op Fl H | Fl L | Fl P
46.Op Fl EXdsx
47.Fl f Ar path
48.Op Ar path ...
49.Op Ar expression
50.Sh DESCRIPTION
51The
52.Nm
53utility recursively descends the directory tree for each
54.Ar path
55listed, evaluating an
56.Ar expression
57(composed of the
58.Dq primaries
59and
60.Dq operands
61listed below) in terms
62of each file in the tree.
63.Pp
64The options are as follows:
65.Bl -tag -width indent
66.It Fl E
67Interpret regular expressions following the
68.Ic -regex
69and
70.Ic -iregex
71primaries as extended (modern) regular expressions rather than basic
72regular expressions (BRE's).
73The
74.Xr re_format 7
75manual page fully describes both formats.
76.It Fl H
77Cause the file information and file type (see
78.Xr stat 2 )
79returned for each symbolic link specified on the command line to be
80those of the file referenced by the link, not the link itself.
81If the referenced file does not exist, the file information and type will
82be for the link itself.
83File information of all symbolic links not on
84the command line is that of the link itself.
85.It Fl L
86Cause the file information and file type (see
87.Xr stat 2 )
88returned for each symbolic link to be those of the file referenced by the
89link, not the link itself.
90If the referenced file does not exist, the file information and type will
91be for the link itself.
92.Pp
93This option is equivalent to the deprecated
94.Ic -follow
95primary.
96.It Fl P
97Cause the file information and file type (see
98.Xr stat 2 )
99returned for each symbolic link to be those of the link itself.
100This is the default.
101.It Fl X
102Permit
103.Nm
104to be safely used in conjunction with
105.Xr xargs 1 .
106If a file name contains any of the delimiting characters used by
107.Xr xargs 1 ,
108a diagnostic message is displayed on standard error, and the file
109is skipped.
110The delimiting characters include single
111.Pq Dq Li " ' "
112and double
113.Pq Dq Li " \*q "
114quotes, backslash
115.Pq Dq Li \e ,
116space, tab and newline characters.
117.Pp
118However, you may wish to consider the
119.Fl print0
120primary in conjunction with
121.Dq Nm xargs Fl 0
122as an effective alternative.
123.It Fl d
124Cause
125.Nm
126to perform a depth-first traversal.
127.Pp
128This option is a BSD-specific equivalent of the
129.Ic -depth
130primary specified by
131.St -p1003.1-2001 .
132Refer to its description under
133.Sx PRIMARIES
134for more information.
135.It Fl f Ar path
136Add
137.Ar path
138to the list of paths that will be recursed into.
139This is useful when
140.Ar path
141begins with a character that would otherwise be interpreted as an
142.Ar expression ,
143namely
144.Dq Li "!" ,
145.Dq Li "("
146and
147.Dq Li - .
148.It Fl s
149Cause
150.Nm
151to traverse the file hierarchies in lexicographical order,
152i.e., alphabetical order within each directory.
153Note:
154.Ql find -s
155and
156.Ql "find | sort"
157may give different results.
158.Pp
159For example,
160.Ql find -s
161puts a directory
162.Ql Ar foo
163with all its contents before a directory
164.Ql Ar foo .
165but
166.Ql "find | sort"
167puts the directory name
168.Ql Ar foo .
169before any string like
170.Ql Ar foo/bar
171because
172.Ql .\&
173goes before
174.Ql /
175in ASCII.
176In locales other than
177.Ar C
178results may vary more due to collation differences.
179.It Fl x
180Prevent
181.Nm
182from descending into directories that have a device number different
183than that of the file from which the descent began.
184.Pp
185This option is equivalent to the deprecated
186.Ic -xdev
187primary.
188.El
189.Sh PRIMARIES
190All primaries which take a numeric argument allow the number to be
191preceded by a plus sign
192.Pq Dq Li +
193or a minus sign
194.Pq Dq Li - .
195A preceding plus sign means
196.Dq more than n ,
197a preceding minus sign means
198.Dq less than n
199and neither means
200.Dq exactly n .
201.Bl -tag -width indent
202.It Ic -Bmin Ar n
203True if the difference between the time of a file's inode creation
204and the time
205.Nm
206was started, rounded up to the next full minute, is
207.Ar n
208minutes.
209.It Ic -Bnewer Ar file
210Same as
211.Ic -newerBm .
212.It Ic -Btime Ar n Ns Op Cm smhdw
213If no units are specified, this primary evaluates to
214true if the difference between the time of a file's inode creation
215and the time
216.Nm
217was started, rounded up to the next full 24-hour period, is
218.Ar n
21924-hour periods.
220.Pp
221If units are specified, this primary evaluates to
222true if the difference between the time of a file's inode creation
223and the time
224.Nm
225was started is exactly
226.Ar n
227units.
228Please refer to the
229.Ic -atime
230primary description for information on supported time units.
231.It Ic -acl
232May be used in conjunction with other primaries to locate
233files with extended ACLs.
234See
235.Xr acl 3
236for more information.
237.It Ic -amin Oo Cm - Ns | Ns Cm + Oc Ns Ar n
238True if the difference between the file last access time and the time
239.Nm
240was started, rounded up to the next full minute, is
241more than
242.Ar n
243.Pq + Ns Ar n ,
244less than
245.Ar n
246.Pq - Ns Ar n ,
247or exactly
248.Ar n
249minutes ago.
250.It Ic -anewer Ar file
251Same as
252.Ic -neweram .
253.It Ic -atime Ar n Ns Op Cm smhdw
254If no units are specified, this primary evaluates to
255true if the difference between the file last access time and the time
256.Nm
257was started, rounded up to the next full 24-hour period, is
258.Ar n
25924-hour periods.
260.Pp
261If units are specified, this primary evaluates to
262true if the difference between the file last access time and the time
263.Nm
264was started is exactly
265.Ar n
266units.
267Possible time units are as follows:
268.Pp
269.Bl -tag -width indent -compact
270.It Cm s
271second
272.It Cm m
273minute (60 seconds)
274.It Cm h
275hour (60 minutes)
276.It Cm d
277day (24 hours)
278.It Cm w
279week (7 days)
280.El
281.Pp
282Any number of units may be combined in one
283.Ic -atime
284argument, for example,
285.Dq Li "-atime -1h30m" .
286Units are probably only useful when used in conjunction with the
287.Cm +
288or
289.Cm -
290modifier.
291.It Ic -cmin Oo Cm - Ns | Ns Cm + Oc Ns Ar n
292True if the difference between the time of last change of file status
293information and the time
294.Nm
295was started, rounded up to the next full minute, is
296more than
297.Ar n
298.Pq + Ns Ar n ,
299less than
300.Ar n
301.Pq - Ns Ar n ,
302or exactly
303.Ar n
304minutes ago.
305.It Ic -cnewer Ar file
306Same as
307.Ic -newercm .
308.It Ic -ctime Ar n Ns Op Cm smhdw
309If no units are specified, this primary evaluates to
310true if the difference between the time of last change of file status
311information and the time
312.Nm
313was started, rounded up to the next full 24-hour period, is
314.Ar n
31524-hour periods.
316.Pp
317If units are specified, this primary evaluates to
318true if the difference between the time of last change of file status
319information and the time
320.Nm
321was started is exactly
322.Ar n
323units.
324Please refer to the
325.Ic -atime
326primary description for information on supported time units.
327.It Ic -d
328Non-portable, BSD-specific version of
329.Ic depth .
330GNU find implements this as a primary in mistaken emulation of
331.Fx
332.Nm .
333.It Ic -delete
334Delete found files and/or directories.
335Always returns true.
336This executes
337from the current working directory as
338.Nm
339recurses down the tree.
340It will not attempt to delete a filename with a
341.Dq Pa /
342character in its pathname relative to
343.Dq Pa \&.
344for security reasons.
345Depth-first traversal processing is implied by this option.
346The
347.Ic -delete
348primary will fail to delete a directory if it is not empty.
349Following symlinks is incompatible with this option.
350.Pp
351.Em WARNING :
352The
353.Ic -delete
354primary will immediately attempt to delete the current path when
355evaluated.
356Be mindful of its place in the expression; as a general rule, it
357should almost always come last.
358If in doubt, try running with
359.Ic -print
360in place of
361.Ic -delete
362first.
363See
364.Sx OPERATORS
365below for additional information on the order of evaluation.
366.It Ic -depth
367Always true;
368same as the non-portable
369.Fl d
370option.
371Cause
372.Nm
373to perform a depth-first traversal, i.e., directories
374are visited in post-order and all entries in a directory will be acted
375on before the directory itself.
376By default,
377.Nm
378visits directories in pre-order, i.e., before their contents.
379Note, the default is
380.Em not
381a breadth-first traversal.
382.Pp
383The
384.Ic -depth
385primary
386can be useful when
387.Nm
388is used with
389.Xr cpio 1
390to process files that are contained in directories with unusual permissions.
391It ensures that you have write permission while you are placing files in a
392directory, then sets the directory's permissions as the last thing.
393.It Ic -depth Ar n
394True if the depth of the file relative to the starting point of the traversal
395is
396.Ar n .
397.It Ic -empty
398True if the current file or directory is empty.
399.It Ic -exec Ar utility Oo Ar argument ... Oc Li \&;
400True if the program named
401.Ar utility
402returns a zero value as its exit status.
403Optional
404.Ar arguments
405may be passed to the utility.
406The expression must be terminated by a semicolon
407.Pq Dq Li \&; .
408If you invoke
409.Nm
410from a shell you may need to quote the semicolon if the shell would
411otherwise treat it as a control operator.
412If the string
413.Dq Li {}
414appears anywhere in the utility name or the
415arguments it is replaced by the pathname of the current file.
416.Ar Utility
417will be executed from the directory from which
418.Nm
419was executed.
420.Ar Utility
421and
422.Ar arguments
423are not subject to the further expansion of shell patterns
424and constructs.
425.It Ic -exec Ar utility Oo Ar argument ... Oc Li {} +
426Same as
427.Ic -exec ,
428except that
429.Dq Li {}
430is replaced with as many pathnames as possible for each invocation of
431.Ar utility .
432This behaviour is similar to that of
433.Xr xargs 1 .
434The primary always returns true;
435if at least one invocation of
436.Ar utility
437returns a non-zero exit status,
438.Nm
439will return a non-zero exit status.
440.It Ic -execdir Ar utility Oo Ar argument ... Oc Li \&;
441The
442.Ic -execdir
443primary is identical to the
444.Ic -exec
445primary with the exception that
446.Ar utility
447will be executed from the directory that holds
448the current file.
449The filename substituted for
450the string
451.Dq Li {}
452is not qualified.
453.It Ic -execdir Ar utility Oo Ar argument ... Oc Li {} +
454Same as
455.Ic -execdir ,
456except that
457.Dq Li {}
458is replaced with as many pathnames as possible for each invocation of
459.Ar utility .
460This behaviour is similar to that of
461.Xr xargs 1 .
462The primary always returns true;
463if at least one invocation of
464.Ar utility
465returns a non-zero exit status,
466.Nm
467will return a non-zero exit status.
468.It Ic -executable
469Matches files which are executable by the current user.
470This test makes use of the
471.Xr access 2
472system call, and so can be fooled by NFS servers which do UID mapping (or root-squashing).
473This is a GNU find extension.
474.It Ic -flags Oo Cm - Ns | Ns Cm + Oc Ns Ar flags , Ns Ar notflags
475The flags are specified using symbolic names (see
476.Xr chflags 1 ) .
477Those with the
478.Qq Li no
479prefix (except
480.Qq Li nodump )
481are said to be
482.Ar notflags .
483Flags in
484.Ar flags
485are checked to be set, and flags in
486.Ar notflags
487are checked to be not set.
488Note that this is different from
489.Ic -perm ,
490which only allows the user to specify mode bits that are set.
491.Pp
492If flags are preceded by a dash
493.Pq Dq Li - ,
494this primary evaluates to true
495if at least all of the bits in
496.Ar flags
497and none of the bits in
498.Ar notflags
499are set in the file's flags bits.
500If flags are preceded by a plus
501.Pq Dq Li + ,
502this primary evaluates to true
503if any of the bits in
504.Ar flags
505is set in the file's flags bits,
506or any of the bits in
507.Ar notflags
508is not set in the file's flags bits.
509Otherwise,
510this primary evaluates to true
511if the bits in
512.Ar flags
513exactly match the file's flags bits,
514and none of the
515.Ar flags
516bits match those of
517.Ar notflags .
518.It Ic -fstype Ar type
519True if the file is contained in a file system of type
520.Ar type .
521The
522.Xr lsvfs 1
523command can be used to find out the types of file systems
524that are available on the system.
525In addition, there are two pseudo-types,
526.Dq Li local
527and
528.Dq Li rdonly .
529The former matches any file system physically mounted on the system where
530the
531.Nm
532is being executed and the latter matches any file system which is
533mounted read-only.
534.It Ic -gid Ar gname
535The same thing as
536.Ic -group Ar gname
537for compatibility with GNU find.
538GNU find imposes a restriction that
539.Ar gname
540is numeric, while
541.Nm
542does not.
543.It Ic -group Ar gname
544True if the file belongs to the group
545.Ar gname .
546If
547.Ar gname
548is numeric and there is no such group name, then
549.Ar gname
550is treated as a group ID.
551.It Ic -ignore_readdir_race
552Ignore errors because a file or a directory is deleted
553after reading the name from a directory.
554This option does not affect errors occurring on starting points.
555.It Ic -ilname Ar pattern
556Like
557.Ic -lname ,
558but the match is case insensitive.
559This is a GNU find extension.
560.It Ic -iname Ar pattern
561Like
562.Ic -name ,
563but the match is case insensitive.
564.It Ic -inum Ar n
565True if the file has inode number
566.Ar n .
567.It Ic -ipath Ar pattern
568Like
569.Ic -path ,
570but the match is case insensitive.
571.It Ic -iregex Ar pattern
572Like
573.Ic -regex ,
574but the match is case insensitive.
575.It Ic -iwholename Ar pattern
576The same thing as
577.Ic -ipath ,
578for GNU find compatibility.
579.It Ic -links Ar n
580True if the file has
581.Ar n
582links.
583.It Ic -lname Ar pattern
584Like
585.Ic -name ,
586but the contents of the symbolic link are matched instead of the file
587name.
588Note that this only matches broken symbolic links
589if symbolic links are being followed.
590This is a GNU find extension.
591.It Ic -ls
592This primary always evaluates to true.
593The following information for the current file is written to standard output:
594its inode number, size in 512-byte blocks, file permissions, number of hard
595links, owner, group, size in bytes, last modification time, and pathname.
596If the file is a block or character special file, the device number
597will be displayed instead of the size in bytes.
598If the file is a symbolic link, the pathname of the linked-to file will be
599displayed preceded by
600.Dq Li -> .
601The format is identical to that produced by
602.Bk -words
603.Dq Nm ls Fl dgils .
604.Ek
605.It Ic -maxdepth Ar n
606Always true; descend at most
607.Ar n
608directory levels below the command line arguments.
609If any
610.Ic -maxdepth
611primary is specified, it applies to the entire expression even if it would
612not normally be evaluated.
613.Dq Ic -maxdepth Li 0
614limits the whole search to the command line arguments.
615.It Ic -mindepth Ar n
616Always true; do not apply any tests or actions at levels less than
617.Ar n .
618If any
619.Ic -mindepth
620primary is specified, it applies to the entire expression even if it would
621not normally be evaluated.
622.Dq Ic -mindepth Li 1
623processes all but the command line arguments.
624.It Ic -mmin Oo Cm - Ns | Ns Cm + Oc Ns Ar n
625True if the difference between the file last modification time and the time
626.Nm
627was started, rounded up to the next full minute, is
628more than
629.Ar n
630.Pq + Ns Ar n ,
631less than
632.Ar n
633.Pq - Ns Ar n ,
634or exactly
635.Ar n
636minutes ago.
637.It Ic -mnewer Ar file
638Same as
639.Ic -newer .
640.It Ic -mount
641The same thing as
642.Ic -xdev ,
643for GNU find compatibility.
644.It Ic -mtime Ar n Ns Op Cm smhdw
645If no units are specified, this primary evaluates to
646true if the difference between the file last modification time and the time
647.Nm
648was started, rounded up to the next full 24-hour period, is
649.Ar n
65024-hour periods.
651.Pp
652If units are specified, this primary evaluates to
653true if the difference between the file last modification time and the time
654.Nm
655was started is exactly
656.Ar n
657units.
658Please refer to the
659.Ic -atime
660primary description for information on supported time units.
661.It Ic -name Ar pattern
662True if the last component of the pathname being examined matches
663.Ar pattern .
664Special shell pattern matching characters
665.Dq ( Li \&[ ,
666.Dq Li \&] ,
667.Dq Li * ,
668and
669.Dq Li \&? )
670may be used as part of
671.Ar pattern .
672These characters may be matched explicitly by escaping them with a
673backslash
674.Pq Dq Li \e .
675.It Ic -newer Ar file
676True if the current file has a more recent last modification time than
677.Ar file .
678.It Ic -newer Ns Ar X Ns Ar Y Ar file
679True if the current file has a more recent last access time
680.Pq Ar X Ns = Ns Cm a ,
681inode creation time
682.Pq Ar X Ns = Ns Cm B ,
683change time
684.Pq Ar X Ns = Ns Cm c ,
685or modification time
686.Pq Ar X Ns = Ns Cm m
687than the last access time
688.Pq Ar Y Ns = Ns Cm a ,
689inode creation time
690.Pq Ar Y Ns = Ns Cm B ,
691change time
692.Pq Ar Y Ns = Ns Cm c ,
693or modification time
694.Pq Ar Y Ns = Ns Cm m
695of
696.Ar file .
697In addition, if
698.Ar Y Ns = Ns Cm t ,
699then
700.Ar file
701is instead interpreted as a direct date specification of the form
702understood by ISO8601 or RFC822.
703Note that
704.Ic -newermm
705is equivalent to
706.Ic -newer .
707.It Ic -nogroup
708True if the file belongs to an unknown group.
709.It Ic -noignore_readdir_race
710Turn off the effect of
711.Ic -ignore_readdir_race .
712This is default behaviour.
713.It Ic -noleaf
714This option is for GNU find compatibility.
715In GNU find it disables an optimization not relevant to
716.Nm ,
717so it is ignored.
718.It Ic -nouser
719True if the file belongs to an unknown user.
720.It Ic -ok Ar utility Oo Ar argument ... Oc Li \&;
721The
722.Ic -ok
723primary is identical to the
724.Ic -exec
725primary with the exception that
726.Nm
727requests user affirmation for the execution of the
728.Ar utility
729by printing
730a message to the terminal and reading a response.
731If the response is not affirmative
732.Ql ( y
733in the
734.Dq Li POSIX
735locale),
736the command is not executed and the
737value of the
738.Ic -ok
739expression is false.
740.It Ic -okdir Ar utility Oo Ar argument ... Oc Li \&;
741The
742.Ic -okdir
743primary is identical to the
744.Ic -execdir
745primary with the same exception as described for the
746.Ic -ok
747primary.
748.It Ic -path Ar pattern
749True if the pathname being examined matches
750.Ar pattern .
751Special shell pattern matching characters
752.Dq ( Li \&[ ,
753.Dq Li \&] ,
754.Dq Li * ,
755and
756.Dq Li \&? )
757may be used as part of
758.Ar pattern .
759These characters may be matched explicitly by escaping them with a
760backslash
761.Pq Dq Li \e .
762Slashes
763.Pq Dq Li /
764are treated as normal characters and do not have to be
765matched explicitly.
766.It Ic -perm Oo Cm - Ns | Ns Cm + Ns | Ns Cm / Oc Ns Ar mode
767The
768.Ar mode
769may be either symbolic (see
770.Xr chmod 1 )
771or an octal number.
772If the
773.Ar mode
774is symbolic, a starting value of zero is assumed and the
775.Ar mode
776sets or clears permissions without regard to the process' file mode
777creation mask.
778If the
779.Ar mode
780is octal, only bits 07777
781.Pq Dv S_ISUID | S_ISGID | S_ISTXT | S_IRWXU | S_IRWXG | S_IRWXO
782of the file's mode bits participate
783in the comparison.
784If the
785.Ar mode
786is preceded by a dash
787.Pq Dq Li - ,
788this primary evaluates to true
789if at least all of the bits in the
790.Ar mode
791are set in the file's mode bits.
792If the
793.Ar mode
794is preceded by a plus
795.Pq Dq Li +
796this primary evaluates to true
797if any of the bits in the
798.Ar mode
799are set in the file's mode bits.
800A slash
801.Pq Dq Li /
802is also accepted with the same meaning as plus for compatibility with GNU find.
803Otherwise, this primary evaluates to true if
804the bits in the
805.Ar mode
806exactly match the file's mode bits.
807Note, the first character of a symbolic mode may not be a dash
808.Pq Dq Li - .
809.It Ic -print
810This primary always evaluates to true.
811It prints the pathname of the current file to standard output.
812If none of
813.Ic -exec , -ls , -print0 ,
814or
815.Ic -ok
816is specified, the given expression shall be effectively replaced by
817.Cm \&( Ar "given expression" Cm \&) Ic -print .
818.It Ic -print0
819This primary always evaluates to true.
820It prints the pathname of the current file to standard output, followed by an
821ASCII
822.Dv NUL
823character (character code 0).
824.It Ic -prune
825This primary always evaluates to true.
826It causes
827.Nm
828to not descend into the current file.
829Note, the
830.Ic -prune
831primary has no effect if the
832.Fl d
833option was specified.
834.It Ic -quit
835Causes
836.Nm
837to terminate immediately.
838.It Ic -readable
839Matches files which are readable by the current user.
840This test makes use of the
841.Xr access 2
842system call, and so can be fooled by NFS servers which do UID mapping (or root-squashing).
843This is a GNU find extension.
844.It Ic -regex Ar pattern
845True if the whole path of the file matches
846.Ar pattern
847using regular expression.
848To match a file named
849.Dq Pa ./foo/xyzzy ,
850you can use the regular expression
851.Dq Li ".*/[xyz]*"
852or
853.Dq Li ".*/foo/.*" ,
854but not
855.Dq Li xyzzy
856or
857.Dq Li /foo/ .
858.It Ic -samefile Ar name
859True if the file is a hard link to
860.Ar name .
861If the command option
862.Ic -L
863is specified, it is also true if the file is a symbolic link and
864points to
865.Ar name .
866.It Ic -size Ar n Ns Op Cm ckMGTP
867True if the file's size, rounded up, in 512-byte blocks is
868.Ar n .
869If
870.Ar n
871is followed by a
872.Cm c ,
873then the primary is true if the
874file's size is
875.Ar n
876bytes (characters).
877Similarly if
878.Ar n
879is followed by a scale indicator then the file's size is compared to
880.Ar n
881scaled as:
882.Pp
883.Bl -tag -width indent -compact
884.It Cm k
885kilobytes (1024 bytes)
886.It Cm M
887megabytes (1024 kilobytes)
888.It Cm G
889gigabytes (1024 megabytes)
890.It Cm T
891terabytes (1024 gigabytes)
892.It Cm P
893petabytes (1024 terabytes)
894.El
895.It Ic -sparse
896True if the current file is sparse,
897i.e. has fewer blocks allocated than expected based on its size in bytes.
898This might also match files that have been compressed by the filesystem.
899.It Ic -type Ar t
900True if the file is of the specified type.
901Possible file types are as follows:
902.Pp
903.Bl -tag -width indent -compact
904.It Cm b
905block special
906.It Cm c
907character special
908.It Cm d
909directory
910.It Cm f
911regular file
912.It Cm l
913symbolic link
914.It Cm p
915FIFO
916.It Cm s
917socket
918.El
919.It Ic -uid Ar uname
920The same thing as
921.Ar -user Ar uname
922for compatibility with GNU find.
923GNU find imposes a restriction that
924.Ar uname
925is numeric, while
926.Nm
927does not.
928.It Ic -user Ar uname
929True if the file belongs to the user
930.Ar uname .
931If
932.Ar uname
933is numeric and there is no such user name, then
934.Ar uname
935is treated as a user ID.
936.It Ic -wholename Ar pattern
937The same thing as
938.Ic -path ,
939for GNU find compatibility.
940.It Ic -writable
941Matches files which are writable by the current user.
942This test makes use of the
943.Xr access 2
944system call, and so can be fooled by NFS servers which do UID mapping (or root-squashing).
945This is a GNU find extension.
946.El
947.Sh OPERATORS
948The primaries may be combined using the following operators.
949The operators are listed in order of decreasing precedence.
950.Pp
951.Bl -tag -width indent -compact
952.It Cm \&( Ar expression Cm \&)
953This evaluates to true if the parenthesized expression evaluates to
954true.
955.Pp
956.It Cm \&! Ar expression
957.It Cm -not Ar expression
958This is the unary
959.Tn NOT
960operator.
961It evaluates to true if the expression is false.
962.Pp
963.It Cm -false
964Always false.
965.It Cm -true
966Always true.
967.Pp
968.It Ar expression Cm -and Ar expression
969.It Ar expression expression
970The
971.Cm -and
972operator is the logical
973.Tn AND
974operator.
975As it is implied by the juxtaposition of two expressions it does not
976have to be specified.
977The expression evaluates to true if both expressions are true.
978The second expression is not evaluated if the first expression is false.
979.Pp
980.It Ar expression Cm -or Ar expression
981The
982.Cm -or
983operator is the logical
984.Tn OR
985operator.
986The expression evaluates to true if either the first or the second expression
987is true.
988The second expression is not evaluated if the first expression is true.
989.El
990.Pp
991All operands and primaries must be separate arguments to
992.Nm .
993Primaries which themselves take arguments expect each argument
994to be a separate argument to
995.Nm .
996.Sh ENVIRONMENT
997The
998.Ev LANG , LC_ALL , LC_COLLATE , LC_CTYPE , LC_MESSAGES
999and
1000.Ev LC_TIME
1001environment variables affect the execution of the
1002.Nm
1003utility as described in
1004.Xr environ 7 .
1005.Sh EXAMPLES
1006The following examples are shown as given to the shell:
1007.Bl -tag -width indent
1008.It Li "find / \e! -name \*q*.c\*q -print"
1009Print out a list of all the files whose names do not end in
1010.Pa .c .
1011.It Li "find / -newer ttt -user wnj -print"
1012Print out a list of all the files owned by user
1013.Dq wnj
1014that are newer
1015than the file
1016.Pa ttt .
1017.It Li "find / \e! \e( -newer ttt -user wnj \e) -print"
1018Print out a list of all the files which are not both newer than
1019.Pa ttt
1020and owned by
1021.Dq wnj .
1022.It Li "find / \e( -newer ttt -or -user wnj \e) -print"
1023Print out a list of all the files that are either owned by
1024.Dq wnj
1025or that are newer than
1026.Pa ttt .
1027.It Li "find / -newerct '1 minute ago' -print"
1028Print out a list of all the files whose inode change time is more
1029recent than the current time minus one minute.
1030.It Li "find / -type f -exec echo {} \e;"
1031Use the
1032.Xr echo 1
1033command to print out a list of all the files.
1034.It Li "find -L /usr/ports/packages -type l -exec rm -- {} +"
1035Delete all broken symbolic links in
1036.Pa /usr/ports/packages .
1037.It Li "find /usr/src -name CVS -prune -o -depth +6 -print"
1038Find files and directories that are at least seven levels deep
1039in the working directory
1040.Pa /usr/src .
1041.It Li "find /usr/src -name CVS -prune -o -mindepth 7 -print"
1042Is not equivalent to the previous example, since
1043.Ic -prune
1044is not evaluated below level seven.
1045.El
1046.Sh COMPATIBILITY
1047The
1048.Ic -follow
1049primary is deprecated; the
1050.Fl L
1051option should be used instead.
1052See the
1053.Sx STANDARDS
1054section below for details.
1055.Sh SEE ALSO
1056.Xr chflags 1 ,
1057.Xr chmod 1 ,
1058.Xr locate 1 ,
1059.Xr lsvfs 1 ,
1060.Xr whereis 1 ,
1061.Xr which 1 ,
1062.Xr xargs 1 ,
1063.Xr stat 2 ,
1064.Xr acl 3 ,
1065.Xr fts 3 ,
1066.Xr getgrent 3 ,
1067.Xr getpwent 3 ,
1068.Xr strmode 3 ,
1069.Xr ascii 7 ,
1070.Xr re_format 7 ,
1071.Xr symlink 7
1072.Sh STANDARDS
1073The
1074.Nm
1075utility syntax is a superset of the syntax specified by the
1076.St -p1003.1-2001
1077standard.
1078.Pp
1079All the single character options except
1080.Fl H
1081and
1082.Fl L
1083as well as
1084.Ic -amin , -anewer , -cmin , -cnewer , -delete , -empty , -fstype ,
1085.Ic -iname , -inum , -iregex , -ls , -maxdepth , -mindepth , -mmin ,
1086.Ic -not , -path , -print0 , -regex , -sparse
1087and all of the
1088.Fl B*
1089birthtime related primaries are extensions to
1090.St -p1003.1-2001 .
1091.Pp
1092Historically, the
1093.Fl d , L
1094and
1095.Fl x
1096options were implemented using the primaries
1097.Ic -depth , -follow ,
1098and
1099.Ic -xdev .
1100These primaries always evaluated to true.
1101As they were really global variables that took effect before the traversal
1102began, some legal expressions could have unexpected results.
1103An example is the expression
1104.Ic -print Cm -o Ic -depth .
1105As
1106.Ic -print
1107always evaluates to true, the standard order of evaluation
1108implies that
1109.Ic -depth
1110would never be evaluated.
1111This is not the case.
1112.Pp
1113The operator
1114.Cm -or
1115was implemented as
1116.Cm -o ,
1117and the operator
1118.Cm -and
1119was implemented as
1120.Cm -a .
1121.Pp
1122Historic implementations of the
1123.Ic -exec
1124and
1125.Ic -ok
1126primaries did not replace the string
1127.Dq Li {}
1128in the utility name or the
1129utility arguments if it had preceding or following non-whitespace characters.
1130This version replaces it no matter where in the utility name or arguments
1131it appears.
1132.Pp
1133The
1134.Fl E
1135option was inspired by the equivalent
1136.Xr grep 1
1137and
1138.Xr sed 1
1139options.
1140.Pp
1141The
1142.Ic -perm
1143primary accepts a leading slash
1144.Pq Dq Li /
1145as an alias for a leading plus
1146.Pq Dq Li +
1147for its argument as an extension of
1148.St -p1003.1-2001
1149to be compatible with GNU find.
1150.Sh HISTORY
1151A simple
1152.Nm
1153command appeared in
1154.At v1
1155and was removed in
1156.At v3 .
1157It was rewritten for
1158.At v5
1159and later be enhanced for the Programmer's Workbench (PWB).
1160These changes were later incorporated in
1161.At v7 .
1162.Sh BUGS
1163The special characters used by
1164.Nm
1165are also special characters to many shell programs.
1166In particular, the characters
1167.Dq Li * ,
1168.Dq Li \&[ ,
1169.Dq Li \&] ,
1170.Dq Li \&? ,
1171.Dq Li \&( ,
1172.Dq Li \&) ,
1173.Dq Li \&! ,
1174.Dq Li \e
1175and
1176.Dq Li \&;
1177may have to be escaped from the shell.
1178.Pp
1179As there is no delimiter separating options and file names or file
1180names and the
1181.Ar expression ,
1182it is difficult to specify files named
1183.Pa -xdev
1184or
1185.Pa \&! .
1186These problems are handled by the
1187.Fl f
1188option and the
1189.Xr getopt 3
1190.Dq Fl Fl
1191construct.
1192.Pp
1193The
1194.Ic -delete
1195primary does not interact well with other options that cause the file system
1196tree traversal options to be changed.
1197.Pp
1198The
1199.Ic -mindepth
1200and
1201.Ic -maxdepth
1202primaries are actually global options (as documented above).
1203They should
1204probably be replaced by options which look like options.
1205