manual-page for ls:

more detailed info-page available further down.



DESCRIPTION
       List  information  about  the FILEs (the current directory by default).
       Sort entries alphabetically if none of -cftuvSUX nor --sort  is  speci-
       fied.

       Mandatory  arguments  to  long  options are mandatory for short options
       too.

       -a, --all
              do not ignore entries starting with .

       -A, --almost-all
              do not list implied . and ..

       --author
              with -l, print the author of each file

       -b, --escape
              print C-style escapes for nongraphic characters

       --block-size=SIZE
              with  -l,  scale  sizes  by  SIZE  when  printing  them;   e.g.,
              '--block-size=M'; see SIZE format below

       -B, --ignore-backups
              do not list implied entries ending with ~

       -c     with -lt: sort by, and show, ctime (time of last modification of
              file status information); with -l: show ctime and sort by  name;
              otherwise: sort by ctime, newest first

       -C     list entries by columns

       --color[=WHEN]
              colorize  the output; WHEN can be 'always' (default if omitted),
              'auto', or 'never'; more info below

       -d, --directory
              list directories themselves, not their contents

       -D, --dired
              generate output designed for Emacs' dired mode

       -f     do not sort, enable -aU, disable -ls --color

       -F, --classify
              append indicator (one of */=>@|) to entries

       --file-type
              likewise, except do not append '*'


       -G, --no-group
              in a long listing, don't print group names

       -h, --human-readable
              with -l and -s, print sizes like 1K 234M 2G etc.

       --si   likewise, but use powers of 1000 not 1024

       -H, --dereference-command-line
              follow symbolic links listed on the command line

       --dereference-command-line-symlink-to-dir
              follow each command line symbolic link

              that points to a directory

       --hide=PATTERN
              do not list implied entries matching shell  PATTERN  (overridden
              by -a or -A)

       --hyperlink[=WHEN]
              hyperlink file names; WHEN can be 'always' (default if omitted),
              'auto', or 'never'

       --indicator-style=WORD
              append indicator with style WORD to entry names: none (default),
              slash (-p), file-type (--file-type), classify (-F)

       -i, --inode
              print the index number of each file

       -I, --ignore=PATTERN
              do not list implied entries matching shell PATTERN

       -k, --kibibytes
              default  to  1024-byte  blocks for disk usage; used only with -s
              and per directory totals

       -l     use a long listing format

       -L, --dereference
              when showing file information for a symbolic link, show informa-
              tion  for  the file the link references rather than for the link
              itself

       -m     fill width with a comma separated list of entries

       -n, --numeric-uid-gid
              like -l, but list numeric user and group IDs

       -N, --literal
       -Q, --quote-name
              enclose entry names in double quotes

       --quoting-style=WORD
              use  quoting style WORD for entry names: literal, locale, shell,
              shell-always,  shell-escape,  shell-escape-always,   c,   escape
              (overrides QUOTING_STYLE environment variable)

       -r, --reverse
              reverse order while sorting

       -R, --recursive
              list subdirectories recursively

       -s, --size
              print the allocated size of each file, in blocks

       -S     sort by file size, largest first

       --sort=WORD
              sort  by  WORD instead of name: none (-U), size (-S), time (-t),
              version (-v), extension (-X)

       --time=WORD
              with -l, show time as WORD instead of default modification time:
              atime  or  access  or  use  (-u); ctime or status (-c); also use
              specified time as sort key if --sort=time (newest first)

       --time-style=TIME_STYLE
              time/date format with -l; see TIME_STYLE below

       -t     sort by modification time, newest first

       -T, --tabsize=COLS
              assume tab stops at each COLS instead of 8

       -u     with -lt: sort by, and show, access time; with -l:  show  access
              time  and  sort  by name; otherwise: sort by access time, newest
              first

       -U     do not sort; list entries in directory order

       -v     natural sort of (version) numbers within text

       -w, --width=COLS
              set output width to COLS.  0 means no limit

       -x     list entries by lines instead of by columns

       -X     sort alphabetically by entry extension

       -Z, --context
       +FORMAT.   FORMAT  is  interpreted  like in date(1).  If FORMAT is FOR-
       MAT1<newline>FORMAT2, then FORMAT1 applies to non-recent files and FOR-
       MAT2  to  recent files.  TIME_STYLE prefixed with 'posix-' takes effect
       only outside the POSIX locale.  Also the TIME_STYLE  environment  vari-
       able sets the default style to use.

       Using  color  to distinguish file types is disabled both by default and
       with --color=never.  With --color=auto, ls emits color codes only  when
       standard  output is connected to a terminal.  The LS_COLORS environment
       variable can change the settings.  Use the dircolors command to set it.

   Exit status:
       0      if OK,

       1      if minor problems (e.g., cannot access subdirectory),

       2      if serious trouble (e.g., cannot access command-line argument).

