From a15c5c319a2a275ce76dcaf91c3b48b2fc38987e Mon Sep 17 00:00:00 2001
From: tg <tg@mirbsd.org>
Date: Tue, 1 Aug 2006 14:35:44 +0000
Subject: [PATCH] * use modulo operation, Mr Glockner * allow promptlen to
 return values > $COLUMNS

---
 edit.c |  4 ++--
 lex.c  | 42 +++++++++++++++++++++++++++++-------------
 2 files changed, 31 insertions(+), 15 deletions(-)

diff --git a/edit.c b/edit.c
index 7ca7fb2..6160ecb 100644
--- a/edit.c
+++ b/edit.c
@@ -5,7 +5,7 @@
 
 #include "sh.h"
 
-__RCSID("$MirOS: src/bin/mksh/edit.c,v 1.26 2006/08/01 14:10:24 tg Exp $");
+__RCSID("$MirOS: src/bin/mksh/edit.c,v 1.27 2006/08/01 14:35:43 tg Exp $");
 
 /* tty driver characters we are interested in */
 typedef struct {
@@ -1241,7 +1241,7 @@ x_emacs(char *buf, size_t len)
 	x_adj_ok = 1;
 	prompt_redraw = 1;
 	if (x_col > xx_cols)
-		x_col = x_col - (x_col / xx_cols) * xx_cols;
+		x_col %= xx_cols;
 	x_displen = xx_cols - 2 - x_col;
 	x_adj_done = 0;
 
diff --git a/lex.c b/lex.c
index 32621b1..81f106a 100644
--- a/lex.c
+++ b/lex.c
@@ -2,7 +2,7 @@
 
 #include "sh.h"
 
-__RCSID("$MirOS: src/bin/mksh/lex.c,v 1.16 2006/08/01 14:10:25 tg Exp $");
+__RCSID("$MirOS: src/bin/mksh/lex.c,v 1.17 2006/08/01 14:35:44 tg Exp $");
 
 /* Structure to keep track of the lexing state and the various pieces of info
  * needed for each particular state. */
@@ -58,6 +58,8 @@ static void	gethere(void);
 static Lex_state *push_state_(State_info *, Lex_state *);
 static Lex_state *pop_state_(State_info *, Lex_state *);
 
+static int dopprompt(const char *, int, const char **, int);
+
 static int backslash_skip;
 static int ignore_backslash_newline;
 
@@ -1085,18 +1087,10 @@ set_prompt(int to, Source *s)
 	}
 }
 
-/* See also related routine, promptlen() in edit.c */
-void
-pprompt(const char *cp, int ntruncate)
+static int
+dopprompt(const char *cp, int ntruncate, const char **spp, int doprint)
 {
-	shf_puts(cp + ntruncate, shl_out);
-	shf_flush(shl_out);
-}
-
-int
-promptlen(const char *cp, const char **spp)
-{
-	int count = 0;
+	int count = 0, lines = 0;
 	const char *sp = cp;
 	char delimiter = 0;
 	int indelimit = 0;
@@ -1112,10 +1106,17 @@ promptlen(const char *cp, const char **spp)
 		cp += 2;
 	}
 	for (; *cp; cp++) {
+		if (!indelimit && ntruncate)
+			--ntruncate;
+		else if (doprint) {
+			shf_puts(cp, shl_out);
+			doprint = 0;
+		}
 		if (indelimit && *cp != delimiter)
 			;
 		else if (*cp == '\n' || *cp == '\r') {
 			count = 0;
+			++lines;
 			sp = cp + 1;
 		} else if (*cp == '\t') {
 			count = (count | 7) + 1;
@@ -1129,7 +1130,22 @@ promptlen(const char *cp, const char **spp)
 	}
 	if (spp)
 		*spp = sp;
-	return count;
+	if (doprint)
+		shf_flush(shl_out);
+	return (count + (lines * x_cols));
+}
+
+
+void
+pprompt(const char *cp, int ntruncate)
+{
+	dopprompt(cp, ntruncate, NULL, 1);
+}
+
+int
+promptlen(const char *cp, const char **spp)
+{
+	return (dopprompt(cp, 0, spp, 0));
 }
 
 /* Read the variable part of a ${...} expression (ie, up to but not including