xref: /freebsd/bin/ls/ls.1 (revision 3157ba21)
1.\"-
2.\" Copyright (c) 1980, 1990, 1991, 1993, 1994
3.\"	The Regents of the University of California.  All rights reserved.
4.\"
5.\" This code is derived from software contributed to Berkeley by
6.\" the Institute of Electrical and Electronics Engineers, Inc.
7.\"
8.\" Redistribution and use in source and binary forms, with or without
9.\" modification, are permitted provided that the following conditions
10.\" are met:
11.\" 1. Redistributions of source code must retain the above copyright
12.\"    notice, this list of conditions and the following disclaimer.
13.\" 2. Redistributions in binary form must reproduce the above copyright
14.\"    notice, this list of conditions and the following disclaimer in the
15.\"    documentation and/or other materials provided with the distribution.
16.\" 4. Neither the name of the University nor the names of its contributors
17.\"    may be used to endorse or promote products derived from this software
18.\"    without specific prior written permission.
19.\"
20.\" THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
21.\" ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
22.\" IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
23.\" ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
24.\" FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
25.\" DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
26.\" OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
27.\" HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
28.\" LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
29.\" OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
30.\" SUCH DAMAGE.
31.\"
32.\"     @(#)ls.1	8.7 (Berkeley) 7/29/94
33.\" $FreeBSD$
34.\"
35.Dd April 4, 2008
36.Dt LS 1
37.Os
38.Sh NAME
39.Nm ls
40.Nd list directory contents
41.Sh SYNOPSIS
42.Nm
43.Op Fl ABCFGHILPRSTUWZabcdfghiklmnopqrstuwx1
44.Op Fl D Ar format
45.Op Ar
46.Sh DESCRIPTION
47For each operand that names a
48.Ar file
49of a type other than
50directory,
51.Nm
52displays its name as well as any requested,
53associated information.
54For each operand that names a
55.Ar file
56of type directory,
57.Nm
58displays the names of files contained
59within that directory, as well as any requested, associated
60information.
61.Pp
62If no operands are given, the contents of the current
63directory are displayed.
64If more than one operand is given,
65non-directory operands are displayed first; directory
66and non-directory operands are sorted separately and in
67lexicographical order.
68.Pp
69The following options are available:
70.Bl -tag -width indent
71.It Fl A
72Include directory entries whose names begin with a
73dot
74.Pq Sq Pa \&.
75except for
76.Pa \&.
77and
78.Pa .. .
79Automatically set for the super-user unless
80.Fl I
81is specified.
82.It Fl B
83Force printing of non-printable characters (as defined by
84.Xr ctype 3
85and current locale settings) in file names as
86.Li \e Ns Va xxx ,
87where
88.Va xxx
89is the numeric value of the character in octal.
90.It Fl C
91Force multi-column output; this is the default when output is to a terminal.
92.It Fl D Ar format
93When printing in the long
94.Pq Fl l
95format, use
96.Ar format
97to format the date and time output.
98The argument
99.Ar format
100is a string used by
101.Xr strftime 3 .
102Depending on the choice of format string, this may result in a
103different number of columns in the output.
104This option overrides the
105.Fl T
106option.
107.It Fl F
108Display a slash
109.Pq Ql /
110immediately after each pathname that is a directory,
111an asterisk
112.Pq Ql *
113after each that is executable,
114an at sign
115.Pq Ql @
116after each symbolic link,
117an equals sign
118.Pq Ql =
119after each socket,
120a percent sign
121.Pq Ql %
122after each whiteout,
123and a vertical bar
124.Pq Ql \&|
125after each that is a
126.Tn FIFO .
127.It Fl G
128Enable colorized output.
129This option is equivalent to defining
130.Ev CLICOLOR
131in the environment.
132(See below.)
133.It Fl H
134Symbolic links on the command line are followed.
135This option is assumed if
136none of the
137.Fl F , d ,
138or
139.Fl l
140options are specified.
141.It Fl I
142Prevent
143.Fl A
144from being automatically set for the super-user.
145.It Fl L
146If argument is a symbolic link, list the file or directory the link references
147rather than the link itself.
148This option cancels the
149.Fl P
150option.
151.It Fl P
152If argument is a symbolic link, list the link itself rather than the
153object the link references.
154This option cancels the
155.Fl H
156and
157.Fl L
158options.
159.It Fl R
160Recursively list subdirectories encountered.
161.It Fl S
162Sort by size (largest file first) before sorting the operands in
163lexicographical order.
164.It Fl T
165When printing in the long
166.Pq Fl l
167format, display complete time information for the file, including
168month, day, hour, minute, second, and year.
169The
170.Fl D
171option gives even more control over the output format.
172.It Fl U
173Use time when file was created for sorting or printing.
174.It Fl W
175Display whiteouts when scanning directories.
176.It Fl Z
177Display each file's MAC label; see
178.Xr maclabel 7 .
179.It Fl a
180Include directory entries whose names begin with a
181dot
182.Pq Sq Pa \&. .
183.It Fl b
184As
185.Fl B ,
186but use
187.Tn C
188escape codes whenever possible.
189.It Fl c
190Use time when file status was last changed for sorting or printing.
191.It Fl d
192Directories are listed as plain files (not searched recursively).
193.It Fl f
194Output is not sorted.
195.It Fl g
196This option is deprecated and is only available for compatibility
197with
198.Bx 4.3 ;
199it was used to display the group name in the long
200.Pq Fl l
201format output.
202.It Fl h
203When used with the
204.Fl l
205option, use unit suffixes: Byte, Kilobyte, Megabyte, Gigabyte, Terabyte
206and Petabyte in order to reduce the number of digits to four or fewer
207using base 2 for sizes.
208.It Fl i
209For each file, print the file's file serial number (inode number).
210.It Fl k
211This has the same effect as setting environment variable
212.Ev BLOCKSIZE
213to 1024, except that it also nullifies any
214.Fl h
215options to its left.
216.It Fl l
217(The lowercase letter
218.Dq ell . )
219List files in the long format, as described in the
220.Sx The Long Format
221subsection below.
222.It Fl m
223Stream output format; list files across the page, separated by commas.
224.It Fl n
225Display user and group IDs numerically rather than converting to a user
226or group name in a long
227.Pq Fl l
228output.
229.It Fl o
230Include the file flags in a long
231.Pq Fl l
232output.
233.It Fl p
234Write a slash
235.Pq Ql /
236after each filename if that file is a directory.
237.It Fl q
238Force printing of non-graphic characters in file names as
239the character
240.Ql \&? ;
241this is the default when output is to a terminal.
242.It Fl r
243Reverse the order of the sort.
244.It Fl s
245Display the number of blocks used in the file system by each file.
246Block sizes and directory totals are handled as described in
247.Sx The Long Format
248subsection below, except (if the long format is not also requested)
249the directory totals are not output when the output is in a
250single column, even if multi-column output is requested.
251.It Fl t
252Sort by time modified (most recently modified
253first) before sorting the operands in lexicographical
254order.
255.It Fl u
256Use time of last access,
257instead of last modification
258of the file for sorting
259.Pq Fl t
260or printing
261.Pq Fl l .
262.It Fl w
263Force raw printing of non-printable characters.
264This is the default
265when output is not to a terminal.
266.It Fl x
267The same as
268.Fl C ,
269except that the multi-column output is produced with entries sorted
270across, rather than down, the columns.
271.It Fl 1
272(The numeric digit
273.Dq one . )
274Force output to be
275one entry per line.
276This is the default when
277output is not to a terminal.
278.El
279.Pp
280The
281.Fl 1 , C , x ,
282and
283.Fl l
284options all override each other; the last one specified determines
285the format used.
286.Pp
287The
288.Fl c , u ,
289and
290.Fl U
291options all override each other; the last one specified determines
292the file time used.
293.Pp
294The
295.Fl S
296and
297.Fl t
298options override each other; the last one specified determines
299the sort order used.
300.Pp
301The
302.Fl B , b , w ,
303and
304.Fl q
305options all override each other; the last one specified determines
306the format used for non-printable characters.
307.Pp
308The
309.Fl H , L
310and
311.Fl P
312options all override each other (either partially or fully); they
313are applied in the order specified.
314.Pp
315By default,
316.Nm
317lists one entry per line to standard
318output; the exceptions are to terminals or when the
319.Fl C
320or
321.Fl x
322options are specified.
323.Pp
324File information is displayed with one or more
325.Ao blank Ac Ns s
326separating the information associated with the
327.Fl i , s ,
328and
329.Fl l
330options.
331.Ss The Long Format
332If the
333.Fl l
334option is given, the following information
335is displayed for each file:
336file mode,
337number of links, owner name, group name,
338MAC label,
339number of bytes in the file, abbreviated
340month, day-of-month file was last modified,
341hour file last modified, minute file last
342modified, and the pathname.
343.Pp
344If the modification time of the file is more than 6 months
345in the past or future, and the
346.Fl D
347or
348.Fl T
349are not specified,
350then the year of the last modification
351is displayed in place of the hour and minute fields.
352.Pp
353If the owner or group names are not a known user or group name,
354or the
355.Fl n
356option is given,
357the numeric ID's are displayed.
358.Pp
359If the file is a character special or block special file,
360the major and minor device numbers for the file are displayed
361in the size field.
362If the file is a symbolic link the pathname of the
363linked-to file is preceded by
364.Dq Li -> .
365.Pp
366The listing of a directory's contents is preceded
367by a labeled total number of blocks used in the file system by the files
368which are listed as the directory's contents
369(which may or may not include
370.Pa \&.
371and
372.Pa ..
373and other files which start with a dot, depending on other options).
374.Pp
375The default block size is 512 bytes.
376The block size may be set with option
377.Fl k
378or environment variable
379.Ev BLOCKSIZE .
380Numbers of blocks in the output will have been rounded up so the
381numbers of bytes is at least as many as used by the corresponding
382file system blocks (which might have a different size).
383.Pp
384The file mode printed under the
385.Fl l
386option consists of the
387entry type and the permissions.
388The entry type character describes the type of file, as
389follows:
390.Pp
391.Bl -tag -width 4n -offset indent -compact
392.It Sy \-
393Regular file.
394.It Sy b
395Block special file.
396.It Sy c
397Character special file.
398.It Sy d
399Directory.
400.It Sy l
401Symbolic link.
402.It Sy p
403.Tn FIFO .
404.It Sy s
405Socket.
406.It Sy w
407Whiteout.
408.El
409.Pp
410The next three fields
411are three characters each:
412owner permissions,
413group permissions, and
414other permissions.
415Each field has three character positions:
416.Bl -enum -offset indent
417.It
418If
419.Sy r ,
420the file is readable; if
421.Sy \- ,
422it is not readable.
423.It
424If
425.Sy w ,
426the file is writable; if
427.Sy \- ,
428it is not writable.
429.It
430The first of the following that applies:
431.Bl -tag -width 4n -offset indent
432.It Sy S
433If in the owner permissions, the file is not executable and
434set-user-ID mode is set.
435If in the group permissions, the file is not executable
436and set-group-ID mode is set.
437.It Sy s
438If in the owner permissions, the file is executable
439and set-user-ID mode is set.
440If in the group permissions, the file is executable
441and setgroup-ID mode is set.
442.It Sy x
443The file is executable or the directory is
444searchable.
445.It Sy \-
446The file is neither readable, writable, executable,
447nor set-user-ID nor set-group-ID mode, nor sticky.
448(See below.)
449.El
450.Pp
451These next two apply only to the third character in the last group
452(other permissions).
453.Bl -tag -width 4n -offset indent
454.It Sy T
455The sticky bit is set
456(mode
457.Li 1000 ) ,
458but not execute or search permission.
459(See
460.Xr chmod 1
461or
462.Xr sticky 8 . )
463.It Sy t
464The sticky bit is set (mode
465.Li 1000 ) ,
466and is searchable or executable.
467(See
468.Xr chmod 1
469or
470.Xr sticky 8 . )
471.El
472.El
473.Pp
474The next field contains a
475plus
476.Pq Ql +
477character if the file has an ACL, or a
478space
479.Pq Ql " "
480if it does not.
481The
482.Nm
483utility does not show the actual ACL;
484use
485.Xr getfacl 1
486to do this.
487.Sh ENVIRONMENT
488The following environment variables affect the execution of
489.Nm :
490.Bl -tag -width ".Ev CLICOLOR_FORCE"
491.It Ev BLOCKSIZE
492If this is set, its value, rounded up to 512 or down to a
493multiple of 512, will be used as the block size in bytes by the
494.Fl l
495and
496.Fl s
497options.
498See
499.Sx The Long Format
500subsection for more information.
501.It Ev CLICOLOR
502Use
503.Tn ANSI
504color sequences to distinguish file types.
505See
506.Ev LSCOLORS
507below.
508In addition to the file types mentioned in the
509.Fl F
510option some extra attributes (setuid bit set, etc.) are also displayed.
511The colorization is dependent on a terminal type with the proper
512.Xr termcap 5
513capabilities.
514The default
515.Dq Li cons25
516console has the proper capabilities,
517but to display the colors in an
518.Xr xterm 1 ,
519for example,
520the
521.Ev TERM
522variable must be set to
523.Dq Li xterm-color .
524Other terminal types may require similar adjustments.
525Colorization
526is silently disabled if the output is not directed to a terminal
527unless the
528.Ev CLICOLOR_FORCE
529variable is defined.
530.It Ev CLICOLOR_FORCE
531Color sequences are normally disabled if the output is not directed to
532a terminal.
533This can be overridden by setting this flag.
534The
535.Ev TERM
536variable still needs to reference a color capable terminal however
537otherwise it is not possible to determine which color sequences to
538use.
539.It Ev COLUMNS
540If this variable contains a string representing a
541decimal integer, it is used as the
542column position width for displaying
543multiple-text-column output.
544The
545.Nm
546utility calculates how
547many pathname text columns to display
548based on the width provided.
549(See
550.Fl C
551and
552.Fl x . )
553.It Ev LANG
554The locale to use when determining the order of day and month in the long
555.Fl l
556format output.
557See
558.Xr environ 7
559for more information.
560.It Ev LSCOLORS
561The value of this variable describes what color to use for which
562attribute when colors are enabled with
563.Ev CLICOLOR .
564This string is a concatenation of pairs of the format
565.Ar f Ns Ar b ,
566where
567.Ar f
568is the foreground color and
569.Ar b
570is the background color.
571.Pp
572The color designators are as follows:
573.Pp
574.Bl -tag -width 4n -offset indent -compact
575.It Sy a
576black
577.It Sy b
578red
579.It Sy c
580green
581.It Sy d
582brown
583.It Sy e
584blue
585.It Sy f
586magenta
587.It Sy g
588cyan
589.It Sy h
590light grey
591.It Sy A
592bold black, usually shows up as dark grey
593.It Sy B
594bold red
595.It Sy C
596bold green
597.It Sy D
598bold brown, usually shows up as yellow
599.It Sy E
600bold blue
601.It Sy F
602bold magenta
603.It Sy G
604bold cyan
605.It Sy H
606bold light grey; looks like bright white
607.It Sy x
608default foreground or background
609.El
610.Pp
611Note that the above are standard
612.Tn ANSI
613colors.
614The actual display may differ
615depending on the color capabilities of the terminal in use.
616.Pp
617The order of the attributes are as follows:
618.Pp
619.Bl -enum -offset indent -compact
620.It
621directory
622.It
623symbolic link
624.It
625socket
626.It
627pipe
628.It
629executable
630.It
631block special
632.It
633character special
634.It
635executable with setuid bit set
636.It
637executable with setgid bit set
638.It
639directory writable to others, with sticky bit
640.It
641directory writable to others, without sticky bit
642.El
643.Pp
644The default is
645.Qq "exfxcxdxbxegedabagacad" ,
646i.e., blue foreground and
647default background for regular directories, black foreground and red
648background for setuid executables, etc.
649.It Ev LS_COLWIDTHS
650If this variable is set, it is considered to be a
651colon-delimited list of minimum column widths.
652Unreasonable
653and insufficient widths are ignored (thus zero signifies
654a dynamically sized column).
655Not all columns have changeable widths.
656The fields are,
657in order: inode, block count, number of links, user name,
658group name, flags, file size, file name.
659.It Ev TERM
660The
661.Ev CLICOLOR
662functionality depends on a terminal type with color capabilities.
663.It Ev TZ
664The timezone to use when displaying dates.
665See
666.Xr environ 7
667for more information.
668.El
669.Sh EXIT STATUS
670.Ex -std
671.Sh COMPATIBILITY
672The group field is now automatically included in the long listing for
673files in order to be compatible with the
674.St -p1003.2
675specification.
676.Sh SEE ALSO
677.Xr chflags 1 ,
678.Xr chmod 1 ,
679.Xr getfacl 1 ,
680.Xr sort 1 ,
681.Xr xterm 1 ,
682.Xr strftime 3 ,
683.Xr strmode 3 ,
684.Xr termcap 5 ,
685.Xr maclabel 7 ,
686.Xr symlink 7 ,
687.Xr getfmac 8 ,
688.Xr sticky 8
689.Sh STANDARDS
690With the exception of options
691.Fl I , g , n
692and
693.Fl o ,
694the
695.Nm
696utility conforms to
697.St -p1003.1-2001 .
698.Pp
699The ACL support is compatible with
700.Tn IEEE
701Std\~1003.2c
702.Pq Dq Tn POSIX Ns .2c
703Draft\~17
704(withdrawn).
705.Sh HISTORY
706An
707.Nm
708command appeared in
709.At v1 .
710.Sh BUGS
711To maintain backward compatibility, the relationships between the many
712options are quite complex.
713.Pp
714The exception mentioned in the
715.Fl s
716option description might be a feature that was
717based on the fact that single-column output
718usually goes to something other than a terminal.
719It is debatable whether this is a design bug.
720