aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorSteve Bennett <steveb@workware.net.au>2012-10-31 13:17:24 +1000
committerSteve Bennett <steveb@workware.net.au>2012-10-31 20:09:47 +1000
commit446c4faa6a6cda3c43ab68df168b3eeec67274b6 (patch)
treeb12c3cf3ff28109b413df49c5321cf991693749a
parent4efbd7b9808abcbaa22099dd9c9703331e849bd2 (diff)
downloadjimtcl-446c4faa6a6cda3c43ab68df168b3eeec67274b6.zip
jimtcl-446c4faa6a6cda3c43ab68df168b3eeec67274b6.tar.gz
jimtcl-446c4faa6a6cda3c43ab68df168b3eeec67274b6.tar.bz2
Fix linenoise serial console window size for vt102
This includes minicom, which doesn't support hpa (CHA), only cuf. Signed-off-by: Steve Bennett <steveb@workware.net.au>
-rw-r--r--linenoise.c18
1 files changed, 9 insertions, 9 deletions
diff --git a/linenoise.c b/linenoise.c
index e6f8ede..281828b 100644
--- a/linenoise.c
+++ b/linenoise.c
@@ -56,10 +56,6 @@
* flickering effect with some slow terminal, but the lesser sequences
* the more compatible.
*
- * CHA (Cursor Horizontal Absolute)
- * Sequence: ESC [ n G
- * Effect: moves cursor to column n (1 based)
- *
* EL (Erase Line)
* Sequence: ESC [ n K
* Effect: if n is 0 or missing, clear from cursor to end of line
@@ -70,6 +66,10 @@
* Sequence: ESC [ n C
* Effect: moves cursor forward of n chars
*
+ * CR (Carriage Return)
+ * Sequence: \r
+ * Effect: moves cursor to column 1
+ *
* The following are used to clear the screen: ESC [ H ESC [ 2 J
* This is actually composed of two sequences:
*
@@ -289,7 +289,7 @@ static void clearScreen(struct current *current)
static void cursorToLeft(struct current *current)
{
- fd_printf(current->fd, "\x1b[1G");
+ fd_printf(current->fd, "\r");
}
static int outputChars(struct current *current, const char *buf, int len)
@@ -299,7 +299,7 @@ static int outputChars(struct current *current, const char *buf, int len)
static void outputControlChar(struct current *current, char ch)
{
- fd_printf(current->fd, "\033[7m^%c\033[0m", ch);
+ fd_printf(current->fd, "\x1b[7m^%c\x1b[0m", ch);
}
static void eraseEol(struct current *current)
@@ -309,7 +309,7 @@ static void eraseEol(struct current *current)
static void setCursorPos(struct current *current, int x)
{
- fd_printf(current->fd, "\x1b[1G\x1b[%dC", x);
+ fd_printf(current->fd, "\r\x1b[%dC", x);
}
/**
@@ -388,8 +388,8 @@ static int getWindowSize(struct current *current)
if (current->cols == 0) {
current->cols = 80;
- /* Move cursor far right and report cursor position */
- fd_printf(current->fd, "\x1b[999G" "\x1b[6n");
+ /* Move cursor far right and report cursor position, then back to the left */
+ fd_printf(current->fd, "\x1b[999C" "\x1b[6n");
/* Parse the response: ESC [ rows ; cols R */
if (fd_read_char(current->fd, 100) == 0x1b && fd_read_char(current->fd, 100) == '[') {