diff options
author | olgeni <olgeni@FreeBSD.org> | 2006-03-21 08:10:27 +0800 |
---|---|---|
committer | olgeni <olgeni@FreeBSD.org> | 2006-03-21 08:10:27 +0800 |
commit | 108ff7864a4bea1732c120526ccc4c49c1bc99b5 (patch) | |
tree | fecc00f5cff44d036e37c8154a3686bd850f4c83 | |
parent | e3332b46799b37fb66eaab68f3453bed137f2b91 (diff) | |
download | freebsd-ports-graphics-108ff7864a4bea1732c120526ccc4c49c1bc99b5.tar.gz freebsd-ports-graphics-108ff7864a4bea1732c120526ccc4c49c1bc99b5.tar.zst freebsd-ports-graphics-108ff7864a4bea1732c120526ccc4c49c1bc99b5.zip |
Fix composed character handling (broken as described in ports/78234).
Obtained from: Gentoo Bug 91878
-rw-r--r-- | x11/eterm/Makefile | 2 | ||||
-rw-r--r-- | x11/eterm/files/patch-src_misc.c | 59 | ||||
-rw-r--r-- | x11/eterm/files/patch-src_misc.h | 13 | ||||
-rw-r--r-- | x11/eterm/files/patch-src_options.c | 17 | ||||
-rw-r--r-- | x11/eterm/files/patch-src_windows.c | 16 |
5 files changed, 106 insertions, 1 deletions
diff --git a/x11/eterm/Makefile b/x11/eterm/Makefile index 665dd0959c2..faaf7f24a15 100644 --- a/x11/eterm/Makefile +++ b/x11/eterm/Makefile @@ -7,7 +7,7 @@ PORTNAME= eterm PORTVERSION= 0.9.3 -PORTREVISION= 4 +PORTREVISION= 5 CATEGORIES+= x11 MASTER_SITES= http://www.eterm.org/download/ DISTNAME= Eterm-${PORTVERSION} diff --git a/x11/eterm/files/patch-src_misc.c b/x11/eterm/files/patch-src_misc.c new file mode 100644 index 00000000000..fdf71498d0b --- /dev/null +++ b/x11/eterm/files/patch-src_misc.c @@ -0,0 +1,59 @@ + +$FreeBSD$ + +--- src/misc.c.orig ++++ src/misc.c +@@ -223,6 +223,53 @@ + return (pnew - str); + } + ++spif_charptr_t ++escape_string(spif_charptr_t str, spif_char_t quote, spif_int32_t maxlen) ++{ ++ spif_charptr_t buff, s = str, pbuff; ++ ++ D_STRINGS(("escape_string(%s %c %ld)\n", (char *) str, quote, maxlen)); ++ if (! quote) { ++ quote = '\"'; ++ } ++ ++ /* The escaped string will be at most twice the length of the original. */ ++ buff = SPIF_CAST(charptr) MALLOC(strlen(SPIF_CAST_PTR(char) str) * 2 + 1); ++ ++ /* Copy and escape the string from str into buff. */ ++ for (pbuff = buff; (*s); s++, pbuff++) { ++ if (*s == quote) { ++ D_STRINGS(("Double-escaping \'%c\' at position %d\n", *s, s - str)); ++ *pbuff = '\\'; ++ pbuff++; ++ *pbuff = '\\'; ++ pbuff++; ++ } else { ++ if (quote == '\"') { ++ if ((*s == '\\') || (*s == '`')) { ++ D_STRINGS(("Escaping \'%c\' at position %d\n", *s, s - str)); ++ *pbuff = '\\'; ++ pbuff++; ++ } ++ } ++ } ++ D_STRINGS(("Copying \'%c\' at position %d\n", *s, s - str)); ++ *pbuff = *s; ++ } ++ *pbuff = 0; ++ ++ if (maxlen) { ++ /* Given maxlen, we know "str" can hold at least "maxlen" chars. */ ++ if (!spiftool_safe_strncpy(str, buff, maxlen)) { ++ str[maxlen] = 0; ++ } ++ FREE(buff); ++ return str; ++ } else { ++ return buff; ++ } ++} ++ + char * + safe_print_string(const char *str, unsigned long len) + { diff --git a/x11/eterm/files/patch-src_misc.h b/x11/eterm/files/patch-src_misc.h new file mode 100644 index 00000000000..a3c25a74230 --- /dev/null +++ b/x11/eterm/files/patch-src_misc.h @@ -0,0 +1,13 @@ + +$FreeBSD$ + +--- src/misc.h.orig ++++ src/misc.h +@@ -40,6 +40,7 @@ + extern unsigned long str_leading_match(register const char *, register const char *); + extern char *str_trim(char *str); + extern int parse_escaped_string(char *str); ++extern spif_charptr_t escape_string(spif_charptr_t str, spif_char_t quote, spif_int32_t maxlen); + extern char *safe_print_string(const char *buff, unsigned long len); + extern unsigned long add_carriage_returns(unsigned char *buff, unsigned long cnt); + extern unsigned char mkdirhier(const char *); diff --git a/x11/eterm/files/patch-src_options.c b/x11/eterm/files/patch-src_options.c new file mode 100644 index 00000000000..af9f0765545 --- /dev/null +++ b/x11/eterm/files/patch-src_options.c @@ -0,0 +1,17 @@ + +$FreeBSD$ + +--- src/options.c.orig ++++ src/options.c +@@ -3832,7 +3832,10 @@ + } + #ifdef CUTCHAR_OPTION + if (rs_cutchars) { +- fprintf(fp, " cut_chars '%s'\n", rs_cutchars); ++ spif_charptr_t cut_chars_escaped; ++ ++ cut_chars_escaped = escape_string(SPIF_CAST(charptr) rs_cutchars, '\"', 0); ++ fprintf(fp, " cut_chars \"%s\"\n", (char *) cut_chars_escaped); + } + #endif + fprintf(fp, "end misc\n\n"); diff --git a/x11/eterm/files/patch-src_windows.c b/x11/eterm/files/patch-src_windows.c new file mode 100644 index 00000000000..6a481de2462 --- /dev/null +++ b/x11/eterm/files/patch-src_windows.c @@ -0,0 +1,16 @@ + +$FreeBSD$ + +--- src/windows.c.orig ++++ src/windows.c +@@ -467,9 +467,7 @@ + XClearWindow(Xdisplay, TermWin.vt); + } + XDefineCursor(Xdisplay, TermWin.vt, TermWin_cursor); +- TermWin.mask = (KeyPressMask | EnterWindowMask | LeaveWindowMask | ExposureMask +- | ButtonPressMask | ButtonReleaseMask | Button1MotionMask +- | Button2MotionMask | Button3MotionMask); ++ TermWin.mask = (EnterWindowMask | LeaveWindowMask | ExposureMask | ButtonPressMask | ButtonReleaseMask | Button1MotionMask | Button2MotionMask | Button3MotionMask); + XSelectInput(Xdisplay, TermWin.vt, TermWin.mask); + + /* If the user wants a specific desktop, tell the WM that */ |