Skip to content
Surf Wiki
Save to docs
general/gnu-project-software

From Surf Wiki (app.surf) — the open knowledge base

Less (Unix)

Terminal pager


Terminal pager

FieldValue
nameless
screenshotLess.PNG
caption`less` output in an x-terminal
developerMark Nudelman
released
latest release versionlatest release date =
repo
programming languageC
operating systemCross-platform
genreSystem utility
licenseDual-licensed under GNU GPLv3 and a custom BSD-style license
website

less is a terminal pager program on Unix, Windows, and Unix-like systems used to view (but not change) the contents of a text file one screen at a time. It is similar to , but has the extended capability of allowing both forward and backward navigation through the file. Unlike most Unix text editors/viewers, does not need to read the entire file before starting, allowing for immediate viewing regardless of file size.

History

Mark Nudelman initially wrote less during 1983–85, in the need of a version of more able to do backward scrolling of the displayed text. The name came from the joke of doing "backwards more." Originally, less was developed for Unix, but it has been ported to a number of other operating systems, including MS-DOS, Microsoft Windows, OS/2, and OS-9, as well as Unix-like systems such as Linux. It is still maintained today by Nudelman.

To help remember the difference between less and more, a common joke is to say, "," implying that less has greater functionality than . A similar saying is that "less is more, more or less".

Usage

can be invoked with options to change its behaviour, for example, the number of lines to display on the screen. A few options vary depending on the operating system. While is displaying the file, various commands can be used to navigate through the file. These commands are based on those used by both and . It is also possible to search for character patterns in the file.

By default, displays the contents of the file to the standard output (one screen at a time). If the file name argument is omitted, it displays the contents from standard input (usually the output of another command through a pipe). If the output is redirected to anything other than a terminal, for example a pipe to another command, behaves like .

The "lesspipe" extension can automatically determine file types such as PDF, multimedia, and compressed archives, and automatically determines which program to launch display the file's information with, such as text from a PDF file, metadata of photos, lists of files in a compressed archive, and content of a single file in a compressed archive.

The command-syntax is:

less [options] [file_name]…

Frequently used options

  • -g: Highlight just the current match of any searched string.
  • -i: Search case-insensitively.
  • -m: Show more detailed prompt, including file position.
  • -N: Show line numbers (useful for viewing source code).
  • -x3: Set tabstops (the number of columns per hard tab character) to the specified number (3, in this example) (useful for viewing source code).
  • -S: Disable line wrapping ("chop long lines"). Long lines can be seen by side-scrolling.
  • -X: Leave file contents on screen when less exits.
  • -?: Show help.
  • --follow-name: Follow mode, for log files that get replaced while being viewed.

Frequently used commands

KeyCommandoror {{Key pressor``````````````or
Next Page
Next half Page
Previous Page
Previous half Page
Edit Content
Next Line
Previous Line
Top of file
End of file
Follow Mode (for expanding logs or pipes). Interrupt (or from v581 ) to abort.
First Line
Last Line
Line ``
Forward Search for ``. Text is interpreted as a regex.
Backward Search like
grep-like filter
Next Search Match
Previous Search Match
Turn off Match Highlighting (see `-g` command line option)
Toggle option ``, e.g., toggles option to match case in searches
Set Mark ``
Go to Mark ``
File information
Next file
Previous file
Help. This is presented with `less`, to quit.
Quit

Examples

less -M readme.txt           # Read "readme.txt"
less +F /var/log/mail.log    # Follow mode for log
file * | less                # Easier file analysis
less -I -p void *.c          # Case insensitive search for "void" in all .c files

Memory considerations

The --buffers=n and --auto-buffers options control how much memory less may use to buffer inputs. This is most relevant when less is directly accessing a named file that is modified or deleted while less is still running, and when less is receiving data from a pipe and the data can not be randomly accessed or regenerated. On the other hand, unlimited buffering means that less will request as much memory as it is fed data, which could drive the system into using virtual memory and swapping a lot of data between RAM and disks (dramatically slowing system performance for most applications on the host), or even further into memory exhaustion where any application on the host requesting memory may have that request denied, or may crash when attempting to access memory that the OS promised but can't find when the application actually attempts to use it and a page-fault occurs.

References

References

  1. Nudelman, Mark. "less, a paginator".
  2. "Less FAQ". Greenwood Software.
  3. "lesspipe(1) — less — Debian bullseye".
  4. "lesspipe(1)".
  5. (7 April 2021). "Less version 581". Greenwood Software.
Info: Wikipedia Source

This article was imported from Wikipedia and is available under the Creative Commons Attribution-ShareAlike 4.0 License. Content has been adapted to SurfDoc format. Original contributors can be found on the article history page.

Want to explore this topic further?

Ask Mako anything about Less (Unix) — get instant answers, deeper analysis, and related topics.

Research with Mako

Free with your Surf account

Content sourced from Wikipedia, available under CC BY-SA 4.0.

This content may have been generated or modified by AI. CloudSurf Software LLC is not responsible for the accuracy, completeness, or reliability of AI-generated content. Always verify important information from primary sources.

Report