nuttx/include/nuttx/vt100.h
2014-11-10 15:10:57 -06:00

300 lines
19 KiB
C

/********************************************************************************************
* include/nuttx/vt100.h
* VT100 Escape Sequences
*
* Copyright (C) 2012 Gregory Nutt. All rights reserved.
* Author: Gregory Nutt <gnutt@nuttx.org>
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions
* are met:
*
* 1. Redistributions of source code must retain the above copyright
* notice, this list of conditions and the following disclaimer.
* 2. Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in
* the documentation and/or other materials provided with the
* distribution.
* 3. Neither the name NuttX nor the names of its contributors may be
* used to endorse or promote products derived from this software
* without specific prior written permission.
*
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
* FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
* COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
* BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS
* OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
* AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
* ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
* POSSIBILITY OF SUCH DAMAGE.
*
********************************************************************************************/
#ifndef __INCLUDE_NUTTX_VT100_H
#define __INCLUDE_NUTTX_VT100_H
/********************************************************************************************
* Included Files
********************************************************************************************/
#include <nuttx/ascii.h>
/********************************************************************************************
* Pre-processor Definitions
********************************************************************************************/
#define VT100_SETNL {ASCII_ESC, '[', '2', '0', 'h'} /* Set new line mode */
#define VT100_SETAPPL {ASCII_ESC, '[', '?', '1', 'h'} /* Set cursor key to application */
#define VT100_SETCOL {ASCII_ESC, '[', '?', '3', 'h'} /* Set number of columns to 132 */
#define VT100_SETSMOOTH {ASCII_ESC, '[', '?', '4', 'h'} /* Set smooth scrolling */
#define VT100_SETREVSCRN {ASCII_ESC, '[', '?', '5', 'h'} /* Set reverse video on screen */
#define VT100_SETORGREL {ASCII_ESC, '[', '?', '6', 'h'} /* Set origin to relative */
#define VT100_SETWRAP {ASCII_ESC, '[', '?', '7', 'h'} /* Set auto-wrap mode */
#define VT100_SETREP {ASCII_ESC, '[', '?', '8', 'h'} /* Set auto-repeat mode */
#define VT100_SETINTER {ASCII_ESC, '[', '?', '9', 'h'} /* Set interlacing mode */
#define VT100_SETLF {ASCII_ESC, '[', '2', '0', 'l'} /* Set line feed mode */
#define VT100_SETCURSOR {ASCII_ESC, '[', '?', '1', 'l'} /* Set cursor key to cursor */
#define VT100_SETVT52 {ASCII_ESC, '[', '?', '2', 'l'} /* Set VT52 (versus ANSI) */
#define VT100_RESETCOL {ASCII_ESC, '[', '?', '3', 'l'} /* Set number of columns to 80 */
#define VT100_SETJUMP {ASCII_ESC, '[', '?', '4', 'l'} /* Set jump scrolling */
#define VT100_SETNORMSCRN {ASCII_ESC, '[', '?', '5', 'l'} /* Set normal video on screen */
#define VT100_SETORGABS {ASCII_ESC, '[', '?', '6', 'l'} /* Set origin to absolute */
#define VT100_RESETWRAP {ASCII_ESC, '[', '?', '7', 'l'} /* Reset auto-wrap mode */
#define VT100_RESETREP {ASCII_ESC, '[', '?', '8', 'l'} /* Reset auto-repeat mode */
#define VT100_RESETINTER {ASCII_ESC, '[', '?', '9', 'l'} /* Reset interlacing mode */
#define VT100_ALTKEYPAD {ASCII_ESC, '='} /* Set alternate keypad mode */
#define VT100_NUMKEYPAD {ASCII_ESC, '>'} /* Set numeric keypad mode */
#define VT100_SETUKG0 {ASCII_ESC, '(', 'A'} /* Set United Kingdom G0 character set */
#define VT100_SETUKG1 {ASCII_ESC, ')', 'A'} /* Set United Kingdom G1 character set */
#define VT100_SETUSG0 {ASCII_ESC, '(', 'B'} /* Set United States G0 character set */
#define VT100_SETUSG1 {ASCII_ESC, ')', 'B'} /* Set United States G1 character set */
#define VT100_SETSPECG0 {ASCII_ESC, '(', '0'} /* Set G0 special chars. & line set */
#define VT100_SETSPECG1 {ASCII_ESC, ')', '0'} /* Set G1 special chars. & line set */
#define VT100_SETALTG0 {ASCII_ESC, '(', '1'} /* Set G0 alternate character ROM */
#define VT100_SETALTG1 {ASCII_ESC, ')', '1'} /* Set G1 alternate character ROM */
#define VT100_SETALTSPECG0 {ASCII_ESC, '(', '2'} /* Set G0 alt char ROM and spec. graphics */
#define VT100_SETALTSPECG1 {ASCII_ESC, ')', '2'} /* Set G1 alt char ROM and spec. graphics */
#define VT100_SETSS2 {ASCII_ESC, 'N'} /* Set single shift 2 */
#define VT100_SETSS3 {ASCII_ESC, 'O'} /* Set single shift 3 */
#define VT100_MODESOFF {ASCII_ESC, '[', 'm'} /* Turn off character attributes */
#define VT100_MODESOFF2 {ASCII_ESC, '[', '0', 'm'} /* Turn off character attributes */
#define VT100_BOLD {ASCII_ESC, '[', '1', 'm'} /* Turn bold mode on */
#define VT100_LOWINT {ASCII_ESC, '[', '2', 'm'} /* Turn low intensity mode on */
#define VT100_FORE_BLACK {ASCII_ESC, '[', '3', '0', 'm'} /* Set foreground to color #0 - black */
#define VT100_FORE_RED {ASCII_ESC, '[', '3', '1', 'm'} /* Set foreground to color #1 - red */
#define VT100_FORE_GREEN {ASCII_ESC, '[', '3', '2', 'm'} /* Set foreground to color #2 - green */
#define VT100_FORE_YELLOW {ASCII_ESC, '[', '3', '3', 'm'} /* Set foreground to color #3 - yellow */
#define VT100_FORE_BLUE {ASCII_ESC, '[', '3', '4', 'm'} /* Set foreground to color #4 - blue */
#define VT100_FORE_MAGENTA {ASCII_ESC, '[', '3', '5', 'm'} /* Set foreground to color #5 - magenta */
#define VT100_FORE_CYAN {ASCII_ESC, '[', '3', '6', 'm'} /* Set foreground to color #6 - cyan */
#define VT100_FORE_WHITE {ASCII_ESC, '[', '3', '7', 'm'} /* Set foreground to color #7 - white */
#define VT100_FORE_DEFAULT {ASCII_ESC, '[', '3', '9', 'm'} /* Set foreground to color #9 - default */
#define VT100_UNDERLINE {ASCII_ESC, '[', '4', 'm'} /* Turn underline mode on */
#define VT100_BACK_BLACK {ASCII_ESC, '[', '4', '0', 'm'} /* Set background to color #0 - black */
#define VT100_BACK_RED {ASCII_ESC, '[', '4', '1', 'm'} /* Set background to color #1 - red */
#define VT100_BACK_GREEN {ASCII_ESC, '[', '4', '2', 'm'} /* Set background to color #2 - green */
#define VT100_BACK_YELLOW {ASCII_ESC, '[', '4', '3', 'm'} /* Set background to color #3 - yellow */
#define VT100_BACK_BLUE {ASCII_ESC, '[', '4', '4', 'm'} /* Set background to color #4 - blue */
#define VT100_BACK_MAGENTA {ASCII_ESC, '[', '4', '5', 'm'} /* Set background to color #5 - magenta */
#define VT100_BACK_CYAN {ASCII_ESC, '[', '4', '6', 'm'} /* Set background to color #6 - cyan */
#define VT100_BACK_WHITE {ASCII_ESC, '[', '4', '7', 'm'} /* Set background to color #7 - white */
#define VT100_BACK_DEFAULT {ASCII_ESC, '[', '4', '9', 'm'} /* Set background to color #9 - default */
#define VT100_BLINK {ASCII_ESC, '[', '5', 'm'} /* Turn blinking mode on */
#define VT100_REVERSE {ASCII_ESC, '[', '7', 'm'} /* Turn reverse video on */
#define VT100_INVISIBLE {ASCII_ESC, '[', '8', 'm'} /* Turn invisible text mode on */
#define VT100_BOLDOFF {ASCII_ESC, '[', '2', '2', 'm'} /* Turn bold off */
#define VT100_UNDERLINEOFF {ASCII_ESC, '[', '2', '4', 'm'} /* Turn underline off */
#define VT100_BLINKOFF {ASCII_ESC, '[', '2', '5', 'm'} /* Turn blink off */
#define VT100_REVERSEOFF {ASCII_ESC, '[', '2', '7', 'm'} /* Turn reverse video off */
#define VT100_SETWIN(t,b) {ASCII_ESC, '[', (t), ';', (b), 'r'} /* Set top and bottom line#s of a window */
#define VT100_CURSOROFF {ASCII_ESC, '[', '?', '2', '5', 'l'} /* Cursor OFF */
#define VT100_CURSORON {ASCII_ESC, '[', '?', '2', '5', 'h'} /* Cursor ON */
#define VT100_CURSOROFF2 {ASCII_ESC, '[', '?', '5', '0', 'l'} /* Cursor OFF */
#define VT100_CURSORON2 {ASCII_ESC, '[', '?', '5', '0', 'h'} /* Cursor ON */
#define VT100_CURSORUP(n) {ASCII_ESC, '[', (n), 'A'} /* Move cursor up n lines */
#define VT100_CURSORDN(n) {ASCII_ESC, '[', (n), 'B'} /* Move cursor down n lines */
#define VT100_CURSORRT(n) {ASCII_ESC, '[', (n), 'C'} /* Move cursor right n lines */
#define VT100_CURSORLF(n) {ASCII_ESC, '[', (n), 'D'} /* Move cursor left n lines */
#define VT100_CURSORHOME {ASCII_ESC, '[', 'H'} /* Move cursor to upper left corner */
#define VT100_CURSORHOME_ {ASCII_ESC, '[', ';', 'H'} /* Move cursor to upper left corner */
#define VT100_CURSORPOS(v,h) {ASCII_ESC, '[', (v), ';', (h), 'H'} /* Move cursor to screen location v,h */
#define VT100_HVHOME {ASCII_ESC, '[', 'f'} /* Move cursor to upper left corner */
#define VT100_HVHOME_ {ASCII_ESC, '[', ';', 'f'} /* Move cursor to upper left corner */
#define VT100_HVPOS(v,h) {ASCII_ESC, '[', (v), ';', (h), 'f'} /* Move cursor to screen location v,h */
#define VT100_INDEX {ASCII_ESC, 'D'} /* Move/scroll window up one line */
#define VT100_REVINDEX {ASCII_ESC, 'M'} /* Move/scroll window down one line */
#define VT100_NEXTLINE {ASCII_ESC, 'E'} /* Move to next line */
#define VT100_SAVECURSOR {ASCII_ESC, '7'} /* Save cursor position and attributes */
#define VT100_RESTORECURSOR {ASCII_ESC, '8'} /* Restore cursor position and attribute */
#define VT100_TABSET {ASCII_ESC, 'H'} /* Set a tab at the current column */
#define VT100_TABCLR {ASCII_ESC, '[', 'g'} /* Clear a tab at the current column */
#define VT100_TABCLR_ {ASCII_ESC, '[', '0', 'g'} /* Clear a tab at the current column */
#define VT100_TABCLRALL {ASCII_ESC, '[', '3', 'g'} /* Clear all tabs */
#define VT100_DHTOP {ASCII_ESC, '#', '3'} /* Double-height letters, top half */
#define VT100_DHBOT {ASCII_ESC, '#', '4'} /* Double-height letters, bottom hal */
#define VT100_SWSH {ASCII_ESC, '#', '5'} /* Single width, single height letters */
#define VT100_DWSH {ASCII_ESC, '#', '6'} /* Double width, single height letters */
#define VT100_CLEAREOL {ASCII_ESC, '[', 'K'} /* Clear line from cursor right */
#define VT100_CLEAREOL_ {ASCII_ESC, '[', '0', 'K'} /* Clear line from cursor right */
#define VT100_CLEARBOL {ASCII_ESC, '[', '1', 'K'} /* Clear line from cursor left */
#define VT100_CLEARLINE {ASCII_ESC, '[', '2', 'K'} /* Clear entire line */
#define VT100_CLEAREOS {ASCII_ESC, '[', 'J'} /* Clear screen from cursor down */
#define VT100_CLEAREOS_ {ASCII_ESC, '[', '0', 'J'} /* Clear screen from cursor down */
#define VT100_CLEARBOS {ASCII_ESC, '[', '1', 'J'} /* Clear screen from cursor up */
#define VT100_CLEARSCREEN {ASCII_ESC, '[', '2', 'J'} /* Clear entire screen */
#define VT100_DEVSTAT {ASCII_ESC, '[', '5', 'n'} /* Device status report */
#define VT100_TERMOK {ASCII_ESC, '[', '0', 'n'} /* Response: terminal is OK */
#define VT100_TERMNOK {ASCII_ESC, '[', '3', 'n'} /* Response: terminal is not OK */
#define VT100_GETCURSOR {ASCII_ESC, '[', '6', 'n'} /* Get cursor position */
#define VT100_CURSORPOSAT {ASCII_ESC, '[', (v), ';', (h), 'R'} /* Response: cursor is at v,h */
#define VT100_IDENT {ASCII_ESC, '[', 'c'} /* Identify what terminal type */
#define VT100_IDENT_ {ASCII_ESC, '[', '0', 'c'} /* Identify what terminal type */
#define VT100_GETTYPE {ASCII_ESC, '[', '?', '1', ';', (n), '0', 'c'} /* Response: terminal type code n */
#define VT100_RESET RIS {ASCII_ESC, 'c'} /* Reset terminal to initial state */
#define VT100_ALIGN {ASCII_ESC, '#', '8'} /* Screen alignment display */
#define VT100_TESTPU {ASCII_ESC, '[', '2', ';', '1', 'y'} /* Confidence power up test */
#define VT100_TESTLB {ASCII_ESC, '[', '2', ';', '2', 'y'} /* Confidence loopback test */
#define VT100_TESTPUREP {ASCII_ESC, '[', '2', ';', '9', 'y'} /* Repeat power up test */
#define VT100_TESTLBREP {ASCII_ESC, '[', '2', ';', '1', '0', 'y'} /* Repeat loopback test */
#define VT100_LEDSOFF {ASCII_ESC, '[', '0', 'q'} /* Turn off all four leds */
#define VT100_LED1 {ASCII_ESC, '[', '1', 'q'} /* Turn on LED #1 */
#define VT100_LED2 {ASCII_ESC, '[', '2', 'q'} /* Turn on LED #2 */
#define VT100_LED3 {ASCII_ESC, '[', '3', 'q'} /* Turn on LED #3 */
#define VT100_LED4 {ASCII_ESC, '[', '4', 'q'} /* Turn on LED #4 */
/* All codes below are for use in VT52 compatibility mode. */
#define VT52_SETANSI {ASCII_ESC, '<'} /* Enter/exit ANSI mode */
#define VT52_ALTKEYPAD {ASCII_ESC, '='} /* Enter alternate keypad mode */
#define VT52_NUMKEYPAD {ASCII_ESC, '>'} /* Exit alternate keypad mode */
#define VT52_SETGR {ASCII_ESC, 'F'} /* Use special graphics character set */
#define VT52_RESETGR {ASCII_ESC, 'G'} /* Use normal US/UK character set */
#define VT52_CURSORUP {ASCII_ESC, 'A'} /* Move cursor up one line */
#define VT52_CURSORDN {ASCII_ESC, 'B'} /* Move cursor down one line */
#define VT52_CURSORRT {ASCII_ESC, 'C'} /* Move cursor right one char */
#define VT52_CURSORLF {ASCII_ESC, 'D'} /* Move cursor left one char */
#define VT52_CURSORHOME {ASCII_ESC, 'H'} /* Move cursor to upper left corner */
#define VT52_CURSORPOS(v,h) {ASCII_ESC, (v), (h)} /* Move cursor to v,h location */
#define VT52_REVINDEX {ASCII_ESC, 'I'} /* Generate a reverse line-feed */
#define VT52_CLEAREOL {ASCII_ESC, 'K'} /* Erase to end of current line */
#define VT52_CLEAREOS {ASCII_ESC, 'J'} /* Erase to end of screen */
#define VT52_IDENT {ASCII_ESC, 'Z'} /* Identify what the terminal is */
#define VT52_IDENTRESP {ASCII_ESC, '/', 'Z'} /* Correct response to ident */
/* Format strings for VT100 sequences that require numeric arguments */
#define VT100_BLACK 0 /* Color #0 - black */
#define VT100_RED 1 /* Color #1 - red */
#define VT100_GREEN 2 /* Color #2 - green */
#define VT100_YELLOW 3 /* Color #3 - yellow */
#define VT100_BLUE 4 /* Color #4 - blue */
#define VT100_MAGENTA 5 /* Color #5 - magenta */
#define VT100_CYAN 6 /* Color #6 - cyan */
#define VT100_WHITE 7 /* Color #7 - white */
#define VT100_DEFAULT 9 /* Color #9 - default */
#define VT100_FMT_FORE_COLOR "\033[3%dm" /* Set foreground to color #n, n=0-8,9*/
#define VT100_FMT_BACK_COLOR "\033[4%dm" /* Color #n, n=0-8,9*/
#define VT100_FMT_SETWIN "\033[%d;%dr" /* Set top and bottom line#s of a window */
#define VT100_FMT_CURSORUP "\033[%dA" /* Move cursor up n lines */
#define VT100_FMT_CURSORDN "\033[%dB" /* Move cursor down n lines */
#define VT100_FMT_CURSORRT "\033[%dC" /* Move cursor right n lines */
#define VT100_FMT_CURSORLF "\033[%dD" /* Move cursor left n lines */
#define VT100_FMT_CURSORPOS "\033[%d;%dH" /* Move cursor to screen location v,h */
#define VT100_FMT_HVPOS "\033[%d;%df" /* Move cursor to screen location v,h */
#define VT52_FMT_CURSORPOS "\033%d%d" /* Move cursor to v,h location */
/* VT100 Special Key Codes
*
* These are sent from the terminal back to the computer when the particular
* key is pressed. Note that the numeric keypad keys send different codes
* in numeric mode than in alternate mode.
*/
/* Function Keys */
#define VT100_PF1 {ASCII_ESC, 'O', 'P'}
#define VT100_PF2 {ASCII_ESC, 'O', 'Q'}
#define VT100_PF3 {ASCII_ESC, 'O', 'R'}
#define VT100_PF4 {ASCII_ESC, 'O', 'S'}
/* Arrow keys */
#define VT100_UP_RESET {ASCII_ESC, 'A'}
#define VT100_UP_SET {ASCII_ESC, 'O', 'A'}
#define VT100_DOWN_RESET {ASCII_ESC, 'B'}
#define VT100_DOWN_SET {ASCII_ESC, 'O', 'B'}
#define VT100_RIGHT_RESET {ASCII_ESC, 'C'}
#define VT100_RIGHT_SET {ASCII_ESC, 'O', 'C'}
#define VT100_LEFT_RESET {ASCII_ESC, 'D'}
#define VT100_LEFT_SET {ASCII_ESC, 'O', 'D'}
/* Numeric Keypad Keys */
#define VT100_NUMERIC_0 {'0'}
#define VT100_ALT_0 {ASCII_ESC, 'O', 'p'}
#define VT100_NUMERIC_1 {'1'}
#define VT100_ALT_1 {ASCII_ESC, 'O', 'q'}
#define VT100_NUMERIC_2 {'2'}
#define VT100_ALT_2 {ASCII_ESC, 'O', 'r'}
#define VT100_NUMERIC_3 {'3'}
#define VT100_ALT_3 {ASCII_ESC, 'O', 's'}
#define VT100_NUMERIC_4 {'4'}
#define VT100_ALT_4 {ASCII_ESC, 'O', 't'}
#define VT100_NUMERIC_5 {'5'}
#define VT100_ALT_5 {ASCII_ESC, 'O', 'u'}
#define VT100_NUMERIC_6 {'6'}
#define VT100_ALT_6 {ASCII_ESC, 'O', 'v'}
#define VT100_NUMERIC_7 {'7'}
#define VT100_ALT_7 {ASCII_ESC, 'O', 'w'}
#define VT100_NUMERIC_8 {'8'}
#define VT100_ALT_8 {ASCII_ESC, 'O', 'x'}
#define VT100_NUMERIC_9 {'9',
#define VT100_ALT_9 {ASCII_ESC, 'O', 'y'}
#define VT100_NUMERIC_MINUS {'-'}
#define VT100_ALT_MINUS {ASCII_ESC, 'O', 'm'}
#define VT100_NUMERIC_COMMA {','}
#define VT100_ALT_COMMA {ASCII_ESC, 'O', 'l'}
#define VT100_NUMERIC_PERIOD {'.'}
#define VT100_ALT_PERIOD {ASCII_ESC, 'O', 'n'}
#define VT100_NUMERIC_ENTER {ASCII_CR}
#define VT100_ALT_ENTER {ASCII_ESC, 'O', 'M'}
/********************************************************************************************
* Public Data
********************************************************************************************/
/********************************************************************************************
* Public Function Prototypes
********************************************************************************************/
#endif /* __INCLUDE_NUTTX_VT100_H */