Thompson shell

Revision as of 12:43, 15 November 2024 by 104.195.238.239 (talk) (→‎History: ce: reduced verbiage. Also, added need for citation, because the statement looks partly wrong.)
(diff) ← Previous revision | Latest revision (diff) | Newer revision → (diff)

Template:Short description {{#invoke:Infobox|infobox}}Template:Template other{{#invoke:Check for unknown parameters | check | showblankpositional=1 | unknown = Template:Main other | preview = Page using Template:Infobox software with unknown parameter "_VALUE_"|ignoreblank=y | AsOf | author | background | bodystyle | caption | collapsetext | collapsible | developer | discontinued | engine | engines | genre | included with | language | language count | language footnote | latest preview date | latest preview version | latest release date | latest release version | latest_preview_date | latest_preview_version | latest_release_date | latest_release_version | licence | license | logo | logo alt | logo caption | logo upright | logo size | logo title | logo_alt | logo_caption | logo_upright | logo_size | logo_title | middleware | module | name | operating system | operating_system | other_names | platform | programming language | programming_language | released | replaced_by | replaces | repo | screenshot | screenshot alt | screenshot upright | screenshot size | screenshot title | screenshot_alt | screenshot_upright | screenshot_size | screenshot_title | service_name | size | standard | title | ver layout | website | qid }}Template:Main other The Thompson shell was the first Unix shell, introduced in the first version of Unix in 1971, and was written by Ken Thompson.<ref name=Mashey1976-10-13> Template:Cite conference </ref> It was a simple command interpreter, not designed for scripting, but nonetheless introduced several innovative features to the command-line interface and led to the development of the later Unix shells.

HistoryEdit

The name "shell" for a command-line interpreter and the concept of making the shell a user program outside of the operating system kernel were introduced in Unix's precursor Multics.

An early feature of the Thompson shell was a compact syntax for input/output redirection. In Multics, redirecting the input or output of a command required separate commands to start and stop redirection; in Unix, one could simply add an argument to the command line consisting of the < symbol followed by a filename for input or the > symbol for output, and the shell would redirect I/O for the duration of the command. This syntax was already present by the release of the first version of Unix in 1971.

A later addition was the concept of pipes. At the suggestion of Douglas McIlroy, the redirection syntax was expanded so that the output of one command could be passed to the input of another command. The original pipe syntax, as described in the Version 3 manual, was:

command1 >command2>

This syntax proved too ambiguous and was easily confused with redirection to files—the system cannot tell whether "command2" is a command or a file.Template:Citation needed By Version 4, the syntax had changed to use both the | and ^ symbols to denote pipes:

command1 | command2

This produces exactly the same result as:

command1 ^ command2

The > symbol changed into:

command1 > file1

This would put the output of command1 into file1.

The Thompson shell syntax for redirection with < and >, and piping with |, has proven durable and has been adopted by most other Unix shells and command shells of several other operating systems, most notably on DOS, OS/2 and Microsoft Windows.

DesignEdit

The shell's design was intentionally minimalistic; even the if and goto statements, essential for control of program flow, were implemented as separate commands.<ref name=Mashey1976-10-13/>

The shell has no facilities for comments besides a builtin command <syntaxhighlight lang="text" class="" style="" inline="1">:</syntaxhighlight>. Programmers simply write text after this command, which ignores all parameters and simply succeeds. Other builtins include <syntaxhighlight lang="text" class="" style="" inline="1">chdir</syntaxhighlight>, <syntaxhighlight lang="text" class="" style="" inline="1">exit</syntaxhighlight>, <syntaxhighlight lang="text" class="" style="" inline="1">login</syntaxhighlight>, <syntaxhighlight lang="text" class="" style="" inline="1">newgrp</syntaxhighlight>, <syntaxhighlight lang="text" class="" style="" inline="1">shift</syntaxhighlight>, and <syntaxhighlight lang="text" class="" style="" inline="1">wait</syntaxhighlight>.<ref name=etsh.man/>

The if command combines the uses of modern-day Bourne shell test and if. The command first looks for an expression (which can be similar to modern-day test or involve an external command) then treats the rest of the command-line as the command to execute if the condition turns out true. There is no else branch.<ref>{{#invoke:citation/CS1|citation |CitationClass=web }}</ref>

goto is implemented in an interesting way, as it is separate from the shell. When asked to jump to "LABEL", it seeks the current command file for a line that says <syntaxhighlight lang="text" class="" style="" inline="1">: LABEL</syntaxhighlight> (recall that <syntaxhighlight lang="text" class="" style="" inline="1">:</syntaxhighlight> is simply ignored), then exits. When the shell tries to read a next line, the repositioned file descriptor will direct it to the labelled location.<ref>{{#invoke:citation/CS1|citation |CitationClass=web }}</ref>

There is no redirection of additional file descriptors other than standard input and output (0 and 1) in Thompson shell. Redirection of stderr (file descriptor 2) also requires an external program wrapper, <syntaxhighlight lang="text" class="" style="" inline="1">fd2</syntaxhighlight>.<ref>{{#invoke:citation/CS1|citation |CitationClass=web }}</ref>

The shell supports globbing,<ref name=etsh.man>{{#invoke:citation/CS1|citation |CitationClass=web }}</ref> but actually implements it by deferring it to a <syntaxhighlight lang="text" class="" style="" inline="1">glob</syntaxhighlight> command that replaces the arguments and calls the requested command.<ref>{{#invoke:citation/CS1|citation |CitationClass=web }}</ref>

Thompson shell has positional parameters, but no named variables nor access to environmental variables. It understands the creation of background commands with <syntaxhighlight lang="text" class="" style="" inline="1">&</syntaxhighlight>, similar to Bourne shell. It offers quoting and backslash escapes, though the single quotes work differently from Bourne shell.<ref name=etsh.man/>

Decline and replacementsEdit

As a result of the simplistic design, by the 1975 release of Version 6 Unix, it was becoming clear that the Thompson shell was inadequate for most serious programming tasks.

At this time, the developers of the Programmer's Workbench UNIX distribution, most notably John Mashey, began modifying the Thompson shell to make it more suitable for programming.<ref name=Mashey1976-10-13/> The result, known as the PWB shell or the Mashey shell, included more advanced flow-control mechanisms and introduced shell variables, but remained limited by the necessity to remain compatible with the Thompson shell.

Finally, the Thompson shell was replaced as the main Unix shell by the Bourne shell in Version 7 Unix and the C shell in 2BSD, both released in 1979. Since virtually all modern Unix and Unix-like systems are descended from V7 and 2BSD, the Thompson shell is generally no longer used. It is, however, available as open-source as part of several Ancient Unix source distributions, and has been ported to modern Unices as a historical exhibit.

See alsoEdit

ReferencesEdit

Template:Reflist

External linksEdit

Template:Unix Shells Template:Ken Thompson navbox