AUTHOR
       Written by Richard M. Stallman and David MacKenzie.

REPORTING BUGS
       GNU coreutils online help: <https://www.gnu.org/software/coreutils/>
       Report ls translation bugs to <https://translationproject.org/team/>

COPYRIGHT
       Copyright © 2018 Free Software Foundation, Inc.   License  GPLv3+:  GNU
       GPL version 3 or later <https://gnu.org/licenses/gpl.html>.
       This  is  free  software:  you  are free to change and redistribute it.
       There is NO WARRANTY, to the extent permitted by law.

SEE ALSO
       Full documentation at: <https://www.gnu.org/software/coreutils/ls>
       or available locally via: info '(coreutils) ls invocation'

GNU coreutils 8.30              September 2019                           LS(1)

Man(1) output converted with man2html

info-page for ls:


as usual.

   For non-option command-line arguments that are directories, by
default 'ls' lists the contents of directories, not recursively, and
omitting files with names beginning with '.'.  For other non-option
arguments, by default 'ls' lists just the file name.  If no non-option
argument is specified, 'ls' operates on the current directory, acting as
if it had been invoked with a single argument of '.'.

   By default, the output is sorted alphabetically, according to the
locale settings in effect.(1)  If standard output is a terminal, the
output is in columns (sorted vertically) and control characters are
output as question marks; otherwise, the output is listed one per line
and control characters are output as-is.

   Because 'ls' is such a fundamental program, it has accumulated many
options over the years.  They are described in the subsections below;
within each section, options are listed alphabetically (ignoring case).
The division of options into the subsections is not absolute, since some
options affect more than one aspect of 'ls''s operation.

   Exit status:

     0 success
     1 minor problems  (e.g., failure to access a file or directory not
       specified as a command line argument.  This happens when listing a
       directory in which entries are actively being removed or renamed.)
     2 serious trouble (e.g., memory exhausted, invalid option, failure
       to access a file or directory specified as a command line argument
       or a directory loop)

   Also see *note Common options::.

* Menu:

* Which files are listed::
* What information is listed::
* Sorting the output::
* Details about version sort::
* General output formatting::
* Formatting file timestamps::
* Formatting the file names::

   ---------- Footnotes ----------

   (1) If you use a non-POSIX locale (e.g., by setting 'LC_ALL' to
'en_US'), then 'ls' may produce output that is sorted differently than
you're accustomed to.  In that case, set the 'LC_ALL' environment
variable to 'C'.

File: coreutils.info,  Node: Which files are listed,  Next: What information is listed,  Up: ls invocation

     In directories, do not ignore all file names that start with '.';
     ignore only '.' and '..'.  The '--all' ('-a') option overrides this
     option.

'-B'
'--ignore-backups'
     In directories, ignore files that end with '~'.  This option is
     equivalent to '--ignore='*~' --ignore='.*~''.

'-d'
'--directory'
     List just the names of directories, as with other types of files,
     rather than listing their contents.  Do not follow symbolic links
     listed on the command line unless the '--dereference-command-line'
     ('-H'), '--dereference' ('-L'), or
     '--dereference-command-line-symlink-to-dir' options are specified.

'-H'
'--dereference-command-line'
     If a command line argument specifies a symbolic link, show
     information for the file the link references rather than for the
     link itself.

'--dereference-command-line-symlink-to-dir'
     Do not dereference symbolic links, with one exception: if a command
     line argument specifies a symbolic link that refers to a directory,
     show information for that directory rather than for the link
     itself.  This is the default behavior when no other
     dereferencing-related option has been specified ('--classify'
     ('-F'), '--directory' ('-d'), ('-l'), '--dereference' ('-L'), or
     '--dereference-command-line' ('-H')).

