/**************************************************************************** * apps/interpreters/bas/bas_vt100.c * * Copyright (C) 2014 Gregory Nutt. All rights reserved. * Author: Gregory Nutt * * 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. * ****************************************************************************/ /**************************************************************************** * Included Files ****************************************************************************/ #include #include #include #include #include "bas_fs.h" #include "bas_vt100.h" /**************************************************************************** * Pre-processor Definitions ****************************************************************************/ /**************************************************************************** * Private Data ****************************************************************************/ /* VT100 escape sequences */ #if 0 /* Not used */ static const char g_cursoron[] = VT100_CURSORON; static const char g_cursoroff[] = VT100_CURSOROFF; #endif static const char g_cursorhome[] = VT100_CURSORHOME; #if 0 /* Not used */ static const char g_erasetoeol[] = VT100_CLEAREOL; #endif static const char g_clrscreen[] = VT100_CLEARSCREEN; #if 0 /* Not used */ static const char g_index[] = VT100_INDEX; static const char g_revindex[] = VT100_REVINDEX; static const char g_attriboff[] = VT100_MODESOFF; static const char g_boldon[] = VT100_BOLD; static const char g_reverseon[] = VT100_REVERSE; static const char g_blinkon[] = VT100_BLINK; static const char g_boldoff[] = VT100_BOLDOFF; static const char g_reverseoff[] = VT100_REVERSEOFF; static const char g_blinkoff[] = VT100_BLINKOFF; #endif static const char g_fmt_cursorpos[] = VT100_FMT_CURSORPOS; static const char g_fmt_forecolor[] = VT100_FMT_FORE_COLOR; static const char g_fmt_backcolor[] = VT100_FMT_BACK_COLOR; /**************************************************************************** * Private Functions ****************************************************************************/ /**************************************************************************** * Name: vt100_write * * Description: * Write a sequence of bytes to the channel device * ****************************************************************************/ static void vt100_write(int chn, FAR const char *buffer, size_t buflen) { for (; buflen > 0; buflen--) { FS_putChar(chn, *buffer++); } } /**************************************************************************** * Public Functions ****************************************************************************/ /**************************************************************************** * Name: vt100_blinkon * * Description: * Enable the blinking attribute at the current cursor location * ****************************************************************************/ #if 0 /* Not used */ void vt100_blinkon(int chn) { /* Send the VT100 BLINKON command */ vt100_write(chn, g_blinkon, sizeof(g_blinkon)); } #endif /**************************************************************************** * Name: vt100_boldon * * Description: * Enable the blinking attribute at the current cursor location * ****************************************************************************/ #if 0 /* Not used */ void vt100_boldon(int chn) { /* Send the VT100 BOLDON command */ vt100_write(chn, g_boldon, sizeof(g_boldon)); } #endif /**************************************************************************** * Name: vt100_reverseon * * Description: * Enable the blinking attribute at the current cursor location * ****************************************************************************/ #if 0 /* Not used */ void vt100_reverseon(int chn) { /* Send the VT100 REVERSON command */ vt100_write(chn, g_reverseon, sizeof(g_reverseon)); } #endif /**************************************************************************** * Name: * * Description: * Disable all previously selected attributes. * ****************************************************************************/ #if 0 /* Not used */ void vt100_attriboff(int chn) { /* Send the VT100 ATTRIBOFF command */ vt100_write(chn, g_attriboff, sizeof(g_attriboff)); } #endif /**************************************************************************** * Name: vt100_cursoron * * Description: * Turn on the cursor * ****************************************************************************/ #if 0 /* Not used */ void vt100_cursoron(int chn) { /* Send the VT100 CURSORON command */ vt100_write(chn, g_cursoron, sizeof(g_cursoron)); } #endif /**************************************************************************** * Name: vt100_cursoroff * * Description: * Turn off the cursor * ****************************************************************************/ #if 0 /* Not used */ void vt100_cursoroff(int chn) { /* Send the VT100 CURSOROFF command */ vt100_write(chn, g_cursoroff, sizeof(g_cursoroff)); } #endif /**************************************************************************** * Name: vt100_cursorhome * * Description: * Move the current cursor to the upper left hand corner of the display * ****************************************************************************/ void vt100_cursorhome(int chn) { /* Send the VT100 CURSORHOME command */ vt100_write(chn, g_cursorhome, sizeof(g_cursorhome)); } /**************************************************************************** * Name: vt100_setcursor * * Description: * Move the current cursor position to position (row,col) * ****************************************************************************/ void vt100_setcursor(int chn, uint16_t row, uint16_t column) { char buffer[16]; int len; /* Format the cursor position command. The origin is (1,1). */ len = snprintf(buffer, 16, g_fmt_cursorpos, row + 1, column + 1); /* Send the VT100 CURSORPOS command */ vt100_write(chn, buffer, len); } /**************************************************************************** * Name: vt100_clrtoeol * * Description: * Clear the display from the current cursor position to the end of the * current line. * ****************************************************************************/ #if 0 /* Not used */ void vt100_clrtoeol(int chn) { /* Send the VT100 ERASETOEOL command */ vt100_write(chn, g_erasetoeol, sizeof(g_erasetoeol)); } #endif /**************************************************************************** * Name: vt100_clrscreen * * Description: * Clear the entire display * ****************************************************************************/ void vt100_clrscreen(int chn) { /* Send the VT100 CLRSCREEN command */ vt100_write(chn, g_clrscreen, sizeof(g_clrscreen)); } /**************************************************************************** * Name: vt100_scrollup * * Description: * Scroll the display up 'nlines' by sending the VT100 INDEX command. * ****************************************************************************/ #if 0 /* Not used */ void vt100_scrollup(int chn, uint16_t nlines) { /* Scroll for the specified number of lines */ for (; nlines; nlines--) { /* Send the VT100 INDEX command */ vt100_write(chn, g_index, sizeof(g_index)); } } #endif /**************************************************************************** * Name: vt100_scrolldown * * Description: * Scroll the display down 'nlines' by sending the VT100 REVINDEX command. * ****************************************************************************/ #if 0 /* Not used */ void vt100_scrolldown(int chn, uint16_t nlines) { /* Scroll for the specified number of lines */ for (; nlines; nlines--) { /* Send the VT100 REVINDEX command */ vt100_write(chn, g_revindex, sizeof(g_revindex)); } #endif /**************************************************************************** * Name: vt100_foreground_color * * Description: * Set the foreground color * ****************************************************************************/ void vt100_foreground_color(int chn, uint8_t color) { char buffer[16]; int len; /* Format the foreground color command. */ DEBUGASSERT(color < 10); len = snprintf(buffer, 16, g_fmt_forecolor, color); /* Send the VT100 foreground color command */ vt100_write(chn, buffer, len); } /**************************************************************************** * Name: vt100_background_color * * Description: * Set the background color * ****************************************************************************/ void vt100_background_color(int chn, uint8_t color) { char buffer[16]; int len; /* Format the background color command. */ DEBUGASSERT(color < 10); len = snprintf(buffer, 16, g_fmt_backcolor, color); /* Send the VT100 background color command */ vt100_write(chn, buffer, len); }