From 2ddaeb605f4b7a89dab23a843ae79fbdc88afa69 Mon Sep 17 00:00:00 2001 From: Peter Stephenson Date: Wed, 19 Oct 2005 21:59:34 +0000 Subject: 21890: fix segmentation error in left prompt truncation and a couple of minor inconsistencies --- Src/Zle/zle_utils.c | 3 ++- Src/builtin.c | 8 ++++---- Src/prompt.c | 2 +- 3 files changed, 7 insertions(+), 6 deletions(-) (limited to 'Src') diff --git a/Src/Zle/zle_utils.c b/Src/Zle/zle_utils.c index cfc77de27..a65aa05d0 100644 --- a/Src/Zle/zle_utils.c +++ b/Src/Zle/zle_utils.c @@ -787,7 +787,8 @@ showmsg(char const *msg) ZLE_CHAR_T c; #ifdef ZLE_UNICODE_SUPPORT char *umsg; - int ulen, ret, width; + int ulen, ret; + size_t width; mbstate_t ps; #endif diff --git a/Src/builtin.c b/Src/builtin.c index cd1358614..063baa687 100644 --- a/Src/builtin.c +++ b/Src/builtin.c @@ -3368,7 +3368,7 @@ bin_print(char *name, char **args, Options ops, int func) */ char *str = unmetafy(promptexpand(metafy(args[n], len[n], META_NOALLOC), 0, NULL, NULL), &len[n]); - args[n] = dupstring(str); + args[n] = dupstrpfx(str, len[n]); free(str); } /* -D option -- interpret as a directory, and use ~ */ @@ -3378,9 +3378,9 @@ bin_print(char *name, char **args, Options ops, int func) queue_signals(); d = finddir(args[n]); if(d) { - char *arg = zhalloc(strlen(args[n]) + 1); - sprintf(arg, "~%s%s", d->nam, - args[n] + strlen(d->dir)); + int dirlen = strlen(d->dir); + char *arg = zhalloc(len[n] - dirlen + strlen(d->nam) + 2); + sprintf(arg, "~%s%s", d->nam, args[n] + dirlen); args[n] = arg; len[n] = strlen(args[n]); } diff --git a/Src/prompt.c b/Src/prompt.c index f96369760..8b3aa531e 100644 --- a/Src/prompt.c +++ b/Src/prompt.c @@ -1078,7 +1078,7 @@ prompttrunc(int arg, int truncchar, int doprint, int endchar) int remw; mbstate_t mbs; - fulltextptr = fulltext = bp; + fulltextptr = fulltext = ptr + ntrunc; memmove(fulltext, ptr, fullen); fulltext[fullen] = '\0'; -- cgit 1.4.1