'--group-directories-first'
     Group all the directories before the files and then sort the
     directories and the files separately using the selected sort key
     (see -sort option).  That is, this option specifies a primary sort
     key, and the -sort option specifies a secondary key.  However, any
     use of '--sort=none' ('-U') disables this option altogether.

'--hide=PATTERN'
     In directories, ignore files whose names match the shell pattern
     PATTERN, unless the '--all' ('-a') or '--almost-all' ('-A') is also
     given.  This option acts like '--ignore=PATTERN' except that it has
     no effect if '--all' ('-a') or '--almost-all' ('-A') is also given.

     This option can be useful in shell aliases.  For example, if 'lx'
     is an alias for 'ls --hide='*~'' and 'ly' is an alias for 'ls
     --ignore='*~'', then the command 'lx -A' lists the file 'README~'
     even though 'ly -A' would not.

'-I PATTERN'
'--ignore=PATTERN'
     When showing file information for a symbolic link, show information
     for the file the link references rather than the link itself.
     However, even with this option, 'ls' still prints the name of the
     link itself, not the name of the file that the link points to.

'-R'
'--recursive'
     List the contents of all directories recursively.

File: coreutils.info,  Node: What information is listed,  Next: Sorting the output,  Prev: Which files are listed,  Up: ls invocation

10.1.2 What information is listed
---------------------------------

These options affect the information that 'ls' displays.  By default,
only file names are shown.

'--author'
     List each file's author when producing long format directory
     listings.  In GNU/Hurd, file authors can differ from their owners,
     but in other operating systems the two are the same.

'-D'
'--dired'
     With the long listing ('-l') format, print an additional line after
     the main output:

          //DIRED// BEG1 END1 BEG2 END2 ...

     The BEGN and ENDN are unsigned integers that record the byte
     position of the beginning and end of each file name in the output.
     This makes it easy for Emacs to find the names, even when they
     contain unusual characters such as space or newline, without fancy
     searching.

     If directories are being listed recursively ('-R'), output a
     similar line with offsets for each subdirectory name:

          //SUBDIRED// BEG1 END1 ...

     Finally, output a line of the form:

          //DIRED-OPTIONS// --quoting-style=WORD

     where WORD is the quoting style (*note Formatting the file
     names::).

     Here is an actual example:

          $ mkdir -p a/sub/deeper a/sub2
          $ touch a/f1 a/f2
          $ touch a/sub/deeper/file
            -rw-r--r-- 1 0 Jun 10 12:27 file

            a/sub2:
            total 0
          //DIRED// 48 50 84 86 120 123 158 162 217 223 282 286
          //SUBDIRED// 2 3 167 172 228 240 290 296
          //DIRED-OPTIONS// --quoting-style=literal

     Note that the pairs of offsets on the '//DIRED//' line above
     delimit these names: 'f1', 'f2', 'sub', 'sub2', 'deeper', 'file'.
     The offsets on the '//SUBDIRED//' line delimit the following
     directory names: 'a', 'a/sub', 'a/sub/deeper', 'a/sub2'.

     Here is an example of how to extract the fifth entry name,
     'deeper', corresponding to the pair of offsets, 222 and 228:

          $ ls -gloRF --dired a > out
          $ dd bs=1 skip=222 count=6 < out 2>/dev/null; echo
          deeper

     Note that although the listing above includes a trailing slash for
     the 'deeper' entry, the offsets select the name without the
     trailing slash.  However, if you invoke 'ls' with '--dired' along
     with an option like '--escape' (aka '-b') and operate on a file
     whose name contains special characters, notice that the backslash
     _is_ included:

          $ touch 'a b'
          $ ls -blog --dired 'a b'
            -rw-r--r-- 1 0 Jun 10 12:28 a\ b
          //DIRED// 30 34
          //DIRED-OPTIONS// --quoting-style=escape

     If you use a quoting style that adds quote marks (e.g.,
     '--quoting-style=c'), then the offsets include the quote marks.  So
     beware that the user may select the quoting style via the
     environment variable 'QUOTING_STYLE'.  Hence, applications using
     '--dired' should either specify an explicit
     '--quoting-style=literal' option (aka '-N' or '--literal') on the
     command line, or else be prepared to parse the escaped names.

