This repository has been archived on 2024-04-08. You can view files and clone it, but cannot push or open issues or pull requests.
2017-03-19 07:49:46 +10:00

248 lines
7.7 KiB
C

/* OpenDoors Online Software Programming Toolkit
* (C) Copyright 1991 - 1999 by Brian Pirie.
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation; either
* version 2 of the License, or (at your option) any later version.
*
* This library is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with this library; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
*
*
* File: ODGraph.c
*
* Description: Implements special ANSI/AVATAR control functions.
*
* Revisions: Date Ver Who Change
* ---------------------------------------------------------------
* Oct 13, 1994 6.00 BP New file header format.
* Dec 09, 1994 6.00 BP Standardized coding style.
* Aug 19, 1995 6.00 BP 32-bit portability.
* Nov 11, 1995 6.00 BP Removed register keyword.
* Nov 14, 1995 6.00 BP Added include of odscrn.h.
* Nov 16, 1995 6.00 BP Removed oddoor.h, added odcore.h.
* Nov 16, 1995 6.00 BP Moved local vars here from odcore.c.
* Dec 12, 1995 6.00 BP Added entry, exit and kernel macros.
* Dec 30, 1995 6.00 BP Added ODCALL for calling convention.
* Feb 19, 1996 6.00 BP Changed version number to 6.00.
* Mar 03, 1996 6.10 BP Begin version 6.10.
* Mar 13, 1996 6.10 BP Added od_get_cursor().
* Aug 10, 2003 6.23 SH *nix support
*/
#define BUILDING_OPENDOORS
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include "OpenDoor.h"
#include "ODCore.h"
#include "ODGen.h"
#include "ODScrn.h"
#include "ODKrnl.h"
/* Local private variables. */
static char szANSIClearLine[3] = {27, '[', 'K'};
static char szAvatarClearLine[2] = {22, 7};
/* ----------------------------------------------------------------------------
* od_clr_line()
*
* Clears the contents of the current line, from the current cursor position
* to the end of the line. This function affects both local and remote
* screens.
*
* Parameters: None.
*
* Return: void
*/
ODAPIDEF void ODCALL od_clr_line(void)
{
char *pchLine;
INT nCharsLeft;
INT nCount;
/* Log function entry if running in trace mode. */
TRACE(TRACE_API, "od_clr_line()");
/* Ensure that OpenDoors has been initialized. */
if(!bODInitialized) od_init();
OD_API_ENTRY();
/* Obtain the current cursor position. */
ODScrnGetTextInfo(&ODTextInfo);
/* Calculate the number of columns that are to be erased. */
nCharsLeft = 80 - ODTextInfo.curx;
/* If either ANSI or AVATAR mode is available, then we first */
/* clear the line on the local screen without affecting the */
/* remote screen. */
if(od_control.user_avatar || od_control.user_ansi)
{
pchLine = (char *)szODWorkString;
for(nCount = 0; nCount <= nCharsLeft; ++nCount) *pchLine++ = ' ';
*pchLine = '\0';
ODScrnEnableScrolling(0);
ODScrnDisplayString(szODWorkString);
ODScrnEnableScrolling(1);
ODScrnSetCursorPos(ODTextInfo.curx, ODTextInfo.cury);
}
/* If AVATAR mode is active. */
if(od_control.user_avatar)
{
/* Transmit the two-character AVATAR clear to end of line sequence. */
od_disp(szAvatarClearLine, 2, FALSE);
}
/* If ANSI mode is active. */
else if(od_control.user_ansi)
{
/* Transmit the three-character ANSI clear to end of line sequence. */
od_disp(szANSIClearLine, 3, FALSE);
}
/* If we are operating in plain-ASCII mode. */
else
{
/* Generate a sequence of space characters followed by backspace */
/* characters. */
pchLine = (char *)szODWorkString;
for(nCount = 0; nCount < nCharsLeft; ++nCount) *pchLine++ = ' ';
for(nCount = 0; nCount < nCharsLeft; ++nCount) *pchLine++ = 8;
*pchLine='\0';
/* Send this sequence to both the local and remote screens. */
od_disp(szODWorkString, strlen(szODWorkString), TRUE);
}
OD_API_EXIT();
}
/* ----------------------------------------------------------------------------
* od_set_cursor()
*
* Moves the position of the cursor on both local and remote screens. This
* function is available in all display modes other than plain-ASCII.
*
* Parameters: nRow - 1-based index of the row to position the cursor in.
*
* nColumn - Index of the column to position the cursor in.
*
* Return: void
*/
ODAPIDEF void ODCALL od_set_cursor(INT nRow, INT nColumn)
{
static char szControlSequence[40];
/* Log function entry if running in trace mode. */
TRACE(TRACE_API, "od_set_cursor()");
/* Ensure that OpenDoors has been initialized. */
if(!bODInitialized) od_init();
OD_API_ENTRY();
/* Check validity of parameters. */
if(nRow < 1 || nColumn < 1)
{
od_control.od_error = ERR_PARAMETER;
return;
}
/* If AVATAR mode is on. */
if(od_control.user_avatar)
{
/* Position the local cursor. */
ODScrnSetCursorPos((BYTE)nColumn, (BYTE)nRow);
/* Generate the AVATAR control sequence to position the remote cursor. */
szControlSequence[0] = 22;
szControlSequence[1] = 8;
szControlSequence[2] = nRow;
szControlSequence[3] = nColumn;
/* Transmit the AVATAR control sequence to the remote terminal. */
od_disp(szControlSequence, 4, FALSE);
}
/* If ANSI mode is on. */
else if(od_control.user_ansi)
{
/* Generate the ANSI control sequence to position the remote cursor. */
sprintf(szControlSequence, "x[%d;%dH", nRow, nColumn);
szControlSequence[0] = 27;
/* Transmit the ANSI control seequence to the remote terminal. */
od_disp(szControlSequence, strlen(szControlSequence), FALSE);
/* Position the cursor on the local screen. */
ODScrnSetCursorPos((BYTE)nColumn, (BYTE)nRow);
}
else
{
/* If neither ANSI nor AVATAR modes are available, indicate this */
/* in the error code in od_control. */
od_control.od_error = ERR_NOGRAPHICS;
}
OD_API_EXIT();
}
/* ----------------------------------------------------------------------------
* od_get_cursor()
*
* Returns our best estimate of the current position of the cursor on the
* remote screen.
*
* Parameters: pnRow - 1-based index of the row to position the cursor in.
*
* pnColumn - Index of the column to position the cursor in.
*
* Return: void
*/
ODAPIDEF void ODCALL od_get_cursor(INT *pnRow, INT *pnColumn)
{
tODScrnTextInfo TextInfo;
/* Log function entry if running in trace mode. */
TRACE(TRACE_API, "od_get_cursor()");
/* Ensure that OpenDoors has been initialized. */
if(!bODInitialized) od_init();
OD_API_ENTRY();
/* Check for parameter validity. */
if(pnRow == NULL && pnColumn == NULL)
{
od_control.od_error = ERR_PARAMETER;
OD_API_EXIT();
return;
}
/* Obtain current state of local screen. */
ODScrnGetTextInfo(&TextInfo);
/* Set the caller's parameters to the current row and column, if each */
/* of these parameters were supplied. */
if(pnRow != NULL) *pnRow = (INT)TextInfo.cury;
if(pnColumn != NULL) *pnColumn = (INT)TextInfo.curx;
OD_API_EXIT();
}