history explained

history
Developer:Various open-source and commercial developers
Operating System:Unix, Unix-like, PTS-DOS, Windows, ReactOS, KolibriOS
Genre:Command

In computing, various shells maintain a record of the commands issued by the user during the current session. The history command works with the command history list. When the command is issued with no options, it prints the history list. Users can supply options and arguments to the command to manipulate the display of the history list and its entries. The operation of the history command can also be influenced by a shell's environment variables. For example, an environment variable can be set to control the number of commands to retain in the list.[1]

History

In early versions of Unix the history command was a separate program. However, most shells have long included the history command as a shell built-in, so the separate program is no longer in common use.

Implementations

The command is available in various Unix shells, as well as in PowerShell, ReactOS,[2] and KolibriOS.[3] It is also included as external command in PTS-DOS where it keeps a resident part, sometimes in conventional memory.[4]

Since most current history commands are shell built-ins, details depend on the choice of shell.

bash

The history command has the following syntax in bash:[5]

history [-c] [-d offset] [n] history -awrn [filename] history -ps arg [arg...]

tcsh

The history command has the following syntax in tcsh:

history ['''-hTr'''] [n] history -S|-L|-M [filename] (+) history -c (+)

The first form prints the history event list. If n is given only the n most recent events are printed or saved. With -h, the history list is printed without leading numbers. If -T is specified, timestamps are printed also in comment form. (This can be used to produce files suitable for loading with 'history -L' or 'source -h'.) With -r, the order of printing is most recent first rather than oldest first.

With -S, the second form saves the history list to filename. If the first word of the savehist shell variable is set to a number, at most that many lines are saved. If the second word of savehist is set to `merge', the history list is merged with the existing history file instead of replacing it (if there is one) and sorted by time stamp. (+) Merging is intended for an environment like the X Window System with several shells in simultaneous use. Currently it succeeds only when the shells quit nicely one after another.

With -L, the shell appends filename, which is presumably a history list saved by the -S option or the savehist mechanism, to the history list. -M is like -L, but the contents of filename are merged into the history list and sorted by timestamp. In either case, histfile is used if filename is not given and ~/.history is used if histfile is unset. `history -L' is exactly like 'source -h' except that it does not require a filename.

Note that login shells do the equivalent of `history -L' on startup and, if savehist is set, `history -S' before exiting. Because only ~/.tcshrc is normally sourced before ~/.history, histfile should be set in ~/.tcshrc rather than ~/.login.

If histlit is set, the first and second forms print and save the literal (unexpanded) form of the history list.

The last form clears the history list.

PowerShell

In PowerShell, history is a predefined command alias for the Get-History cmdlet. In addition, PowerShell includes the Add-History, Clear-History, Get-History, and Invoke-History cmdlets. The *-History cmdlets serve the same purpose as the Unix-like history command.

Get-History -Id ] -Count ] [<CommonParameters>] Add-History -InputObject ] [-Passthru] [<CommonParameters>] Clear-History -Id ] -Count ] [-Newest] [-Confirm] [-WhatIf] [<CommonParameters>] Clear-History -Count ] [-CommandLine <String[]>] [-Newest] [-Confirm] [-WhatIf] [<CommonParameters>] Invoke-History -Id ] [-Confirm] [-WhatIf] [<CommonParameters>]

ReactOS Command Prompt

The history command of the ReactOS Command Prompt currently only supports printing the history list.

See also

Further reading

Notes and References

  1. Web site: Using "History" to Repeat Commands. University of Washington. 25 July 2013.
  2. Web site: Reactos/Reactos. GitHub. 3 November 2021.
  3. Web site: Shell - KolibriOS wiki.
  4. Web site: PTS-DOS 2000 Pro User Manual . . Buggingen, Germany . 1999 . 2018-05-12 . live . https://web.archive.org/web/20180512094512/http://download.paragon-software.com/doc/manual_dos_eng.pdf . 2018-05-12.
  5. Darwin Kernel Version 15.0.0: Sat Sep 19 15:53:46 PDT 2015