'--full-time'
     Produce long format directory listings, and list times in full.  It
     is equivalent to using '--format=long' with '--time-style=full-iso'
     (*note Formatting file timestamps::).

'-g'
     Produce long format directory listings, but don't display owner
     information.

'-G'
'--no-group'
     index number) of each file to the left of the file name.  (This
     number uniquely identifies each file within a particular file
     system.)

'-l'
'--format=long'
'--format=verbose'
     In addition to the name of each file, print the file type, file
     mode bits, number of hard links, owner name, group name, size, and
     timestamp (*note Formatting file timestamps::), normally the
     modification timestamp (the mtime, *note File timestamps::).  Print
     question marks for information that cannot be determined.

     Normally the size is printed as a byte count without punctuation,
     but this can be overridden (*note Block size::).  For example, '-h'
     prints an abbreviated, human-readable count, and
     '--block-size="'1"' prints a byte count with the thousands
     separator of the current locale.

     For each directory that is listed, preface the files with a line
     'total BLOCKS', where BLOCKS is the total disk allocation for all
     files in that directory.  The block size currently defaults to 1024
     bytes, but this can be overridden (*note Block size::).  The BLOCKS
     computed counts each hard link separately; this is arguably a
     deficiency.

     The file type is one of the following characters:

     '-'
          regular file
     'b'
          block special file
     'c'
          character special file
     'C'
          high performance ("contiguous data") file
     'd'
          directory
     'D'
          door (Solaris 2.5 and up)
     'l'
          symbolic link
     'M'
          off-line ("migrated") file (Cray DMF)
     'n'
          network special file (HP-UX)
     'p'
          FIFO (named pipe)
     'P'
          port (Solaris 10 and up)
     's'
          socket
          corresponding executable bit is not set.

     't'
          If the restricted deletion flag or sticky bit, and the
          other-executable bit, are both set.  The restricted deletion
          flag is another name for the sticky bit.  *Note Mode
          Structure::.

     'T'
          If the restricted deletion flag or sticky bit is set but the
          other-executable bit is not set.

     'x'
          If the executable bit is set and none of the above apply.

     '-'
          Otherwise.

     Following the file mode bits is a single character that specifies
     whether an alternate access method such as an access control list
     applies to the file.  When the character following the file mode
     bits is a space, there is no alternate access method.  When it is a
     printing character, then there is such a method.

     GNU 'ls' uses a '.' character to indicate a file with a security
     context, but no other alternate access method.

     A file with any other combination of alternate access methods is
     marked with a '+' character.

'-n'
'--numeric-uid-gid'
     Produce long format directory listings, but display numeric user
     and group IDs instead of the owner and group names.

'-o'
     Produce long format directory listings, but don't display group
     information.  It is equivalent to using '--format=long' with
     '--no-group' .

'-s'
'--size'
     Print the disk allocation of each file to the left of the file
     name.  This is the amount of disk space used by the file, which is
     usually a bit more than the file's size, but it can be less if the
     file has holes.

     Normally the disk allocation is printed in units of 1024 bytes, but
     this can be overridden (*note Block size::).

     For files that are NFS-mounted from an HP-UX system to a BSD
     system, this option reports sizes that are half the correct values.
     used with the '-l' option, print the security context to the left
     of the size column.

File: coreutils.info,  Node: Sorting the output,  Next: Details about version sort,  Prev: What information is listed,  Up: ls invocation

10.1.3 Sorting the output
-------------------------

These options change the order in which 'ls' sorts the information it
outputs.  By default, sorting is done by character code (e.g., ASCII
order).

'-c'
'--time=ctime'
'--time=status'
     If the long listing format (e.g., '-l', '-o') is being used, print
     the status change timestamp (the ctime) instead of the mtime.  When
     explicitly sorting by time ('--sort=time' or '-t') or when not
     using a long listing format, sort according to the ctime.  *Note
     File timestamps::.

'-f'
     Primarily, like '-U'--do not sort; list the files in whatever order
     they are stored in the directory.  But also enable '-a' (list all
     files) and disable '-l', '--color', and '-s' (if they were
     specified before the '-f').

'-r'
'--reverse'
     Reverse whatever the sorting method is--e.g., list files in reverse
     alphabetical order, youngest first, smallest first, or whatever.

