Date: Sat, 27 Oct 90 15:59:27 -0400 From: tihor@acf4.NYU.EDU (Stephen Tihor) Message-Id: <9010271959.AA10105@acf4.NYU.EDU> To: tihor@acf4.NYU.EDU Subject: Re: VT100/52/ANSI et.al. Escape codes Newsgroups: comp.os.vms In-Reply-To: <9010240014.AA10730@ucbvax.Berkeley.EDU> 23 Oct 90 16:00 EDT /* acf4:comp.os.vms */ /* 20950709@VUVAXCOM.BITNET (Jim McRee [Merlin]) / 4:00 pm Oct 23, 1990 */ Villanova University Campus Computing - Terminal Emulation Includes VT100 and VT52 Terminal and Control Codes This file contains control and terminal codes for the VT100 terminals, ANSI terminals, and VT52 terminals. Many of the codes were derived from PC/ Intercomm, from Mark of the Unicorn Software. I have researched some of them and added some of my own. Thank you, Jim McRee (209507097@VUVAXCOM.BITNET) (* ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** *) CONTROL SEQUENCE SUMMARY * For additional information on the DEC VT100 and VT102 terminals, please consult the VT100 USER GUIDE and VT102 USER GUIDE, published by Digital Equipment Corporation as part numbers EK-VT100-UG and EK-VT102-UG. CONTROL CHARACTERS: ------------------ Character Name Decimal Action Taken --------------------------------------------------------------- NUL 0 Fill character; ignored on input. ENQ 5 Transmit answerback message. BEL 7 Ring the bell. BS 8 Move cursor left. HT 9 Move cursor to next tab stop. LF 10 Line feed; causes print if in autoprint. VT 11 Same as LF. FF 12 Same as LF. CR 13 Move cursor to left margin or newline. SO 14 Invoke G1 character set. SI 15 Invoke G0 character set. XON 17 Resume transmission. XOFF 19 Halt transmission. CAN 24 Cancel escape sequence and display checkerboard. SUB 26 Same as CAN. ESC 27 Introduce a control sequence. DEL 127 Fill character; ignored on input. * All characters less than 32 decimal which are not listed above are ignored. (* ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** *) ANSI MODE SUMMARY: ----------------- *In ANSI sequences, parameters are given as a string of ASCII digits ('0' - '9') seperated by semicolons. Pn refers to a number whose value used directly. Ps refers to a number used as a selector. CURSOR MOVEMENT: --------------- Cursor Up: Esc [ Pn A Cursor Down: Esc [ Pn B Cursor Left: Esc [ Pn C Cursor Right: Esc [ Pn D Direct Addressing : Esc [ Pn(row);Pn(col);H or Esc [ Pn(row);Pn(col);f ie. (Pascal) Writeln (Esc,'[',Row:1,';',col:1,';','H'); Index: Esc D New Line: Esc E Reverse Line: Esc M Save cursor & Attributes: Esc 7 Restore cursor & attributes: Esc 8 ERASING: ------- Cursor to end of line Esc [ K Beginning of line to cursor Esc [ 1 K Entire line Esc [ 2 K Cursor to end of screen Esc [ J Beginning of screen to cursor Esc [ 1 J Entire screen Esc [ 2 J (Some programs expect Esc [ J to always clear the entire screen, but this does not conform to the standard.) MODES: ----- Set with Esc [ Ps h Reset with Esc [ Ps l Mode name Ps Set Reset ------------------------------------------------------------------- Keyboard action 2 Locked Unlocked Insertion 4 Insert Overwrite Send - Receive 12 Full Echo Line feed/New line 20 New line Line feed Cursor key ?1 Application Cursor ANSI/VT52 ?2 ANSI VT52 Column ?3 132 80 Scrolling ?4 Smooth Jump Screen ?5 Reverse Normal Origin ?6 Relative Absolute Wraparound ?7 Wrap Truncate Auto key repeat ?8 Repeating No repeat Print form feed ?18 Yes No Print extent ?19 Full screen Scrolling region Keypad application Esc = Keypad numeric mode Esc > EDITING: ------- Insert line Esc [ Pn L Delete line Esc [ Pn M Delete character Esc [ Pn P Scrolling region Esc [ Pn(top);Pn(bot) r PRINTING: -------- Print screen or region Esc [ i Print cursor line Esc [ ? 1 i Enter auto print Esc [ ? 5 i Exit auto print Esc [ ? 4 i Enter print controller Esc [ 5 i Exit print controller Esc [ 4 i LINE SIZE: --------- The following is a list of the available styles of printing on the screen. "Yes" in any column means that the option is supported by the escape code on that line. "No" means that the option is not supported by the escape code on that line; however, it may, and almost certainly is, supported by another escape sequence. Double-height and double-width double the size of the characters in their respective ways (ie. Double-height is twice as tall as usual). _Line designates underlining. Blink is for blinking characters. Side is the orientation of the character. Normal means that there is no orientation. Top and bottom refers to the position of the character in order to make a complete character. The top and bottom sequences will be important if you use the double height option. You will need to print the line twice to get a complete line. The first printing will print the top part of the characters and the second printing will print the bottom part. Inverse refers to the condition of the character. "No" indicates that the character will be printed in the color it normally is printed in with its usual backround. "Yes" means that the character will be printed in the backround color and the character's backround will be the color it is usually printed in. Shade refers to the brightness of the character. Normal is the standard brightness of the character. Bright is bold type. Dark is a darker brightness than usual. The escape code is the command you would type before the text you want to print to get the indicated effects. This section was greatly expanded in version 1.1 of this file. Double Double Height Width _Line Blink Side Inverse Shade Escape Code ----------------------------------------------------------------------- No No No No Normal No Normal <ESC>[0m Yes Yes No No Top No Bright <ESC>#3<ESC>[1m Yes Yes No No Bottom No Bright <ESC>#4<ESC>[1m Yes Yes No No Top No Dark <ESC>#3<ESC>[2m Yes Yes No No Bottom No Dark <ESC>#4<ESC>[2m Yes Yes No No Top No Normal <ESC>#3<ESC>[3m Yes Yes No No Bottom No Normal <ESC>#4<ESC>[3m Yes Yes Yes No Top No Normal <ESC>#3<ESC>[4m Yes Yes Yes No Bottom No Normal <ESC>#4<ESC>[4m Yes Yes No Yes Top No Normal <ESC>#3<ESC>[5m Yes Yes No Yes Bottom No Normal <ESC>#4<ESC>[5m Yes Yes No No Top Yes Normal <ESC>#3<ESC>[7m Yes Yes No No Bottom Yes Normal <ESC>#3<ESC>[7m No Yes No No Normal No Normal <ESC>#6<ESC>[0m No Yes No No Normal No Bright <ESC>#6<ESC>[1m No Yes No No Normal No Dark <ESC>#6<ESC>[2m No Yes Yes No Normal No Normal <ESC>#6<ESC>[4m No Yes No Yes Normal No Normal <ESC>#6<ESC>[5m No Yes No No Normal Yes Normal <ESC>#6<ESC>[7m No No No No Normal No Bright <ESC>#7<ESC>[1m No No No No Normal No Dark <ESC>#7<ESC>[2m No No Yes No Normal No Normal <ESC>#7<ESC>[4m No No No Yes Normal No Normal <ESC>#7<ESC>[5m No No No No Normal Yes Normal <ESC>#7<ESC>[7m * Some codes have been eliminated due to a repetition of effects. To the best of my knowledge, these codes are complete and correct. If you should find any errors, or you find some new sequences/effects, please inform me. * <ESC>#3 and <ESC>#4 behave in the same way as <ESC>#3[3m and <ESC>#4[4m. CHARACTER SETS: -------------- Character set G0 G1 ----------------------------------------------------- United Kingdom (UK) Esc ( A Esc ) A United States (US) Esc ( B Esc ) B Graphics Esc ( 0 Esc ) 0 Default ROM Esc ( 1 Esc ) 1 Alternate ROM Esc ( 2 Esc ) 2 Switch to G0/G1 Esc O Esc N TAB STOPS: --------- Set tab at current column Esc H Clear tab at current column Esc [ g Clear all tabs Esc [ 3 g MISCELLANEOUS: ------------- Hard Reset Esc c Character attributes Esc [ Ps m or Esc [ Ps ; Ps ; Ps m 0 - All attributes off 1 - Bold on 4 - Underscore on 5 - Blink on 7 - Reverse on Programmable LEDs Esc [ Ps q 0 - All LEDs off (1 - 4) - Turn respective LED on Fill screen with "E"s (test) Esc # 8 (* ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** *) NON-VT100 CONTROL SEQUENCES: ---------------------------- *Some VT100 terminal programs also understand a few other escape sequences than the standard VT100. I cannot guarantee that any of these nonstandard codes will work with any particular terminal, but they may be useful if they do work. Transmit a file Esc { T filenameCR ---> CR = Carriage Return Receive a file Esc { R filenameCR ---> CR = Carriage Return Append to a file Esc { A filenameCR ---> CR = Carriage Return Save collected text Esc { S Save collected text Esc S * These sequences will probably be most useful in developing a micro version of a VT100 emulator or in adapting an existing one. (* ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** *) VT52 MODE SUMMARY: ----------------- Cursor up Esc A Cursor down Esc B Cursor right Esc C Cursor left Esc D Graphics character set Esc F ASCII character set Esc G Home cursor Esc H Reverse line feed Esc I Erase to end of screen Esc J Erase to end of line Esc K Print cursor line Esc V Enter print controller Esc W Exit print controller Esc X Cursor address Esc Y row col Identify Esc Z Print screen Esc ] Enter auto print Esc ^ Exit auto print Esc - Alternate keypad Esc = Numeric keypad Esc > Enter ANSI mode Esc < * Row and column numbers are single characters with a bias of 31. E.g., "$" means row/column 5.) KEYPAD AND FUNCTION KEY SUMMARY: ------------------------------- CURSOR CONTROL KEYS: ------------------- Vt52 ANSI and Cursor Key modes Arrow Key Mode Reset Set --------------------------------------------------- Up Esc A Esc [ A Esc O A Down Esc B Esc [ B Esc O B Right Esc C Esc [ C Esc O C Left Esc D Esc [ D Esc O D AUXILLIARY KEYPAD: ----------------- VT52 Mode ANSI Mode Key Numeric Application Numeric Application ---------------------------------------------------------------------- 0 0 Esc ? p 0 Esc O p 1 1 Esc ? q 1 Esc O q 2 2 Esc ? r 2 Esc O r 3 3 Esc ? s 3 Esc O s 4 4 Esc ? t 4 Esc O t 5 5 Esc ? u 5 Esc O u 6 6 Esc ? v 6 Esc O v 7 7 Esc ? w 7 Esc O w 8 8 Esc ? x 8 Esc O x 9 9 Esc ? y 9 Esc O y - - Esc ? m - Esc O m , , Esc ? l , Esc O l . . Esc ? n . Esc O n ENTER ^M Esc ? M ^M Esc O M PF1 Esc P Esc P Esc O P Esc O P PF2 Esc Q Esc Q Esc O Q Esc O Q PF3 Esc R Esc R Esc O R Esc O R PF4 Esc S Esc S Esc O S Esc O S VT100 CURRENT STATES: -------------------- Esc [ c DA:Device Attributes or Esc Z DECID:Identify Terminal (ANSI mode) * For PC/Intercomm and some other emulators, irrespective of the parameter(s) present, the response is always Esc [ ? 6 c (i.e., a VT102) Other DEC terminals will respond according to their configuration and mode. Esc Z Identify (VT52 mode) * The sequence Esc / Z is always returned. Esc [ <sol> x DECREQTPARM: Request Terminal Parameters * <sol> values other than 1 are ignored. Upon receipt of a <sol> value of 1, the following response is sent: Esc[3;<par>;<nbits>;<xspeed>;<rspeed>;1;0x * Where <par>, <nbits>, <xspeed>, and <rspeed> are as for VT100s with the following exceptions: <nbits> Values of 5 and 6 bits per character are sent as 7 bits. <xspeed>,<rspeed> These two numbers will always be the same. 9600 baud is sent for 7200 baud. Esc [ Ps n DSR: Device Status Report * Parameter values other than 5, 6, are ignored. If the parameter value is 5, the sequence Esc [ O n is returned. If the parameter value is 6, the CPR: Cursor Position Report sequence Esc [ Pn ; Pn R is returned with the Pn set to cursor row and column numbers. /* ---------- */