• src/sbbs3/ansiterm.cpp

    From rswindell to CVS commit on Tue Apr 21 21:35:15 2020
    src/sbbs3 ansiterm.cpp 1.23 1.24
    Update of /cvsroot/sbbs/src/sbbs3
    In directory cvs:/tmp/cvs-serv19787

    Modified Files:
    ansiterm.cpp
    Log Message:
    Spell-checkers in code editors weren't really a thing 30 years ago.

  • From rswindell to CVS commit on Sun May 24 00:36:55 2020
    src/sbbs3 ansiterm.cpp 1.25 1.26
    Update of /cvsroot/sbbs/src/sbbs3
    In directory cvs:/tmp/cvs-serv17994

    Modified Files:
    ansiterm.cpp
    Log Message:
    ansi_getxy() - handle unexpected cursor-position responses and stuff into the keyboard buffer (at the end) corrrectly. Previously, only part of the unexpected response would be placed in the keyboard buffer.

  • From rswindell to CVS commit on Sun May 24 01:26:09 2020
    src/sbbs3 ansiterm.cpp 1.26 1.27
    Update of /cvsroot/sbbs/src/sbbs3
    In directory cvs:/home/rswindell/sbbs/src/sbbs3

    Modified Files:
    ansiterm.cpp
    Log Message:
    Resolve GCC warning: comparison between signed and unsigned integer expressions


  • From Rob Swindell to Git commit to main/sbbs/master on Fri Oct 21 12:10:19 2022
    https://gitlab.synchro.net/main/sbbs/-/commit/25b0e6d73356cc16b825a1a0
    Modified Files:
    src/sbbs3/ansiterm.cpp
    Log Message:
    Fix lost 'unexpected characters' received in ANSI get cursor position response

    Unexpected characters received (maybe typed by the user) were supposed to
    be stuffed in the keyboard input buffer using ungetstr(), but the input string was cleared rather than NUL-terminated before logging the expected character and calling ungetstr(), so nothing (a blank string) was logged and nothing was stuffed in the keyboard input-buffer in this case. Just an off-by-one bug.

    This should fix issue #304. Thanks to Keyop and Nelgin for their persistence
    in reporting and testing (in #synchronet at irc.synchro.net).
  • From Rob Swindell to Git commit to main/sbbs/master on Sat Oct 22 11:06:57 2022
    https://gitlab.synchro.net/main/sbbs/-/commit/6812da2fd3c14d77c0b5c401
    Modified Files:
    src/sbbs3/ansiterm.cpp
    Log Message:
    Fix CID 319174 (Out-of-bounds write) correctly

    This Coverity reported issue was previously resolved (incorrectly) with
    commit 0c441424 which also introduced a bug that ate all the unexpected
    cursor position report characters (causing issue #304).

    The correct fix was to compare the response length against the buffer size minus one, to leave room for the NUL terminator.

    While fixing this and issue #304, I noticed that this function was using the response length ('rsp') as both the state machine state and string length, which didn't work right if a nearly-matching report/response was received:
    the x/y values would have been stripped from the response before stuffing
    in the keyboard input buffer. So a bit of a refactor here using a proper
    state machine variable.
  • From Rob Swindell (in GitKraken) to Git commit to main/sbbs/master on Mon Mar 20 17:56:11 2023
    https://gitlab.synchro.net/main/sbbs/-/commit/d93e48b017307d53e00bd858
    Modified Files:
    src/sbbs3/ansiterm.cpp
    Log Message:
    Remove the call to sync() from ansi_getlines()

    This was needed back in the v2 days to be sure the escape sequence was sent *after* an output buffer before might've been cleared by a user's abort/Ctrl-C action. SYNC/ASYNC called riosync() which called rioctl(TXSYNC) and we have no equivalent in Synchronet for TCP/IP (modern sbbs). A user's Ctrl-C will clear all pending I/O, but won't prevent subsequent output from being sent (until
    the abort condition is cleared) as used to be the case with serial I/O.