'-S'
'--sort=size'
     Sort by file size, largest first.

'-t'
'--sort=time'
     Sort by modification timestamp (mtime), newest first.  *Note File
     timestamps::.

'-u'
'--time=atime'
'--time=access'
'--time=use'
     If the long listing format (e.g., '--format=long') is being used,
     print the last access timestamp (the atime).  When explicitly
     sorting by time ('--sort=time' or '-t') or when not using a long
     listing format, sort according to the atime.  *Note File
     timestamps::.

'-U'
'--sort=extension'
     Sort directory contents alphabetically by file extension
     (characters after the last '.'); files with no extension are sorted
     first.

File: coreutils.info,  Node: Details about version sort,  Next: General output formatting,  Prev: Sorting the output,  Up: ls invocation

10.1.4 Details about version sort
---------------------------------

Version sorting handles the fact that file names frequently include
indices or version numbers.  Standard sorting usually does not produce
the order that one expects because comparisons are made on a
character-by-character basis.  Version sorting is especially useful when
browsing directories that contain many files with indices/version
numbers in their names:

     $ ls -1            $ ls -1v
     abc.zml-1.gz       abc.zml-1.gz
     abc.zml-12.gz      abc.zml-2.gz
     abc.zml-2.gz       abc.zml-12.gz

   Version-sorted strings are compared such that if VER1 and VER2 are
version numbers and PREFIX and SUFFIX (SUFFIX matching the regular
expression '(\.[A-Za-z~][A-Za-z0-9~]*)*') are strings then VER1 < VER2
implies that the name composed of "PREFIX VER1 SUFFIX" sorts before
"PREFIX VER2 SUFFIX".

   Note also that leading zeros of numeric parts are ignored:

     $ ls -1            $ ls -1v
     abc-1.007.tgz      abc-1.01a.tgz
     abc-1.012b.tgz     abc-1.007.tgz
     abc-1.01a.tgz      abc-1.012b.tgz

   This functionality is implemented using gnulib's 'filevercmp'
function, which has some caveats worth noting.

   * 'LC_COLLATE' is ignored, which means 'ls -v' and 'sort -V' will
     sort non-numeric prefixes as if the 'LC_COLLATE' locale category
     was set to 'C'.
   * Some suffixes will not be matched by the regular expression
     mentioned above.  Consequently these examples may not sort as you
     expect:

          abc-1.2.3.4.7z
          abc-1.2.3.7z

          abc-1.2.3.4.x86_64.rpm
          abc-1.2.3.x86_64.rpm

File: coreutils.info,  Node: General output formatting,  Next: Formatting file timestamps,  Prev: Details about version sort,  Up: ls invocation
     List files in columns, sorted vertically.  This is the default for
     'ls' if standard output is a terminal.  It is always the default
     for the 'dir' program.  GNU 'ls' uses variable width columns to
     display as many files as possible in the fewest lines.

'--color [=WHEN]'
     Specify whether to use color for distinguishing file types.  WHEN
     may be omitted, or one of:
        * none - Do not use color at all.  This is the default.
        * auto - Only use color if standard output is a terminal.
        * always - Always use color.
     Specifying '--color' and no WHEN is equivalent to '--color=always'.
     If piping a colorized listing through a pager like 'less', use the
     '-R' option to pass the color codes to the terminal.

     Note that using the '--color' option may incur a noticeable
     performance penalty when run in a directory with very many entries,
     because the default settings require that 'ls' 'stat' every single
     file it lists.  However, if you would like most of the file-type
     coloring but can live without the other coloring options (e.g.,
     executable, orphan, sticky, other-writable, capability), use
     'dircolors' to set the 'LS_COLORS' environment variable like this,
          eval $(dircolors -p | perl -pe \
            's/^((CAP|S[ET]|O[TR]|M|E)\w+).*/$1 00/' | dircolors -)
     and on a 'dirent.d_type'-capable file system, 'ls' will perform
     only one 'stat' call per command line argument.

'-F'
'--classify'
'--indicator-style=classify'
     Append a character to each file name indicating the file type.
     Also, for regular files that are executable, append '*'.  The file
     type indicators are '/' for directories, '@' for symbolic links,
     '|' for FIFOs, '=' for sockets, '>' for doors, and nothing for
     regular files.  Do not follow symbolic links listed on the command
     line unless the '--dereference-command-line' ('-H'),
     '--dereference' ('-L'), or
     '--dereference-command-line-symlink-to-dir' options are specified.

