mirror of https://github.com/microsoft/MS-DOS.git
227 lines
6.6 KiB
Plaintext
227 lines
6.6 KiB
Plaintext
This document explains the how the ANSI escape sequences are
|
||
defined for the IBM PC.
|
||
|
||
Notes:
|
||
|
||
1. The default value is used when no explicit value is given
|
||
or a value of zero is given.
|
||
|
||
2. Pn - Numeric parameter. A decimal number specified
|
||
with ASCII digits.
|
||
|
||
3. Ps - Selective parameter. Any decimal number that is
|
||
is used to select a subfunction. Multiple subfunctions
|
||
may be selected by separating the parameters with
|
||
semi-colons.
|
||
|
||
C U R S O R F U N C T I O N S
|
||
|
||
CUP - Cursor Postion
|
||
|
||
ESC [ Pl ; Pc H
|
||
|
||
HVP - Horizontal & Vertical Postion
|
||
|
||
ESC [ Pl ; Pc f
|
||
|
||
CUP and HVP move the cursor to the position specified by
|
||
the parameters. The first parameter specifies the line number
|
||
and the second parameter specifies the column number. The
|
||
default value is one. When no parameters are given the cursor
|
||
is moved to the home postion.
|
||
|
||
CUU - Cursor Up
|
||
|
||
ESC [ Pn A
|
||
|
||
Moves the cursor up one line without changing columns. The
|
||
value of Pn determines the number of lines moved. The default
|
||
value for Pn is one. This sequence is ignored if the cursor
|
||
is already on the top line.
|
||
|
||
CUD - Cursor Down
|
||
|
||
ESC [ Pn B
|
||
|
||
Moves the cursor down one line without changing columns.
|
||
The value of Pn determines the number of lines moved. The
|
||
default value for Pn is one. This sequence is ignored if the
|
||
cursor is already on the bottom line.
|
||
|
||
CUF - Cursor Forward
|
||
|
||
ESC [ Pn C
|
||
|
||
Moves the cursor forword one column without changing lines.
|
||
The value of Pn determines the number of columns moved. The
|
||
default value for Pn is one. This sequence is ignored if the
|
||
cursor is already in the rightmost column.
|
||
|
||
ESC [ Pn D
|
||
|
||
Moves the cursor back one column without changing lines. The
|
||
value of Pn determines the number of columns moved. The default
|
||
value for Pn is one. This sequence is ignored if the cursor
|
||
is already in the leftmost column.
|
||
|
||
DSR - Device Status Report
|
||
|
||
ESC [ 6 n
|
||
|
||
The console driver will output a CPR sequence on receipt of
|
||
DSR.
|
||
|
||
CPR - Cursor Position Report (from console driver to system)
|
||
|
||
ESC [ Pn ; Pn R
|
||
|
||
The CPR sequence reports current cursor position via
|
||
standard input. The first parameter specifies the current
|
||
line and the second parameter specifies the current column.
|
||
|
||
SCP - Save Cursor Postion
|
||
|
||
ESC [ s
|
||
|
||
The current cursor position is saved. This cursor position
|
||
can be restored with the RCP sequence.
|
||
|
||
RCP - Restore cursor position
|
||
|
||
ESC [ u
|
||
|
||
Restores the cursor position to the value it had when the
|
||
console driver received the SCP sequence.
|
||
|
||
E R A S I N G
|
||
|
||
ED - Erase Display
|
||
|
||
ESC [ 2 J
|
||
|
||
Erases all of the screen and the cursor goes to the home
|
||
position.
|
||
|
||
EL - Erase Line
|
||
|
||
ESC [ K
|
||
|
||
Erases from the cursor to the end of the line and includes
|
||
the cursor position.
|
||
|
||
|
||
|
||
M O D E S O F O P E R A T I O N
|
||
|
||
SGR - Set Graphics Rendition
|
||
|
||
ESC [ Ps ; ... ; Ps m
|
||
|
||
Invokes the graphic rendition specified by the parameter(s).
|
||
All following characters are rendered according to the
|
||
parameter(s) until the next occurence of SGR.
|
||
|
||
Parameter Parameter Function
|
||
|
||
0 All Attributes Off
|
||
1 Bold On
|
||
4 Underscore On (monochrome displays
|
||
only)
|
||
5 Blink On
|
||
7 Reverse Video On
|
||
8 Concealed On (ISO 6429 standard)
|
||
30 Black foreground (ISO 6429 standard)
|
||
31 Red foreground (ISO 6429 standard)
|
||
32 Green foreground (ISO 6429 standard)
|
||
33 Yellow foreground (ISO 6429 standard)
|
||
34 Blue foreground (ISO 6429 standard)
|
||
35 Magenta foreground (ISO 6429 standard)
|
||
36 Cyan foreground (ISO 6429 standard)
|
||
37 White foregound (ISO 6429 standard)
|
||
40 Black background (ISO 6429 standard)
|
||
41 Red background (ISO 6429 standard)
|
||
42 Green background (ISO 6429 standard)
|
||
43 Yellow background (ISO 6429 standard)
|
||
44 Blue background (ISO 6429 standard)
|
||
45 Magenta background (ISO 6429 standard)
|
||
46 Cyan background (ISO 6429 standard)
|
||
47 White backgound (ISO 6429 standard)
|
||
|
||
SM - Set Mode (IBM/MICROSOFT Private)
|
||
|
||
ESC [ = Ps h
|
||
or ESC [ = h
|
||
or ESC [ = 0 h
|
||
or ESC [ ? 7 h
|
||
|
||
|
||
Invokes the screen width or type specified by the parameter.
|
||
|
||
Parameter Parameter Function
|
||
|
||
0 40 x 25 black and white
|
||
1 40 x 25 color
|
||
2 80 x 25 black and white
|
||
3 80 x 25 color
|
||
|
||
4 320 x 200 color
|
||
5 320 x 200 black and white
|
||
6 640 x 200 black and white
|
||
7 wrap at end of line
|
||
|
||
|
||
RM - Reset Mode
|
||
|
||
ESC [ = Ps l
|
||
or ESC [ = l
|
||
or ESC [ = 0 l
|
||
or ESC [ ? 7 l
|
||
|
||
|
||
Parameters are the same as SM (Set Mode) except that
|
||
parameter 7 will reset wrap at end of line mode.
|
||
|
||
|
||
K E Y B O A R D R E - A S S I G N M E N T
|
||
|
||
Although not part of the ANSI 3.64-1979 or ISO 6429 standard
|
||
the IBM PC keyboard re-assignment was done in a compatible
|
||
way.
|
||
|
||
The control sequence is:
|
||
|
||
ESC [ Pn ; Pn ; ... Pn p
|
||
or ESC [ "string" ; p
|
||
or ESC [ Pn ; "string" ; Pn ; Pn ; "string" ; Pn p
|
||
or any other combination of strings and decimal numbers
|
||
|
||
The final code in the control sequence ("p") is one reserved
|
||
for private use the by ANSI 3.64-1979 standard.
|
||
|
||
The first ASCII code in the control sequence defines which
|
||
code is being mapped. The remaining numbers define the
|
||
sequence of ASCII codes generated when this key is
|
||
intercepted.
|
||
|
||
To every rule there is an exception, however! If the first
|
||
code in the sequence is zero (NUL) then the first and second
|
||
code make up an extended ASCII re-definition.
|
||
|
||
Here are some examples:
|
||
|
||
1. Reassign the Q and q key to the A and a key (and the other
|
||
way as well):
|
||
|
||
ESC [ 6 5 ; 8 1 p A becomes Q
|
||
ESC [ 9 7 ; 1 1 3 p a becomes q
|
||
ESC [ 8 1 ; 6 5 p Q becomes A
|
||
ESC [ 1 1 3 ; 9 7 p q becomes a
|
||
|
||
2. Reassign the F10 key to to a dir command followed by a
|
||
carriage return:
|
||
|
||
ESC [ 0 ; 6 8 ; " d i r " ; 1 3 p
|
||
|
||
The 0;68 is the extended ASCII code for the F10 key. 13
|
||
decimal is a carriage return
|
||
|