Differences between revisions 14 and 15
Revision 14 as of 2011-09-05 22:46:40
Size: 4571
Editor: ormaaj
Comment: Some problems with this section: This isn't true of mksh; ksh88 doesn't have pre/post increment operators; and bash 4.2 has lastpipe. Added a "ksh93" comment for now.
Revision 15 as of 2011-10-08 19:05:02
Size: 3493
Editor: ormaaj
Comment: Rewrite. Add tables.
Deletions are marked like this. Additions are marked like this.
Line 2: Line 2:
The KornShell is a reimplementation of the [[BourneShell|Bourne shell]]. It is downward compatible, but adds many features intended to simplify programming. Most of the features are part of [[PosixShell|POSIX shell]], too, and therefore are available on any POSIX compliant system. The KornShell is a reimplementation of the [[BourneShell|Bourne shell]]. It is downward compatible, but adds many features intended to simplify programming. Most of the features are part of [[PosixShell|POSIX shell]] too, and therefore are available on any POSIX compliant system. In the universe of shells it might be said that the Ksh family is Bash's closest relative. [[Bash]] implements much of the Korn shell's functionality and both share many common conventions. If care is taken it is possible to write polyglot code portable between these shells while still using a superset of POSIX sh features. For example, the (( arithmetic keyword. Incompatibilities do exist in many shared features. For instance, the Bash builtin '''read -a''' is equivalent to Ksh's '''read -A'''.
Line 4: Line 4:
[[Bash]] also implements most of the Korn shell's functionality.

There are three primary version of the Korn shell in use today: the original (often dubbed '''ksh88'''), the successor ('''ksh93'''), and an open source version called '''pdksh''' ("Public Domain Korn Shell"). pdksh was developed before the source code for ksh93 was liberated.
'''ksh88''', and it's successor '''ksh93''', is David Korn's "original" Korn shell. Now part of the ast-open package since being open-sourced by AT&T in 2000 under the CPL license, '''ksh93''' is still actively developed and is probably what someone is referring to if using the term "Ksh" without further qualification. It is also currently the most featureful. Additionally, there exist several variants under the name "Korn shell". Some of the most common and actively developed include ''mksh'' - the MirBSD Korn shell, and '''pdksh''' ("Public Domain Korn Shell") - intended to be ksh93's open-source replacement while it was still proprietary software.
Line 10: Line 8:
Some of the features of the Korn shell are:
 * '''KornShellArrays''' provide arrays with numerical indexes
 * '''TypedVariables''' using the [[TypedefCommand|typedef]] command. It can be used to print strings left- or right-aligned, print integer numbers with leading zeros, or provide LocalVariables for a function
 * '''ArithmeticExpressions''' in ((...)),
{{{
        # ksh93
        for ((i=0; i<10; ++i)); do
            print $i
        done
}}}
Incomplete list of ksh93 features with no ''direct'' BashShell equivalent (as of version 4.2), (i.e., no same feature with same syntax by a different name). Some are trivial to accomplish in Bash by other means:
Line 21: Line 10:
 * '''CommandSubstitution''' with $(_command_), which simplifies nesting. Compare e.g. the BourneShell command
{{{
        parent=`basename \`dirname "${PWD}"\``
}}}
(Below is a work in progress)
||'''Feature'''||'''Description'''||
||{n1..n2[ ..n3]%fmt}||Sequence expression with a printf format specification applied to each generated argument.||
||{n[,m]}(pattern-list)||ERE-style arbitrary quantification of extended globs.||
||varname=([typeset [options]] assignment ...)||Compound and nested variable assignment. Similar to C structs. Bash arrays can only be homogenous datatypes.||
||%n$ and *n$||SUS printf extensions for addressing individual arguments||
||Floating point numeric types|| - ||
||print (built-in)||allows for reliably printing arbitrary characters.||
Line 26: Line 19:
  with its KornShell counterpart: Incomplete list of BashShell features with no direct ksh93 equivalent:
Line 28: Line 21:
{{{
        parent=$(basename $(dirname "${PWD}"))
}}}
||'''Feature'''||'''Description'''||
||;;&||case...esac delimiter, like ;&, but additionally only continue if the next pattern list matches||
||pushd/popd/dirs/~[+|-]N|| Ksh has no directory stack. Tilde expansion supports only one level.||
Line 32: Line 25:
 * Powerful '''PatternMatching''' (for filename generation and for usage in {{{case}}} and {{{[[ ... ]]}}}, e.g.:
{{{
        case ${url} in
            http://*) print a browser can handle that;;
                   *) print maybe a browser can handle that, too;;
        esac

        if [[ ${pathname} == /* ]]; then
            print path is absolute;
        fi
}}}
 * '''ParameterSubstitution''' like {{{${var%pattern}}}}, {{{${var%%pattern}}}} to remove (last/largest) {{{pattern}}} from the end of variable {{{var}}}, and {{{${var#pattern}}}}, {{{${var##pattern}}}} to remove (first/largest) {{{pattern}}} from the front of the variable.
 * [[CoProcess|Co-processes]], e.g. {{{bc |&}}} to start the "bc" command as a co-process. "{{{read -p}}}" and "{{{print -p}}}" are used to read from or write to the co-process. Other shells (e.g. [[BASH]]) require the user to use e.g. NamedPipes (FiFos) for that purpose
 * built-in '''{{{print}}}''' command. This doesn't sound like a big innovation, but it allows for reliably printing arbitrary characters. Most important uses are "{{{print -n --}}}" to print without trailing NewLine character, and "{{{print -r --}}}" to print arbitrary strings, possibly including EscapeSequences or a BackSlash character.
 * '''[[SelectComand|select]]''' command for easy menus. {{{select}}} is used like {{{for}}}, but prints an simple interactive menu where a user can select one out of several choices.
 * '''KornShellFunctions''' are similar to traditional BourneShell functions, but can have local variables, local argument handling using [[GetoptsCommand|getopts]], and local [[TrapCommand|traps]]
 * Built-in [[TestOperator|[[]] ("test") with improved quoting behaviour and more conditional operators than the OldTestOperator
 * CommandLineEditing with [[ViEditor|vi]] or [[EmacsEditor|emacs]] command sequences

Other, smaller improvements over the BourneShell include
 * Earlier versions of the Bourne shell don't know yet signal names for the [[TrapCommand|trap]] command, e.g. {{{trap 'rm temp' EXIT}}} instead of {{{trap 'rm temp' 0}}}
 * TildeSubstitution, '''~''' is replaced with the user's HomeDirectory, ~_user_ is replaced with the HomeDirectory of the user _user_, e.g. {{{echo ~root}}}



Most of the features of the KornShell are available in the BashShell, too. The following features are '''not''' found in the BashShell:

 * co-processes (process |&)
 * built-in "print" command
 * some of the [[TypedefCommand|typedef]] options

And everyone's favorite KornShell feature that's not in Bash:

 * The last command in a pipe is executed in the current shell instead of a subshell. So the following works the way a naive user would expect:

  {{{
  #ksh93
  i=0
  ls -l | while read; do
    ((++i))
  done
  echo "$i lines"
  }}}
Other important notes:
 * Bash co-processes are considerably different and weren't available in Bash at all until version 4. (process |& versus the coproc keyword)
 * Ksh has always executed the last command of a pipeline in the parent shell's environment. Bash has always used a subshell for all pipeline commands. Bash 4.2 adds the '''lastpipe''' shopt option, but it isn't enabled by default.
 * $SECONDS in ksh93 has millisecond precision. Bash only counts seconds and has no high-resolution timestamp mechanism.

Korn Shell

The KornShell is a reimplementation of the Bourne shell. It is downward compatible, but adds many features intended to simplify programming. Most of the features are part of POSIX shell too, and therefore are available on any POSIX compliant system. In the universe of shells it might be said that the Ksh family is Bash's closest relative. Bash implements much of the Korn shell's functionality and both share many common conventions. If care is taken it is possible to write polyglot code portable between these shells while still using a superset of POSIX sh features. For example, the (( arithmetic keyword. Incompatibilities do exist in many shared features. For instance, the Bash builtin read -a is equivalent to Ksh's read -A.

ksh88, and it's successor ksh93, is David Korn's "original" Korn shell. Now part of the ast-open package since being open-sourced by AT&T in 2000 under the CPL license, ksh93 is still actively developed and is probably what someone is referring to if using the term "Ksh" without further qualification. It is also currently the most featureful. Additionally, there exist several variants under the name "Korn shell". Some of the most common and actively developed include mksh - the MirBSD Korn shell, and pdksh ("Public Domain Korn Shell") - intended to be ksh93's open-source replacement while it was still proprietary software.

The Korn shell (either ksh88 or ksh93, depending on the age of the system) is a standard part of any modern (commercial) Unix system, e.g. Solaris, AIX, HP-UX. pdksh is often available on BSD or GNU/Linux systems, and a growing number of GNU/Linux systems now offer ksh93, either instead of or in addition to pdksh.

Incomplete list of ksh93 features with no direct BashShell equivalent (as of version 4.2), (i.e., no same feature with same syntax by a different name). Some are trivial to accomplish in Bash by other means:

(Below is a work in progress)

Feature

Description

{n1..n2[ ..n3]%fmt}

Sequence expression with a printf format specification applied to each generated argument.

{n[,m]}(pattern-list)

ERE-style arbitrary quantification of extended globs.

varname=([typeset [options]] assignment ...)

Compound and nested variable assignment. Similar to C structs. Bash arrays can only be homogenous datatypes.

%n$ and *n$

SUS printf extensions for addressing individual arguments

Floating point numeric types

-

print (built-in)

allows for reliably printing arbitrary characters.

Incomplete list of BashShell features with no direct ksh93 equivalent:

Feature

Description

;;&

case...esac delimiter, like ;&, but additionally only continue if the next pattern list matches

pushd/popd/dirs/~[+|-]N

Ksh has no directory stack. Tilde expansion supports only one level.

Other important notes:

  • Bash co-processes are considerably different and weren't available in Bash at all until version 4. (process |& versus the coproc keyword)

  • Ksh has always executed the last command of a pipeline in the parent shell's environment. Bash has always used a subshell for all pipeline commands. Bash 4.2 adds the lastpipe shopt option, but it isn't enabled by default.

  • $SECONDS in ksh93 has millisecond precision. Bash only counts seconds and has no high-resolution timestamp mechanism.


CategoryShell

KornShell (last edited 2022-06-20 20:47:27 by emanuele6)