'--file-type'
'--indicator-style=file-type'
     Append a character to each file name indicating the file type.
     This is like '-F', except that executables are not marked.

'--hyperlink [=WHEN]'
     Output codes recognized by some terminals to link to files using
     the 'file://' URI format.  WHEN may be omitted, or one of:
        * none - Do not use hyperlinks at all.  This is the default.
        * auto - Only use hyperlinks if standard output is a terminal.
        * always - Always use hyperlinks.
     Specifying '--hyperlink' and no WHEN is equivalent to
     '--hyperlink=always'.
     'classify'
          Append '*' for executable regular files, otherwise behave as
          for 'file-type'.  This is the same as the '-F' or '--classify'
          option.

'-k'
'--kibibytes'
     Set the default block size to its normal value of 1024 bytes,
     overriding any contrary specification in environment variables
     (*note Block size::).  This option is in turn overridden by the
     '--block-size', '-h' or '--human-readable', and '--si' options.

     The '-k' or '--kibibytes' option affects the per-directory block
     count written by the '-l' and similar options, and the size written
     by the '-s' or '--size' option.  It does not affect the file size
     written by '-l'.

'-m'
'--format=commas'
     List files horizontally, with as many as will fit on each line,
     separated by ', ' (a comma and a space).

'-p'
'--indicator-style=slash'
     Append a '/' to directory names.

'-x'
'--format=across'
'--format=horizontal'
     List the files in columns, sorted horizontally.

'-T COLS'
'--tabsize=COLS'
     Assume that each tab stop is COLS columns wide.  The default is 8.
     'ls' uses tabs where possible in the output, for efficiency.  If
     COLS is zero, do not use tabs at all.

     Some terminal emulators might not properly align columns to the
     right of a TAB following a non-ASCII byte.  You can avoid that
     issue by using the '-T0' option or put 'TABSIZE=0' in your
     environment, to tell 'ls' to align using spaces, not tabs.

'-w COLS'
'--width=COLS'
     Assume the screen is COLS columns wide.  The default is taken from
     the terminal settings if possible; otherwise the environment
     variable 'COLUMNS' is used if it is set; otherwise the default is
     80.  With a COLS value of '0', there is no limit on the length of
     the output line, and that single output line will be delimited with
     spaces, not tabs.

File: coreutils.info,  Node: Formatting file timestamps,  Next: Formatting the file names,  Prev: General output formatting,  Up: ls invocation

   Timestamps are listed according to the time zone rules specified by
the 'TZ' environment variable, or by the system default rules if 'TZ' is
not set.  *Note Specifying the Time Zone with 'TZ': (libc)TZ Variable.

   The following option changes how file timestamps are printed.

