aboutsummaryrefslogtreecommitdiffstats
path: root/chinese/aterm/files
diff options
context:
space:
mode:
authorflathill <flathill@FreeBSD.org>1999-05-11 00:20:23 +0800
committerflathill <flathill@FreeBSD.org>1999-05-11 00:20:23 +0800
commitd53b66d3c5e87603746c7177ae63c1b10db8353c (patch)
treea6ce7c78ffe11c1ed3ce7e89d34563e7752913dc /chinese/aterm/files
parentc7574c7520b5b5a8736ccdeb897ee37558f0947a (diff)
downloadfreebsd-ports-graphics-d53b66d3c5e87603746c7177ae63c1b10db8353c.tar.gz
freebsd-ports-graphics-d53b66d3c5e87603746c7177ae63c1b10db8353c.tar.zst
freebsd-ports-graphics-d53b66d3c5e87603746c7177ae63c1b10db8353c.zip
Update to 0.3.5
PR: ports/11625 Submitted by: davidyu@ken.csie.ntu.edu.tw
Diffstat (limited to 'chinese/aterm/files')
-rw-r--r--chinese/aterm/files/cli_xcin.c146
-rw-r--r--chinese/aterm/files/patch-aa169
-rw-r--r--chinese/aterm/files/patch-ab55
-rw-r--r--chinese/aterm/files/protocol.h13
-rw-r--r--chinese/aterm/files/state.h23
5 files changed, 231 insertions, 175 deletions
diff --git a/chinese/aterm/files/cli_xcin.c b/chinese/aterm/files/cli_xcin.c
new file mode 100644
index 00000000000..91c14d2fa3d
--- /dev/null
+++ b/chinese/aterm/files/cli_xcin.c
@@ -0,0 +1,146 @@
+/*
+ Copyright (C) 1994,1995 Edward Der-Hua Liu, Hsin-Chu, Taiwan
+*/
+
+#include <stdio.h>
+#include <stdarg.h>
+#include <sys/types.h>
+#include <X11/Xlib.h>
+#include <X11/Xatom.h>
+#include "state.h"
+#include "protocol.h"
+
+/*static void p_err(char *fmt,...)
+{
+ va_list args;
+
+ va_start(args, fmt);
+ fprintf(stderr,"%s:", "cli_xcin:");
+ vfprintf(stderr, fmt, args);
+ va_end(args);
+ fprintf(stderr,"\n");
+ exit(-1);
+}
+*/
+
+
+static Atom xcin_atom=0;
+static Window xcin_win=None;
+static InmdState inmdstate;
+#define ENDIAN_TEST() (*(int *)"\x11\x22\x33\x44"==0x11223344)
+char my_endian;
+
+static int connect_xcin(Display *display)
+{
+/*Window twin;*/
+xcin_atom=XInternAtom(display, XCIN_ATOM,False);
+my_endian=ENDIAN_TEST(); /* if == 11223344, it is big-endian */
+
+xcin_win=XGetSelectionOwner(display,xcin_atom);
+return xcin_win;
+}
+
+void send_FocusIn(Display *display, Window window)
+{
+ XClientMessageEvent event;
+ /*XEvent erreve;*/
+ char *tmp=event.data.b;
+
+ if (connect_xcin(display)==None) return;
+/* Ensure xcin exists, or the process will be hanged */
+ event.type=ClientMessage;
+ event.window=window;
+ event.message_type=xcin_atom;
+ event.format=8;
+
+ tmp[0]=tmp[1]=tmp[2]=0xff;
+ tmp[3]=CLI_FOCUS_IN;
+ memcpy(&tmp[4],&inmdstate, sizeof(inmdstate));
+ XSendEvent(display, xcin_win, False, 0, (XEvent *)&event);
+}
+
+void send_FocusOut(Display *display, Window window)
+{
+ XClientMessageEvent event;
+/* XEvent erreve; */
+ char *tmp=event.data.b;
+
+ if (connect_xcin(display)==None) return;
+/* Ensure xcin exists, or the process will be hanged */
+ event.type=ClientMessage;
+ event.window=window;
+ event.message_type=xcin_atom;
+ event.format=8;
+
+ tmp[0]=tmp[1]=tmp[2]=0xff;
+ tmp[3]=CLI_FOCUS_OUT;
+ memcpy(&tmp[4],&inmdstate, sizeof(inmdstate));
+ XSendEvent(display, xcin_win, False, 0, (XEvent *)&event);
+}
+
+static void big_little(char *i)
+{
+char t;
+t=*i; *i=*(i+3); *(i+3)=t;
+t=*(i+1); *(i+1)=*(i+2); *(i+2)=t;
+}
+static int read_keys(Display *display, char *buf)
+{
+ Atom actual_type;
+ int actual_format/*,i*/;
+ u_long nitems,bytes_after;
+ char *ttt, *cp;
+ XCIN_RES res;
+ int ofs;
+
+ cp=(char *)&res;
+ ofs=0;
+ do {
+ if (XGetWindowProperty(display,xcin_win,xcin_atom,
+ ofs/4,(sizeof(XCIN_RES)+3)/4,
+ True, AnyPropertyType, &actual_type,&actual_format,
+ &nitems,&bytes_after,(unsigned char **)&ttt) != Success)
+ puts("err property");
+ memcpy((char *)(&res)+(ofs & ~0x3), ttt, nitems);
+ XFree(ttt);
+ ofs=(ofs & ~0x3) + nitems;
+ } while ((!nitems && !ofs) || bytes_after>0);
+ if (my_endian) {
+ big_little((char *)&res.len);
+ big_little((char *)&res.status);
+ }
+ memcpy(buf,res.tkey, res.len);
+ inmdstate=res.inmdstate;
+ buf[res.len]=0;
+
+ return res.status;
+}
+
+#include <X11/Xutil.h>
+
+static XComposeStatus compose_status = {NULL, 0};
+
+int send_key(Display *display, Window win, XKeyEvent *eve, char *buf)
+{
+XClientMessageEvent event;
+/*XEvent erreve;*/
+char *tmp=event.data.b;
+u_char tttt[8];
+/*KeySym keysym;*/
+int count;
+
+if (xcin_win==None && connect_xcin(display)==None)
+ return K_REJECT;
+if ((xcin_win=XGetSelectionOwner(display,xcin_atom))==None)
+ return K_REJECT;
+
+event.type=ClientMessage;
+event.window=win;
+event.message_type=xcin_atom;
+event.format=32;
+count = XLookupString (eve, tttt, sizeof(tmp), (KeySym *)tmp, &compose_status);
+memcpy(&tmp[4],&eve->state,4);
+XSendEvent(display, xcin_win, False, 0, (XEvent *)&event);
+XSync(display,False);
+return (read_keys(display, buf));
+}
diff --git a/chinese/aterm/files/patch-aa b/chinese/aterm/files/patch-aa
index 7d5f7b76c9c..f1d01287b7f 100644
--- a/chinese/aterm/files/patch-aa
+++ b/chinese/aterm/files/patch-aa
@@ -1,149 +1,20 @@
---- src/cli_xcin.c.orig Mon Apr 26 01:49:02 1999
-+++ src/cli_xcin.c Mon Apr 26 01:49:02 1999
-@@ -0,0 +1,146 @@
-+/*
-+ Copyright (C) 1994,1995 Edward Der-Hua Liu, Hsin-Chu, Taiwan
-+*/
-+
-+#include <stdio.h>
-+#include <stdarg.h>
-+#include <sys/types.h>
-+#include <X11/Xlib.h>
-+#include <X11/Xatom.h>
-+#include "state.h"
-+#include "protocol.h"
-+
-+/*static void p_err(char *fmt,...)
-+{
-+ va_list args;
-+
-+ va_start(args, fmt);
-+ fprintf(stderr,"%s:", "cli_xcin:");
-+ vfprintf(stderr, fmt, args);
-+ va_end(args);
-+ fprintf(stderr,"\n");
-+ exit(-1);
-+}
-+*/
-+
-+
-+static Atom xcin_atom=0;
-+static Window xcin_win=None;
-+static InmdState inmdstate;
-+#define ENDIAN_TEST() (*(int *)"\x11\x22\x33\x44"==0x11223344)
-+char my_endian;
-+
-+static int connect_xcin(Display *display)
-+{
-+/*Window twin;*/
-+xcin_atom=XInternAtom(display, XCIN_ATOM,False);
-+my_endian=ENDIAN_TEST(); /* if == 11223344, it is big-endian */
-+
-+xcin_win=XGetSelectionOwner(display,xcin_atom);
-+return xcin_win;
-+}
-+
-+void send_FocusIn(Display *display, Window window)
-+{
-+ XClientMessageEvent event;
-+ /*XEvent erreve;*/
-+ char *tmp=event.data.b;
-+
-+ if (connect_xcin(display)==None) return;
-+/* Ensure xcin exists, or the process will be hanged */
-+ event.type=ClientMessage;
-+ event.window=window;
-+ event.message_type=xcin_atom;
-+ event.format=8;
-+
-+ tmp[0]=tmp[1]=tmp[2]=0xff;
-+ tmp[3]=CLI_FOCUS_IN;
-+ memcpy(&tmp[4],&inmdstate, sizeof(inmdstate));
-+ XSendEvent(display, xcin_win, False, 0, (XEvent *)&event);
-+}
-+
-+void send_FocusOut(Display *display, Window window)
-+{
-+ XClientMessageEvent event;
-+/* XEvent erreve; */
-+ char *tmp=event.data.b;
-+
-+ if (connect_xcin(display)==None) return;
-+/* Ensure xcin exists, or the process will be hanged */
-+ event.type=ClientMessage;
-+ event.window=window;
-+ event.message_type=xcin_atom;
-+ event.format=8;
-+
-+ tmp[0]=tmp[1]=tmp[2]=0xff;
-+ tmp[3]=CLI_FOCUS_OUT;
-+ memcpy(&tmp[4],&inmdstate, sizeof(inmdstate));
-+ XSendEvent(display, xcin_win, False, 0, (XEvent *)&event);
-+}
-+
-+static void big_little(char *i)
-+{
-+char t;
-+t=*i; *i=*(i+3); *(i+3)=t;
-+t=*(i+1); *(i+1)=*(i+2); *(i+2)=t;
-+}
-+static int read_keys(Display *display, char *buf)
-+{
-+ Atom actual_type;
-+ int actual_format/*,i*/;
-+ u_long nitems,bytes_after;
-+ char *ttt, *cp;
-+ XCIN_RES res;
-+ int ofs;
-+
-+ cp=(char *)&res;
-+ ofs=0;
-+ do {
-+ if (XGetWindowProperty(display,xcin_win,xcin_atom,
-+ ofs/4,(sizeof(XCIN_RES)+3)/4,
-+ True, AnyPropertyType, &actual_type,&actual_format,
-+ &nitems,&bytes_after,(unsigned char **)&ttt) != Success)
-+ puts("err property");
-+ memcpy((char *)(&res)+(ofs & ~0x3), ttt, nitems);
-+ XFree(ttt);
-+ ofs=(ofs & ~0x3) + nitems;
-+ } while ((!nitems && !ofs) || bytes_after>0);
-+ if (my_endian) {
-+ big_little((char *)&res.len);
-+ big_little((char *)&res.status);
-+ }
-+ memcpy(buf,res.tkey, res.len);
-+ inmdstate=res.inmdstate;
-+ buf[res.len]=0;
-+
-+ return res.status;
-+}
-+
-+#include <X11/Xutil.h>
-+
-+static XComposeStatus compose_status = {NULL, 0};
-+
-+int send_key(Display *display, Window win, XKeyEvent *eve, char *buf)
-+{
-+XClientMessageEvent event;
-+/*XEvent erreve;*/
-+char *tmp=event.data.b;
-+u_char tttt[8];
-+/*KeySym keysym;*/
-+int count;
-+
-+if (xcin_win==None && connect_xcin(display)==None)
-+ return K_REJECT;
-+if ((xcin_win=XGetSelectionOwner(display,xcin_atom))==None)
-+ return K_REJECT;
-+
-+event.type=ClientMessage;
-+event.window=win;
-+event.message_type=xcin_atom;
-+event.format=32;
-+count = XLookupString (eve, tttt, sizeof(tmp), (KeySym *)tmp, &compose_status);
-+memcpy(&tmp[4],&eve->state,4);
-+XSendEvent(display, xcin_win, False, 0, (XEvent *)&event);
-+XSync(display,False);
-+return (read_keys(display, buf));
-+}
+--- src/Makefile.in.orig Mon May 10 13:05:37 1999
++++ src/Makefile.in Mon May 10 13:06:19 1999
+@@ -19,13 +19,14 @@
+
+ SRCS = command.c graphics.c grkelot.c main.c menubar.c misc.c \
+ netdisp.c rmemset.c screen.c @SBARFILE@.c utmp.c xdefaults.c \
+- pixmap.c ximage_utils.c
++ pixmap.c ximage_utils.c cli_xcin.c
+
+ OBJS = command.o graphics.o grkelot.o main.o menubar.o misc.o \
+ netdisp.o rmemset.o screen.o @SBARFILE@.o utmp.o xdefaults.o \
+- pixmap.o ximage_utils.o
++ pixmap.o ximage_utils.o cli_xcin.o
+
+-HDRS = feature.h protos.h grkelot.h rxvt.h rxvtgrx.h screen.h version.h
++HDRS = feature.h protos.h grkelot.h rxvt.h rxvtgrx.h screen.h version.h \
++ state.h protocol.h
+
+ PROS = command.pro graphics.pro grkelot.pro main.pro menubar.pro misc.pro \
+ netdisp.pro rmemset.pro screen.pro @SBARFILE@.pro utmp.pro xdefaults.pro \
diff --git a/chinese/aterm/files/patch-ab b/chinese/aterm/files/patch-ab
index 8fdc683b33d..f7dd7009ecb 100644
--- a/chinese/aterm/files/patch-ab
+++ b/chinese/aterm/files/patch-ab
@@ -1,26 +1,29 @@
---- src/state.h.orig Mon Apr 26 01:49:05 1999
-+++ src/state.h Mon Apr 26 01:49:05 1999
-@@ -0,0 +1,23 @@
-+/*
-+ Copyright (C) 1994 Edward Der-Hua Liu, Hsin-Chu, Taiwan
-+*/
-+
-+typedef struct {
-+ char kb_state;
-+ char _CurInMethod;
-+} InmdState;
-+
-+#define EngChiMask (1)
-+#define HalfFullMask (2)
-+
-+typedef struct {
-+ int len;
-+ int status;
-+ InmdState inmdstate;
-+ char tkey[512];
-+} XCIN_RES;
-+
-+#define EngChi ((inmdstate.kb_state & EngChiMask) ? 1:0)
-+#define HalfFull ((inmdstate.kb_state & HalfFullMask) ? 1:0)
-+#define CurInMethod (inmdstate._CurInMethod)
-+/* extern InmdState inmdstate; */
+--- src/command.c.orig Mon May 10 13:06:58 1999
++++ src/command.c Mon May 10 13:09:27 1999
+@@ -2069,11 +2069,17 @@
+ static int bypass_keystate = 0;
+ int reportmode;
+ static int csrO = 0; /* Hops - csr offset in thumb/slider */
++ int k_status;
++ char kbuf[256];
+
+ /* to give proper Scroll behaviour */
+ switch (ev->type) {
+ case KeyPress:
+- lookup_key(ev);
++ k_status = send_key(Xdisplay, TermWin.parent, &ev->xkey, kbuf);
++ if(!k_status)
++ lookup_key(ev);
++ else if(kbuf[0])
++ tt_write(kbuf, strlen(kbuf));
+ break;
+
+ case ClientMessage:
+@@ -2138,6 +2144,7 @@
+
+ case FocusIn:
+ if (!TermWin.focus) {
++ send_FocusIn(Xdisplay, TermWin.parent);
+ TermWin.focus = 1;
+ #ifdef OFF_FOCUS_FADING
+ if( rs_fade != NULL )
diff --git a/chinese/aterm/files/protocol.h b/chinese/aterm/files/protocol.h
new file mode 100644
index 00000000000..bc19abfb5d1
--- /dev/null
+++ b/chinese/aterm/files/protocol.h
@@ -0,0 +1,13 @@
+/*
+ Copyright (C) 1994 Edward Der-Hua Liu, Hsin-Chu, Taiwan
+*/
+
+#define K_REJECT (0)
+#define K_ACCEPT (1)
+
+#define CLI_FOCUS_IN (1)
+#define CLI_FOCUS_OUT (3)
+
+#define LOAD_KEYWORD (2)
+
+#define XCIN_ATOM "XCIN_A"
diff --git a/chinese/aterm/files/state.h b/chinese/aterm/files/state.h
new file mode 100644
index 00000000000..e663df9fb98
--- /dev/null
+++ b/chinese/aterm/files/state.h
@@ -0,0 +1,23 @@
+/*
+ Copyright (C) 1994 Edward Der-Hua Liu, Hsin-Chu, Taiwan
+*/
+
+typedef struct {
+ char kb_state;
+ char _CurInMethod;
+} InmdState;
+
+#define EngChiMask (1)
+#define HalfFullMask (2)
+
+typedef struct {
+ int len;
+ int status;
+ InmdState inmdstate;
+ char tkey[512];
+} XCIN_RES;
+
+#define EngChi ((inmdstate.kb_state & EngChiMask) ? 1:0)
+#define HalfFull ((inmdstate.kb_state & HalfFullMask) ? 1:0)
+#define CurInMethod (inmdstate._CurInMethod)
+/* extern InmdState inmdstate; */