123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299 |
- /********************************************************************************************
- * 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 */
|