'--time-style=STYLE'
     List timestamps in style STYLE.  The STYLE should be one of the
     following:

     '+FORMAT'
          List timestamps using FORMAT, where FORMAT is interpreted like
          the format argument of 'date' (*note date invocation::).  For
          example, '--time-style="+%Y-%m-%d %H:%M:%S"' causes 'ls' to
          list timestamps like '2002-03-30 23:45:56'.  As with 'date',
          FORMAT's interpretation is affected by the 'LC_TIME' locale
          category.

          If FORMAT contains two format strings separated by a newline,
          the former is used for non-recent files and the latter for
          recent files; if you want output columns to line up, you may
          need to insert spaces in one of the two formats.

     'full-iso'
          List timestamps in full using ISO 8601-like date, time, and
          time zone components with nanosecond precision, e.g.,
          '2002-03-30 23:45:56.477817180 -0700'.  This style is
          equivalent to '+%Y-%m-%d %H:%M:%S.%N %z'.

          This is useful because the time output includes all the
          information that is available from the operating system.  For
          example, this can help explain 'make''s behavior, since GNU
          'make' uses the full timestamp to determine whether a file is
          out of date.

     'long-iso'
          List ISO 8601 date and time components with minute precision,
          e.g., '2002-03-30 23:45'.  These timestamps are shorter than
          'full-iso' timestamps, and are usually good enough for
          everyday work.  This style is equivalent to '+%Y-%m-%d %H:%M'.

     'iso'
          List ISO 8601 dates for non-recent timestamps (e.g.,
          '2002-03-30 '), and ISO 8601-like month, day, hour, and minute
          for recent timestamps (e.g., '03-30 23:45').  These timestamps
          are uglier than 'long-iso' timestamps, but they carry nearly
          the same information in a smaller space and their brevity
          helps 'ls' output fit within traditional 80-column output
          lines.  The following two 'ls' invocations are equivalent:

               newline='

          The default POSIX locale uses timestamps like 'Mar 30  2002'
          and 'Mar 30 23:45'; in this locale, the following two 'ls'
          invocations are equivalent:

               newline='
               '
               ls -l --time-style="+%b %e  %Y$newline%b %e %H:%M"
               ls -l --time-style="locale"

          Other locales behave differently.  For example, in a German
          locale, '--time-style="locale"' might be equivalent to
          '--time-style="+%e. %b %Y $newline%e. %b %H:%M"' and might
          generate timestamps like '30. Mär 2002 ' and '30. Mär 23:45'.

     'posix-STYLE'
          List POSIX-locale timestamps if the 'LC_TIME' locale category
          is POSIX, STYLE timestamps otherwise.  For example, the
          'posix-long-iso' style lists timestamps like 'Mar 30  2002'
          and 'Mar 30 23:45' when in the POSIX locale, and like
          '2002-03-30 23:45' otherwise.

   You can specify the default value of the '--time-style' option with
the environment variable 'TIME_STYLE'; if 'TIME_STYLE' is not set the
default style is 'locale'.  GNU Emacs 21.3 and later use the '--dired'
option and therefore can parse any date format, but if you are using
Emacs 21.1 or 21.2 and specify a non-POSIX locale you may need to set
'TIME_STYLE="posix-long-iso"'.

   To avoid certain denial-of-service attacks, timestamps that would be
longer than 1000 bytes may be treated as errors.

File: coreutils.info,  Node: Formatting the file names,  Prev: Formatting file timestamps,  Up: ls invocation

10.1.7 Formatting the file names
--------------------------------

These options change how file names themselves are printed.

'-b'
'--escape'
'--quoting-style=escape'
     Quote nongraphic characters in file names using alphabetic and
     octal backslash sequences like those used in C.

'-N'
'--literal'
'--quoting-style=literal'
     Do not quote file names.  However, with 'ls' nongraphic characters
     are still printed as question marks if the output is a terminal and
     you do not specify the '--show-control-chars' option.

'-q'
     following:

     'literal'
          Output strings as-is; this is the same as the '-N' or
          '--literal' option.
     'shell'
          Quote strings for the shell if they contain shell
          metacharacters or would cause ambiguous output.  The quoting
          is suitable for POSIX-compatible shells like 'bash', but it
          does not always work for incompatible shells like 'csh'.
     'shell-always'
          Quote strings for the shell, even if they would normally not
          require quoting.
     'shell-escape'
          Like 'shell', but also quoting non-printable characters using
          the POSIX proposed '$''' syntax suitable for most shells.
     'shell-escape-always'
          Like 'shell-escape', but quote strings even if they would
          normally not require quoting.
     'c'
          Quote strings as for C character string literals, including
          the surrounding double-quote characters; this is the same as
          the '-Q' or '--quote-name' option.
     'escape'
          Quote strings as for C character string literals, except omit
          the surrounding double-quote characters; this is the same as
          the '-b' or '--escape' option.
     'clocale'
          Quote strings as for C character string literals, except use
          surrounding quotation marks appropriate for the locale.
     'locale'
          Quote strings as for C character string literals, except use
          surrounding quotation marks appropriate for the locale, and
          quote 'like this' instead of "like this" in the default C
          locale.  This looks nicer on many displays.

     You can specify the default value of the '--quoting-style' option
     with the environment variable 'QUOTING_STYLE'.  If that environment
     variable is not set, the default value is 'shell-escape' when the
     output is a terminal, and 'literal' otherwise.

'--show-control-chars'
     Print nongraphic characters as-is in file names.  This is the
     default unless the output is a terminal and the program is 'ls'.


Man(1) output converted with man2html