diff options
author | keichii <keichii@FreeBSD.org> | 2001-10-02 03:46:41 +0800 |
---|---|---|
committer | keichii <keichii@FreeBSD.org> | 2001-10-02 03:46:41 +0800 |
commit | af3efc7f55ea7e6a3dfa76bdf5532b8458c013c6 (patch) | |
tree | 02fce9d736392dcd6192bca5e72e19f066adc57c /chinese/aterm/files | |
parent | 0695121a1d98f5e0a0ee565c639d926d2b2ba355 (diff) | |
download | freebsd-ports-gnome-af3efc7f55ea7e6a3dfa76bdf5532b8458c013c6.tar.gz freebsd-ports-gnome-af3efc7f55ea7e6a3dfa76bdf5532b8458c013c6.tar.zst freebsd-ports-gnome-af3efc7f55ea7e6a3dfa76bdf5532b8458c013c6.zip |
Add aterm 0.4.2,
a color vt102 terminal emulator with transparency
support and XIM support.
PR: 30950
Submitted by: gugod@gugod.org
Diffstat (limited to 'chinese/aterm/files')
-rw-r--r-- | chinese/aterm/files/patch-aa | 1064 |
1 files changed, 1064 insertions, 0 deletions
diff --git a/chinese/aterm/files/patch-aa b/chinese/aterm/files/patch-aa new file mode 100644 index 000000000000..74e0ef524175 --- /dev/null +++ b/chinese/aterm/files/patch-aa @@ -0,0 +1,1064 @@ +diff -cNr aterm-0.4.2.orig/autoconf/acconfig.h aterm-0.4.2/autoconf/acconfig.h +*** aterm-0.4.2.orig/autoconf/acconfig.h Fri Sep 7 00:38:07 2001 +--- aterm-0.4.2/autoconf/acconfig.h Sun Sep 30 15:13:21 2001 +*************** +*** 38,44 **** +--- 38,49 ---- + /* Define if Xlocale support doesn't work */ + #undef NO_XLOCALE + ++ #undef USE_XIM ++ + /* Define is setlocale (defined to Xsetlocale) doesn't work */ ++ #undef NO_XSETLOCALE ++ ++ /* Define is plain setlocale doesn't work */ + #undef NO_SETLOCALE + + /* Define if you want Menubar support */ +diff -cNr aterm-0.4.2.orig/autoconf/config.h.in aterm-0.4.2/autoconf/config.h.in +*** aterm-0.4.2.orig/autoconf/config.h.in Fri Sep 7 00:38:07 2001 +--- aterm-0.4.2/autoconf/config.h.in Sun Sep 30 15:14:08 2001 +*************** +*** 88,94 **** +--- 88,99 ---- + /* Define if Xlocale support doesn't work */ + #undef NO_XLOCALE + ++ #undef USE_XIM ++ + /* Define is setlocale (defined to Xsetlocale) doesn't work */ ++ #undef NO_XSETLOCALE ++ ++ /* Define is plain setlocale doesn't work */ + #undef NO_SETLOCALE + + /* Define if you want Menubar support */ +diff -cNr aterm-0.4.2.orig/autoconf/configure.in aterm-0.4.2/autoconf/configure.in +*** aterm-0.4.2.orig/autoconf/configure.in Fri Sep 7 00:38:07 2001 +--- aterm-0.4.2/autoconf/configure.in Sun Sep 30 15:18:11 2001 +*************** +*** 106,111 **** +--- 106,117 ---- + AC_DEFINE(ZH) + fi]) + ++ AC_ARG_ENABLE(xim, ++ [ --enable-xim enable xim support], ++ [if test x$enableval = xyes; then ++ AC_DEFINE(USE_XIM) ++ fi]) ++ + AC_ARG_ENABLE(greek, + [ --enable-greek enable greek keyboard support], + [if test x$enableval = xyes; then +*************** +*** 642,647 **** +--- 648,654 ---- + dnl# this is a really hack test for some basic Xlocale stuff + SAVETHELIBS=$LIBS + LIBS="$LIBS $X_LIBS $X_PRE_LIBS $X_EXTRA_LIBS -lX11" ++ CFLAGS="$CFLAGS $X_CFLAGS" + AC_CACHE_CHECK(for working Xlocale, rxvt_cv_func_xlocale, + [AC_TRY_RUN( + [#define X_LOCALE 1 +*************** +*** 667,672 **** +--- 674,687 ---- + [setlocale(LC_CTYPE, "");], + rxvt_cv_func_xsetlocale=yes, rxvt_cv_func_xsetlocale=no)]) + if test "${rxvt_cv_func_xsetlocale}" = no; then ++ AC_DEFINE(NO_XSETLOCALE) ++ fi ++ ++ AC_CACHE_CHECK(for working plain setlocale, rxvt_cv_func_setlocale, ++ [AC_TRY_LINK([#include <locale.h>], ++ [setlocale(LC_CTYPE, "");], ++ rxvt_cv_func_setlocale=yes, rxvt_cv_func_setlocale=no)]) ++ if test x${rxvt_cv_func_setlocale} = xno; then + AC_DEFINE(NO_SETLOCALE) + fi + +diff -cNr aterm-0.4.2.orig/configure aterm-0.4.2/configure +*** aterm-0.4.2.orig/configure Fri Sep 7 00:38:07 2001 +--- aterm-0.4.2/configure Sun Sep 30 17:00:35 2001 +*************** +*** 36,41 **** +--- 36,43 ---- + ac_help="$ac_help + --enable-big5 enable big5 support" + ac_help="$ac_help ++ --enable-xim enable xim support" ++ ac_help="$ac_help + --enable-greek enable greek keyboard support" + ac_help="$ac_help + --enable-thai enable thai support" +*************** +*** 786,791 **** +--- 788,804 ---- + fi + fi + ++ # Check whether --enable-xim or --disable-xim was given. ++ if test "${enable_xim+set}" = set; then ++ enableval="$enable_xim" ++ if test x$enableval = xyes; then ++ cat >> confdefs.h <<\EOF ++ #define USE_XIM 1 ++ EOF ++ ++ fi ++ fi ++ + + # Check whether --enable-greek or --disable-greek was given. + if test "${enable_greek+set}" = set; then +*************** +*** 4649,4654 **** +--- 4662,4668 ---- + + SAVETHELIBS=$LIBS + LIBS="$LIBS $X_LIBS $X_PRE_LIBS $X_EXTRA_LIBS -lX11" ++ CFLAGS="$CFLAGS $X_CFLAGS" + echo $ac_n "checking for working Xlocale""... $ac_c" 1>&6 + echo "configure:4654: checking for working Xlocale" >&5 + if eval "test \"`echo '$''{'rxvt_cv_func_xlocale'+set}'`\" = set"; then +*************** +*** 4724,4730 **** + echo "$ac_t""$rxvt_cv_func_xsetlocale" 1>&6 + if test "${rxvt_cv_func_xsetlocale}" = no; then + cat >> confdefs.h <<\EOF +! #define NO_SETLOCALE 1 + EOF + + fi +--- 4738,4777 ---- + echo "$ac_t""$rxvt_cv_func_xsetlocale" 1>&6 + if test "${rxvt_cv_func_xsetlocale}" = no; then + cat >> confdefs.h <<\EOF +! #define NO_XSETLOCALE 1 +! EOF +! +! fi +! +! echo $ac_n "checking for working plain setlocale""... $ac_c" 1>&6 +! echo "configure:4659: checking for working plain setlocale" >&5 +! if eval "test \"`echo '$''{'rxvt_cv_func_setlocale'+set}'`\" = set"; then +! echo $ac_n "(cached) $ac_c" 1>&6 +! else +! cat > conftest.$ac_ext <<EOF +! #line 4664 "configure" +! #include "confdefs.h" +! #include <locale.h> +! int main() { +! setlocale(LC_CTYPE, ""); +! ; return 0; } +! EOF +! if { (eval echo configure:4671: \"$ac_link\") 1>&5; (eval $ac_link) 2>&5; } && test -s conftest${ac_exeext}; then +! rm -rf conftest* +! rxvt_cv_func_setlocale=yes +! else +! echo "configure: failed program was:" >&5 +! cat conftest.$ac_ext >&5 +! rm -rf conftest* +! rxvt_cv_func_setlocale=no +! fi +! rm -f conftest* +! fi +! +! echo "$ac_t""$rxvt_cv_func_setlocale" 1>&6 +! if test x${rxvt_cv_func_setlocale} = xno; then +! cat >> confdefs.h <<\EOF +! efine NO_SETLOCALE 1 + EOF + + fi +diff -cNr aterm-0.4.2.orig/scripts/random_colors aterm-0.4.2/scripts/random_colors +*** aterm-0.4.2.orig/scripts/random_colors Thu Jan 1 08:00:00 1970 +--- aterm-0.4.2/scripts/random_colors Sun Sep 30 17:01:24 2001 +*************** +*** 0 **** +--- 1,18 ---- ++ #!/bin/bash ++ ++ # This script will launch aterm with different tinting color ++ # every time you start it ++ # I don't really know how that can be of any use at all, but some ++ # folks like it - so here it is ++ ++ CLRCODE=`expr $RANDOM % 6` ++ ATRMPATH=$DESTDIR/usr/local/bin ++ ++ { [ "$CLRCODE" -eq "0" ] && CLRNAME="-tint blue -fg yellow -bg black"; } || ++ { [ "$CLRCODE" -eq "1" ] && CLRNAME="-tint red -fg white -bg black"; } || ++ { [ "$CLRCODE" -eq "2" ] && CLRNAME="-tint green -fg white -bg white"; } || ++ { [ "$CLRCODE" -eq "3" ] && CLRNAME="-tint cyan -fg white -bg white"; } || ++ { [ "$CLRCODE" -eq "4" ] && CLRNAME="-tint magenta -fg white -bg black"; } || ++ { [ "$CLRCODE" -eq "5" ] && CLRNAME="-tint yellow -fg blue -bg white"; } ++ ++ exec $ATRMPATH/aterm -fg white -tr $CLRNAME $@ +diff -cNr aterm-0.4.2.orig/src/command.c aterm-0.4.2/src/command.c +*** aterm-0.4.2.orig/src/command.c Fri Sep 7 00:38:07 2001 +--- aterm-0.4.2/src/command.c Sun Sep 30 14:36:49 2001 +*************** +*** 69,80 **** + #ifndef NO_XLOCALE + # if (XtSpecificationRelease < 6) + # define NO_XLOCALE +- # else +- # define X_LOCALE +- # include <X11/Xlocale.h> + # endif + #endif /* NO_XLOCALE */ + + #ifdef TTY_GID_SUPPORT + # include <grp.h> + #endif +--- 69,87 ---- + #ifndef NO_XLOCALE + # if (XtSpecificationRelease < 6) + # define NO_XLOCALE + # endif + #endif /* NO_XLOCALE */ + ++ #ifndef NO_XSETLOCALE ++ # define X_LOCALE ++ # include <X11/Xlocale.h> ++ #else ++ # ifndef NO_SETLOCALE ++ # include <locale.h> ++ # endif ++ #endif /* NO_XLOCALE */ ++ ++ + #ifdef TTY_GID_SUPPORT + # include <grp.h> + #endif +*************** +*** 182,190 **** + + /*{{{ defines: */ + +! #define KBUFSZ 8 /* size of keyboard mapping buffer */ +! #define STRING_MAX 512 /* max string size for process_xterm_seq() */ +! #define ESC_ARGS 32 /* max # of args for esc sequences */ + + /* a large REFRESH_PERIOD causes problems with `cat' */ + #define REFRESH_PERIOD 1 +--- 189,201 ---- + + /*{{{ defines: */ + +! #ifdef USE_XIM +! # define KBUFSZ 64 /* size of keyboard mapping buffer */ +! #else +! # define KBUFSZ 8 /* size of keyboard mapping buffer */ +! #endif +! #define STRING_MAX 512 /* max string size for process_xterm_seq() */ +! #define ESC_ARGS 32 /* max # of args for esc sequences */ + + /* a large REFRESH_PERIOD causes problems with `cat' */ + #define REFRESH_PERIOD 1 +*************** +*** 308,318 **** +--- 319,333 ---- + static Atom DndProtocol, DndSelection; + #endif /* OFFIX_DND */ + ++ #ifdef USE_XIM ++ static XIC Input_Context; /* input context */ ++ #else + #ifndef NO_XLOCALE + static char *rs_inputMethod = ""; /* XtNinputMethod */ + static char *rs_preeditType = NULL; /* XtNpreeditType */ + static XIC Input_Context; /* input context */ + #endif /* NO_XLOCALE */ ++ #endif /* USE_XIM */ + + /* command input buffering */ + #ifndef BUFSIZ +*************** +*** 534,540 **** + ttydev = tty_name; + + # define PTYCHAR1 "pqrstuvwxyz" +! # define PTYCHAR2 "0123456789abcdef" + for (c1 = PTYCHAR1; *c1; c1++) { + ptydev[len - 2] = ttydev[len - 2] = *c1; + for (c2 = PTYCHAR2; *c2; c2++) { +--- 549,555 ---- + ttydev = tty_name; + + # define PTYCHAR1 "pqrstuvwxyz" +! # define PTYCHAR2 "0123456789abcdefghijklmnopqrstuvwxyz" + for (c1 = PTYCHAR1; *c1; c1++) { + ptydev[len - 2] = ttydev[len - 2] = *c1; + for (c2 = PTYCHAR2; *c2; c2++) { +*************** +*** 1137,1143 **** +--- 1152,1167 ---- + DndSelection = XInternAtom(Xdisplay, "DndSelection", False); + #endif /* OFFIX_DND */ + ++ #ifndef NO_XLOCALE + init_xlocale(); ++ #else ++ setlocale(LC_CTYPE, ""); ++ #endif ++ ++ #ifdef USE_XIM ++ setTermFontSet(); ++ XRegisterIMInstantiateCallback(Xdisplay, NULL, NULL, NULL, IMInstantiateCallback, NULL); ++ #endif + + /* get number of available file descriptors */ + #ifdef _POSIX_VERSION +*************** +*** 1204,1209 **** +--- 1228,1234 ---- + init_xlocale(void) + { + #ifndef NO_XLOCALE ++ #ifndef USE_XIM + char *p, *s, buf[32], tmp[1024]; + XIM xim = NULL; + XIMStyle input_style = 0; +*************** +*** 1212,1218 **** + + Input_Context = NULL; + +! # ifndef NO_SETLOCALE + /* setlocale(LC_CTYPE, ""); /* XXX: should we do this? */ + # endif + if (rs_inputMethod == NULL || !*rs_inputMethod) { +--- 1237,1243 ---- + + Input_Context = NULL; + +! # if !defined(NO_SETLOCALE) || !defined(NO_XSETLOCALE) + /* setlocale(LC_CTYPE, ""); /* XXX: should we do this? */ + # endif + if (rs_inputMethod == NULL || !*rs_inputMethod) { +*************** +*** 1311,1316 **** +--- 1336,1342 ---- + print_error("Failed to create input context"); + XCloseIM(xim); + } ++ #endif /* USE_XIM */ + #endif /* NO_XLOCALE */ + } + /*}}} */ +*************** +*** 1379,1400 **** + numlock_state = (ev->xkey.state & ModNumLockMask); /* numlock toggle */ + PrivMode((!numlock_state), PrivMode_aplKP); + } +! #ifndef NO_XLOCALE +! if (!XFilterEvent(ev, *(&ev->xkey.window))) { +! if (Input_Context != NULL) { +! Status status_return; +! +! len = XmbLookupString(Input_Context, &ev->xkey, kbuf, +! sizeof(kbuf), &keysym, +! &status_return); +! } else { +! len = XLookupString(&ev->xkey, kbuf, +! sizeof(kbuf), &keysym, +! &compose); +! } +! } else +! len = 0; +! #else /* NO_XLOCALE */ + len = XLookupString(&ev->xkey, (char *) kbuf, sizeof(kbuf), &keysym, &compose); + /* + * have unmapped Latin[2-4] entries -> Latin1 +--- 1405,1425 ---- + numlock_state = (ev->xkey.state & ModNumLockMask); /* numlock toggle */ + PrivMode((!numlock_state), PrivMode_aplKP); + } +! #ifdef USE_XIM +! len = 0; +! if (Input_Context != NULL) { +! Status status_return; +! +! kbuf[0] = '\0'; +! len = XmbLookupString(Input_Context, &ev->xkey, kbuf, +! sizeof(kbuf), &keysym, +! &status_return); +! } else { +! len = XLookupString(&ev->xkey, kbuf, +! sizeof(kbuf), &keysym, +! &compose); +! } +! #else /* USE_XIM */ + len = XLookupString(&ev->xkey, (char *) kbuf, sizeof(kbuf), &keysym, &compose); + /* + * have unmapped Latin[2-4] entries -> Latin1 +*************** +*** 1404,1410 **** + len = 1; + kbuf[0] = (keysym & 0xFF); + } +! #endif /* NO_XLOCALE */ + + if (len && (Options & Opt_scrollKeypress)) + TermWin.view_start = 0; +--- 1429,1435 ---- + len = 1; + kbuf[0] = (keysym & 0xFF); + } +! #endif /* USE_XIM */ + + if (len && (Options & Opt_scrollKeypress)) + TermWin.view_start = 0; +*************** +*** 1977,1984 **** +--- 2002,2013 ---- + XEvent ev; + + refreshed = 0; ++ #ifdef USE_XIM ++ XProcessEvent(Xdisplay); ++ #else + XNextEvent(Xdisplay, &ev); + process_x_event(&ev); ++ #endif + + /* in case button actions pushed chars to cmdbuf */ + if (cmdbuf_ptr < cmdbuf_endp) +*************** +*** 2050,2055 **** +--- 2079,2087 ---- + refreshed = 1; + scr_refresh(refresh_type); + scrollbar_show(1); ++ #ifdef USE_XIM ++ IMSendSpot(); ++ #endif + } + } + } +*************** +*** 2225,2231 **** + on_colors_changed(Color_bg); + } + #endif +! #ifndef NO_XLOCALE + if (Input_Context != NULL) + XSetICFocus(Input_Context); + #endif +--- 2257,2263 ---- + on_colors_changed(Color_bg); + } + #endif +! #ifndef USE_XIM + if (Input_Context != NULL) + XSetICFocus(Input_Context); + #endif +*************** +*** 2242,2248 **** + on_colors_changed(Color_bg); + } + #endif +! #ifndef NO_XLOCALE + if (Input_Context != NULL) + XUnsetICFocus(Input_Context); + #endif +--- 2274,2280 ---- + on_colors_changed(Color_bg); + } + #endif +! #ifndef USE_XIM + if (Input_Context != NULL) + XUnsetICFocus(Input_Context); + #endif +*************** +*** 2720,2725 **** +--- 2752,2760 ---- + scr_refresh(refresh_type); + refresh_count = refresh_limit = 0; + scrollbar_show(1); ++ #ifdef USE_XIM ++ IMSendSpot(); ++ #endif + } + break; + } +*************** +*** 3444,3449 **** +--- 3479,3487 ---- + } + } + Gr_do_graphics(cmd, nargs, args, text); ++ #ifdef USE_XIM ++ IMSendSpot(); ++ #endif + #endif + } + /*}}} */ +*************** +*** 3611,3617 **** +--- 3649,4013 ---- + } + } + ++ #ifdef USE_XIM ++ /* PROTO */ ++ void ++ setSize( XRectangle *size ) ++ { ++ size->x = TermWin_internalBorder; ++ size->y = TermWin_internalBorder; ++ size->width = Width2Pixel (TermWin.ncol); ++ size->height = Height2Pixel(TermWin.nrow); ++ return; ++ } ++ ++ /* PROTO */ ++ void ++ setColor( unsigned long *fg, unsigned long *bg ) ++ { ++ *fg = PixColors[Color_fg]; ++ *bg = PixColors[Color_bg]; ++ return; ++ } + ++ /* PROTO */ ++ void ++ IMSendSpot( void ) ++ { ++ XPoint spot; ++ XVaNestedList preedit_attr; ++ XIMStyle input_style; ++ ++ if( Input_Context == NULL ) ++ return; ++ else { ++ XGetICValues(Input_Context,XNInputStyle,&input_style,NULL); ++ if (!(input_style & XIMPreeditPosition)) ++ return; ++ } ++ setPosition( &spot ); ++ ++ preedit_attr = XVaCreateNestedList( 0, XNSpotLocation, &spot, NULL ); ++ XSetICValues( Input_Context, XNPreeditAttributes, preedit_attr, NULL ); ++ XFree( preedit_attr ); ++ return; ++ } ++ ++ /* PROTO */ ++ void ++ setTermFontSet( void ) ++ { ++ char *string; ++ long length, i; ++ ++ if( TermWin.fontset != NULL ){ ++ XFreeFontSet( Xdisplay, TermWin.fontset ); ++ TermWin.fontset = NULL; ++ } ++ ++ length = 0; ++ for( i = 0 ; i < NFONTS ; i ++){ ++ if( rs_font[ i ] ) ++ length += strlen( rs_font[ i ] ) + 1; ++ # ifdef MULTICHAR_SET ++ if( rs_mfont[ i ] ) ++ length += strlen( rs_mfont[ i ] ) + 1; ++ # endif ++ } ++ if( ( string = malloc( length ) ) != NULL ){ ++ char **missing_charsetlist, *def_string; ++ int missing_charsetcount; ++ ++ string[ 0 ] = '\0'; ++ for( i = 0 ; i < NFONTS ; i ++){ ++ if( rs_font[ i ] ){ ++ strcat( string, rs_font[ i ] ); ++ strcat( string, "," ); ++ } ++ # ifdef MULTICHAR_SET ++ if( rs_mfont[ i ] ){ ++ strcat( string, rs_mfont[ i ] ); ++ strcat( string, "," ); ++ } ++ # endif ++ } ++ length = strlen( string ); ++ if( length > 0 && string[ length - 1 ] == ',' ){ ++ string[ length - 1 ] = '\0'; ++ length --; ++ } ++ if( length > 0 ){ ++ TermWin.fontset = XCreateFontSet ++ ( Xdisplay, string, ++ &missing_charsetlist, &missing_charsetcount, &def_string ); ++ } ++ free( string ); ++ } else { ++ TermWin.fontset = NULL; ++ } ++ return; ++ } ++ ++ /* PROTO */ ++ void ++ setPreeditArea(XRectangle *preedit_rect, XRectangle *status_rect, XRectangle *needed_rect) ++ { ++ preedit_rect->x = needed_rect->width ++ + (scrollbar_visible() && !(Options & Opt_scrollBar_right) ++ ? (SB_WIDTH + sb_shadow * 2) : 0); ++ preedit_rect->y = Height2Pixel(TermWin.nrow - 1) ++ + ((menuBar.state == 1) ? menuBar_TotalHeight() : 0); ++ ++ preedit_rect->width = Width2Pixel(TermWin.ncol + 1) - needed_rect->width ++ + (!(Options & Opt_scrollBar_right) ++ ? (SB_WIDTH + sb_shadow * 2) : 0); ++ preedit_rect->height = Height2Pixel(1); ++ ++ status_rect->x = (scrollbar_visible() && !(Options & Opt_scrollBar_right)) ++ ? (SB_WIDTH + sb_shadow * 2) : 0; ++ status_rect->y = Height2Pixel(TermWin.nrow - 1) ++ + ((menuBar.state == 1) ? menuBar_TotalHeight() : 0); ++ ++ status_rect->width = needed_rect->width ? needed_rect->width ++ : Width2Pixel(TermWin.ncol + 1); ++ status_rect->height = Height2Pixel(1); ++ } ++ ++ /* PROTO */ ++ void ++ IMDestroyCallback(XIM xim, XPointer client_data, XPointer call_data) ++ { ++ Input_Context = NULL; ++ XRegisterIMInstantiateCallback(Xdisplay, NULL, NULL, NULL, IMInstantiateCallback, NULL); ++ } ++ ++ ++ /* PROTO */ ++ void ++ IMInstantiateCallback(Display *display, XPointer client_data, XPointer call_data) ++ { ++ char *p, *s, buf[64], tmp[1024]; ++ char *end, *next_s; ++ XIM xim = NULL; ++ XIMStyle input_style = 0; ++ XIMStyles *xim_styles = NULL; ++ int found; ++ XPoint spot; ++ XRectangle rect, status_rect, needed_rect; ++ unsigned long fg, bg; ++ XVaNestedList preedit_attr = NULL; ++ XVaNestedList status_attr = NULL; ++ XIMCallback ximcallback; ++ ++ Input_Context = NULL; ++ ++ if (Input_Context) ++ return; ++ ++ ximcallback.callback = IMDestroyCallback; ++ ximcallback.client_data = NULL; ++ ++ if (rs_inputMethod && *rs_inputMethod) { ++ STRNCPY(tmp, rs_inputMethod, sizeof(tmp) - 1); ++ for (s = tmp; *s; s = next_s + 1) { ++ for (; *s && isspace(*s); s++); ++ if (!*s) ++ break; ++ for (end = s; (*end && (*end != ',')); end++); ++ for (next_s = end--; ((end >= s) && isspace(*end)); end--); ++ *(end + 1) = '\0'; ++ ++ if (*s) { ++ STRCPY(buf, "@im="); ++ strncat(buf, s, sizeof(buf) - 4 - 1); ++ if ((p = XSetLocaleModifiers(buf)) != NULL && *p ++ && (xim = XOpenIM(Xdisplay, NULL, NULL, NULL)) != NULL) ++ break; ++ } ++ if (!*next_s) ++ break; ++ } ++ } ++ ++ /* try with XMODIFIERS env. var. */ ++ if (xim == NULL && (p = XSetLocaleModifiers("")) != NULL && *p) ++ xim = XOpenIM(Xdisplay, NULL, NULL, NULL); ++ ++ /* try with no modifiers base */ ++ if (xim == NULL && (p = XSetLocaleModifiers("@im=none")) != NULL && *p) ++ xim = XOpenIM(Xdisplay, NULL, NULL, NULL); ++ ++ if (xim == NULL) ++ return; ++ XSetIMValues(xim, XNDestroyCallback, &ximcallback, NULL); ++ ++ if (XGetIMValues(xim, XNQueryInputStyle, &xim_styles, NULL) ++ || !xim_styles) { ++ print_error("input method doesn't support any style"); ++ XCloseIM(xim); ++ return; ++ } ++ STRNCPY(tmp, (rs_preeditType ? rs_preeditType ++ : "OverTheSpot,OffTheSpot,Root"), ++ sizeof(tmp) - 1); ++ for (found = 0, s = tmp; *s && !found; s = next_s + 1) { ++ unsigned short i; ++ ++ for (; *s && isspace(*s); s++); ++ if (!*s) ++ break; ++ for (end = s; (*end && (*end != ',')); end++); ++ for (next_s = end--; ((end >= s) && isspace(*end)); end--); ++ *(end + 1) = '\0'; ++ ++ if (!strcmp(s, "OverTheSpot")) ++ input_style = (XIMPreeditPosition | XIMStatusNothing); ++ else if (!strcmp(s, "OffTheSpot")) ++ input_style = (XIMPreeditArea | XIMStatusArea); ++ else if (!strcmp(s, "Root")) ++ input_style = (XIMPreeditNothing | XIMStatusNothing); ++ ++ for (i = 0; i < xim_styles->count_styles; i++) ++ if (input_style == xim_styles->supported_styles[i]) { ++ found = 1; ++ break; ++ } ++ } ++ XFree(xim_styles); ++ ++ if (found == 0) { ++ print_error("input method doesn't support my preedit type"); ++ XCloseIM(xim); ++ return; ++ } ++ if ((input_style != (XIMPreeditNothing | XIMStatusNothing)) ++ && (input_style != (XIMPreeditArea | XIMStatusArea)) ++ && (input_style != (XIMPreeditPosition | XIMStatusNothing))) { ++ print_error("This program does not support the preedit type"); ++ XCloseIM(xim); ++ return; ++ } ++ if (input_style & XIMPreeditPosition) { ++ setSize(&rect); ++ setPosition(&spot); ++ setColor(&fg, &bg); ++ ++ preedit_attr = XVaCreateNestedList(0, XNArea, &rect, ++ XNSpotLocation, &spot, ++ XNForeground, fg, ++ XNBackground, bg, ++ XNFontSet, TermWin.fontset, ++ NULL); ++ } else if (input_style & XIMPreeditArea) { ++ setColor(&fg, &bg); ++ ++ /* ++ * The necessary width of preedit area is unknown ++ * until create input context. ++ */ ++ needed_rect.width = 0; ++ ++ setPreeditArea(&rect, &status_rect, &needed_rect); ++ ++ preedit_attr = XVaCreateNestedList(0, XNArea, &rect, ++ XNForeground, fg, ++ XNBackground, bg, ++ XNFontSet, TermWin.fontset, ++ NULL); ++ status_attr = XVaCreateNestedList(0, XNArea, &status_rect, ++ XNForeground, fg, ++ XNBackground, bg, ++ XNFontSet, TermWin.fontset, ++ NULL); ++ } ++ Input_Context = XCreateIC(xim, XNInputStyle, input_style, ++ XNClientWindow, TermWin.parent, ++ XNFocusWindow, TermWin.parent, ++ XNDestroyCallback, &ximcallback, ++ preedit_attr ? XNPreeditAttributes : NULL, ++ preedit_attr, ++ status_attr ? XNStatusAttributes : NULL, ++ status_attr, ++ NULL); ++ XFree(preedit_attr); ++ XFree(status_attr); ++ if (Input_Context == NULL) { ++ print_error("Failed to create input context"); ++ XCloseIM(xim); ++ } ++ if (input_style & XIMPreeditArea) ++ IMSetStatusPosition(); ++ } ++ ++ /* PROTO */ ++ void ++ IMSetStatusPosition(void) ++ { ++ XIMStyle input_style; ++ XRectangle rect, status_rect, *needed_rect; ++ XVaNestedList preedit_attr, status_attr; ++ ++ if (Input_Context == NULL) ++ return; ++ ++ XGetICValues(Input_Context, XNInputStyle, &input_style, NULL); ++ ++ if (input_style & XIMPreeditArea) { ++ status_attr = XVaCreateNestedList(0, XNAreaNeeded, &needed_rect, NULL); ++ XGetICValues(Input_Context, XNStatusAttributes, status_attr, NULL); ++ XFree(status_attr); ++ ++ rect.x = needed_rect->width; ++ if (menuBar.state == 1) { ++ rect.y = Height2Pixel(TermWin.nrow - 1) - menuBar_TotalHeight(); ++ } else { ++ rect.y = Height2Pixel(TermWin.nrow - 1); ++ } ++ if (Options & Opt_scrollBar_right) { ++ rect.width = Width2Pixel(TermWin.ncol + 1) - needed_rect->width; ++ } else { ++ rect.width = Width2Pixel(TermWin.ncol + 1) + SB_WIDTH + SHADOW * 2 - needed_rect->width; ++ } ++ rect.height = needed_rect->height; ++ preedit_attr = XVaCreateNestedList(0, XNArea, &rect, NULL); ++ ++ if (scrollbar_visible()) { ++ if (Options & Opt_scrollBar_right) { ++ status_rect.x = 0; ++ } else { ++ status_rect.x = SB_WIDTH + SHADOW * 2; ++ } ++ } else { ++ status_rect.x = 0; ++ } ++ if (menuBar.state == 1) { ++ status_rect.y = Height2Pixel(TermWin.nrow - 1) + menuBar_TotalHeight(); ++ } else { ++ status_rect.y = Height2Pixel(TermWin.nrow - 1); ++ } ++ status_rect.width = needed_rect->width; ++ status_rect.height = needed_rect->height; ++ status_attr = XVaCreateNestedList(0, XNArea, &status_rect, NULL); ++ XSetICValues(Input_Context, ++ XNPreeditAttributes, preedit_attr, ++ XNStatusAttributes, status_attr, NULL); ++ XFree(preedit_attr); ++ XFree(status_attr); ++ } ++ } ++ ++ /* PROTO */ ++ void ++ XProcessEvent( Display *display ) ++ { ++ XEvent xev; ++ XNextEvent( display, &xev ); ++ if( !XFilterEvent( &xev, xev.xany.window ) ) ++ process_x_event( &xev ); ++ return; ++ } ++ ++ #endif + + /*}}} */ + /*----------------------- end-of-file (C source) -----------------------*/ +diff -cNr aterm-0.4.2.orig/src/feature.h aterm-0.4.2/src/feature.h +*** aterm-0.4.2.orig/src/feature.h Fri Sep 7 00:38:07 2001 +--- aterm-0.4.2/src/feature.h Sun Sep 30 14:38:03 2001 +*************** +*** 306,311 **** +--- 306,317 ---- + */ + #define SAVELINES 64 + ++ /* ++ * Default line space ++ */ ++ #define LINESPACE 0 ++ ++ + /* (Hops) Set to choose a number of lines of context between pages + * (rather than a proportion (1/5) of savedlines buffer) + * when paging the savedlines with SHIFT-{Prior,Next} keys. +diff -cNr aterm-0.4.2.orig/src/main.c aterm-0.4.2/src/main.c +*** aterm-0.4.2.orig/src/main.c Fri Sep 7 00:38:07 2001 +--- aterm-0.4.2/src/main.c Sun Sep 30 14:56:48 2001 +*************** +*** 901,906 **** +--- 901,909 ---- + + XResizeWindow(Xdisplay, TermWin.parent, width, height); + resize_window1(width, height); ++ #ifdef USE_XIM ++ IMSetStatusPosition(); ++ #endif + scr_clear(); + } + } +*************** +*** 1357,1363 **** + fw = TermWin.font->min_bounds.width; /* can be error !!!! */ + if( fw > 1000 ) fw = 0 ; /* added by suggestion from <suchness>*/ + +! fh = TermWin.font->ascent + TermWin.font->descent; + + if (TermWin.font->min_bounds.width == TermWin.font->max_bounds.width) + TermWin.fprop = 0; /* Mono-spaced (fixed width) font */ +--- 1360,1370 ---- + fw = TermWin.font->min_bounds.width; /* can be error !!!! */ + if( fw > 1000 ) fw = 0 ; /* added by suggestion from <suchness>*/ + +! #ifdef USE_LINESPACE +! fh = TermWin.font->ascent + TermWin.font->descent + TermWin.lineSpace; +! #else +! fh = TermWin.font->ascent + TermWin.font->descent; +! #endif + + if (TermWin.font->min_bounds.width == TermWin.font->max_bounds.width) + TermWin.fprop = 0; /* Mono-spaced (fixed width) font */ +*************** +*** 1624,1629 **** +--- 1631,1639 ---- + rs_geometry = NULL; /* window geometry */ + rs_minBufferWidth = NULL; + rs_saveLines = NULL; /* scrollback buffer [lines] */ ++ #ifdef USE_LINESPACE ++ rs_lineSpace = NULL; ++ #endif + rs_borderWidth = NULL; + rs_modifier = NULL; /* modifier */ + #if defined (HOTKEY_CTRL) || defined (HOTKEY_META) +*************** +*** 1750,1755 **** +--- 1760,1769 ---- + TermWin.min_bcol = 1; + if (!rs_saveLines || (TermWin.saveLines = atoi(rs_saveLines)) < 0) + TermWin.saveLines = SAVELINES; ++ #ifdef USE_LINESPACE ++ if (!rs_lineSpace || (TermWin.lineSpace = atoi(rs_lineSpace)) < 0) ++ TermWin.lineSpace = LINESPACE; ++ #endif + if (!rs_borderWidth || (TermWin.borderWidth = atoi(rs_borderWidth)) < 0) + TermWin.borderWidth = BORDERWIDTH; + +*************** +*** 1797,1802 **** +--- 1811,1819 ---- + rs_mfont[i] = def_mfontName[i]; + #endif + } ++ #ifdef USE_XIM ++ TermWin.fontset = NULL; ++ #endif + + #ifdef XTERM_REVERSE_VIDEO + /* this is how xterm implements reverseVideo */ +diff -cNr aterm-0.4.2.orig/src/rxvt.h aterm-0.4.2/src/rxvt.h +*** aterm-0.4.2.orig/src/rxvt.h Fri Sep 7 00:38:07 2001 +--- aterm-0.4.2/src/rxvt.h Sun Sep 30 15:01:00 2001 +*************** +*** 266,271 **** +--- 266,274 ---- + ncol, nrow, /* window size [characters] */ + bcol, /* current number of columns in the buffer */ + min_bcol, /* minimum horizontal columns in the buffer */ ++ #ifdef USE_LINESPACE ++ lineSpace, /* linespace */ ++ #endif + focus, /* window has focus */ + saveLines, /* number of lines that fit in scrollback */ + borderWidth,/* number of pixels in window border */ +*************** +*** 280,285 **** +--- 283,291 ---- + #ifdef MULTICHAR_SET + XFontStruct *mfont; /* Multichar font structure */ + #endif ++ #ifdef USE_XIM ++ XFontSet fontset; ++ #endif + #if defined(BACKGROUND_IMAGE) || defined(TRANSPARENT) || defined(_MYSTYLE_) + BackgroundInfo background; + #endif +*************** +*** 928,933 **** +--- 934,942 ---- + EXTERN const char *rs_geometry; /* window geometry */ + EXTERN const char *rs_minBufferWidth; /* minimum buffer width - so we can scroll horizontally */ + EXTERN const char *rs_saveLines; /* scrollback buffer [lines] */ ++ #ifdef USE_LINESPACE ++ EXTERN const char *rs_lineSpace; /* line space [pixels] */ ++ #endif + EXTERN const char *rs_borderWidth; /* border width [pixels] */ + EXTERN const char *rs_cutchars; /* chars for selection boundaries */ + #ifdef META8_OPTION +*************** +*** 948,953 **** +--- 957,966 ---- + #endif + #ifdef PRINTPIPE + EXTERN const char *rs_print_pipe; ++ #endif ++ #ifdef USE_XIM ++ EXTERN const char *rs_preeditType; ++ EXTERN const char *rs_inputMethod; + #endif + #ifndef NO_BRIGHTCOLOR + EXTERN unsigned int colorfgbg; +diff -cNr aterm-0.4.2.orig/src/screen.c aterm-0.4.2/src/screen.c +*** aterm-0.4.2.orig/src/screen.c Fri Sep 7 00:38:07 2001 +--- aterm-0.4.2/src/screen.c Sun Sep 30 15:03:36 2001 +*************** +*** 3439,3441 **** +--- 3439,3455 ---- + #endif + fprintf(stderr, "%s\n", name[color]); + } ++ ++ #ifdef USE_XIM ++ /* PROTO */ ++ void ++ setPosition(XPoint *pos) ++ { ++ XWindowAttributes xwa ; ++ ++ XGetWindowAttributes( Xdisplay, TermWin.vt, &xwa ) ; ++ pos->x = Col2Pixel ( screen.cur.col ) + xwa.x; ++ pos->y = Height2Pixel((screen.cur.row + 1)) + xwa.y; ++ return ; ++ } ++ #endif +diff -cNr aterm-0.4.2.orig/src/xdefaults.c aterm-0.4.2/src/xdefaults.c +*** aterm-0.4.2.orig/src/xdefaults.c Fri Sep 7 00:38:07 2001 +--- aterm-0.4.2/src/xdefaults.c Sun Sep 30 15:06:21 2001 +*************** +*** 276,281 **** +--- 276,286 ---- + STRG(rs_multichar_encoding, "multichar_encoding", "km", "mode", + "multiple-character font encoding; mode = eucj | sjis | big5"), + #endif /* MULTICHAR_SET */ ++ #ifdef USE_XIM ++ STRG(rs_preeditType, "preeditType", "pt", "style", ++ "input style of input method; style = OverTheSpot | OffTheSpot | Root"), ++ STRG(rs_inputMethod, "inputMethod", "im", "name", "name of input method"), ++ #endif /* USE_XIM */ + #ifdef GREEK_SUPPORT + STRG(rs_greek_keyboard, "greek_keyboard", "grk", "mode", + "greek keyboard mapping; mode = iso | ibm"), +*************** +*** 313,318 **** +--- 318,327 ---- + "minimum number of columns stored in buffer"), + STRG(rs_saveLines, "saveLines", "sl", "number", + "number of scrolled lines to save"), ++ #ifdef USE_LINESPACE ++ STRG(rs_lineSpace, "lineSpace", "lsp", "number", ++ "line space"), ++ #endif + BOOL(rs_utmpInhibit, "utmpInhibit", "ut", Opt_utmpInhibit, + "utmp inhibit"), + BOOL(rs_visualBell, "visualBell", "vb", Opt_visualBell, "visual bell"), |