Mercurial > kinput2.yaz
view lib/Xatoklib/if.c @ 0:92745d501b9a
initial import from kinput2-v3.1
author | Yoshiki Yazawa <yaz@honeyplanet.jp> |
---|---|
date | Mon, 08 Mar 2010 04:44:30 +0900 |
parents | |
children |
line wrap: on
line source
/* * Copyright 1999 Justsystem Corporation, Japan. * * Permission to use, copy, modify, and distribute this software and its * documentation for any purpose and without fee is hereby granted, * provided that the above copyright notice appear in all copies and that * both that copyright notice and this permission notice appear in * supporting documentation, and that the name of Justsystem Corporation * not be used in advertising or publicity pertaining to distribution * of the software without specific, written prior permission. Justsystem * Corporation makes no representations about the suitability of this * software for any purpose. It is provided "as is" without express * or implied warranty. * * Author: Atsushi Irisawa */ #ifndef lint static char rcsid[] = "$Id: if.c,v 1.3 1999/08/24 09:05:26 ishisone Exp $" ; #endif /* !lint */ #include <stdio.h> #include <X11/IntrinsicP.h> #include <X11/StringDefs.h> #include <X11/Xmu/Atoms.h> #include <X11/keysym.h> #include <Xatoklib.h> #include <key_def.h> /* Page */ /* * [$B4X?tL>(B] * atokModeSet( ) * [$BI=Bj(B] * $B%b!<%I$N@_Dj(B * [$B8F=P7A<0(B] * int atokModeSet( _XatokRecPtr acomm, WORD ceCmd, WORD value ) * * [$B0z?t(B] * $B7?(B : $BL>(B $B>N(B : IO : $B@b(B $BL@(B * _XatokRecPtr : acomm : i/o : kinput2$BMQJQ49%P%C%U%!(B * WORD : ceCmd : i : CE $B%3%^%s%IHV9f(B * WORD : value : i : $BCM(B * * * [$BJV$jCM(B] * CE$B$N=hM}7k2L(B * [$B;HMQ4X?t(B] * AtokClntCommunicate( ) * [$B5!G=(B] * CE$B$N%b!<%I$r9T$J$&(BAPI$B$r8F$S=P$9!#(B * value $B$,(BATCEPRVAPI_READCMD $B$N;~$O!"(B * $B8=:_$N@_DjCM$NFI$_9~$_$G$"$k!#(B */ WORD atokModeSet(acomm, ceCmd, value) _XatokRecPtr acomm; WORD ceCmd; WORD value; { if ( value == ATCEPRVAPI_READCMD ) { acomm->NETrqst.AtCEPrvAPIOutinf = ATCEPRVAPI_READCMD ; } else { acomm->NETrqst.AtCEPrvAPIOutinf = value ; } acomm->NETrqst.ceCmd = ceCmd ; ; AtokClntCommunicate( acomm->sock, &acomm->NETrqst, &acomm->NETrslt ) ; return acomm->NETrslt.header.CEOutinf ; } /* Page */ /* * [$B4X?tL>(B] * atokConnect( ) * [$BI=Bj(B] * ATOK12X $B%5!<%P$H$N@\B3(B * [$B8F=P7A<0(B] * int atokConnect( char *server, char *port, char *conf, char *style, * _XatokRecPtr acomm ) * * [$B0z?t(B] * $B7?(B : $BL>(B $B>N(B : IO : $B@b(B $BL@(B * char : *server : i : ATOK12x $B2TF/%[%9%HL>(B * char : *port : i : $B@\B3%5!<%S%9L>(B * char : *conf : i : conf $B%U%!%$%kL>(B * char : *style : i : style $B%U%!%$%kL>(B * _XatokRecPtr : acomm : i/o : kinput2$BMQJQ49%P%C%U%!(B * * * [$BJV$jCM(B] * 0 $BL$K~(B : $B@\B3%(%i!<(B * $B#00J>e(B :$B@\B3$7$?(BSOCKET$B5-=R;R(B * * [$B;HMQ4X?t(B] * AtokClntConnect( ) * XatokBufferConvert( ) * [$B5!G=(B] * $B?75,$K(B ATO$B#1#2(Bx$B$H$N@\B3$r9T$J$&!#(B * $B@\B3$O%W%m%;%9$G#1$D$G$h$$!#(B * $B@\B3$,=PMh$?>l9g$K$O!"3F%b!<%I$N8=:_$N@_DjCM$r<hF@$9$k!#(B */ int atokConnect(server, port, conf, style, acomm) char *server; char *port; char *conf; char *style; _XatokRecPtr acomm; { wchar dummy[128] ; int status ; int sock ; sock = AtokClntConnect( server, port, conf, style, &acomm->NETrqst, &acomm->NETrslt ) ; if ( sock < 0 ) { return sock ; } /* * $B@\B3$K@.8y$7$?$i8=:_$N%b!<%I$r<hF@$9$k!#(B *$B%b!<%IJ8;zNs$K4X$7$F$O!"@\B3;~$K%j%?!<%s$5$l$k!#(B */ XatokBufferConvert( acomm, ( WORD ) -1, &acomm->NETrslt, dummy, &status, &status, &status, &status ) ; acomm->sock = sock ; /* * $B8=:_$N@_DjCM$r<hF@$9$k!#(B */ acomm->mode.modeKANDSP = atokModeSet( acomm, IME_PRV_SETKANDSP, ATCEPRVAPI_READCMD ) ; acomm->mode.modeHEN = atokModeSet( acomm, IME_PRV_SETHENMODE, ATCEPRVAPI_READCMD ) ; acomm->mode.modeGAKU = atokModeSet( acomm, IME_PRV_SETGAKUMODE, ATCEPRVAPI_READCMD ) ; acomm->mode.modeKOTE = atokModeSet( acomm, IME_PRV_SETKOTEMODE, ATCEPRVAPI_READCMD ) ; acomm->mode.modeOKURI = atokModeSet( acomm, IME_PRV_SETOKURIMODE, ATCEPRVAPI_READCMD ) ; acomm->mode.modeROT = atokModeSet( acomm, IME_PRV_SETROTMODEF, ATCEPRVAPI_READCMD ) ; return sock ; } /* Page */ /* * [$B4X?tL>(B] * atokCEOpen( ) * [$BI=Bj(B] * CONTEXT$B$N:n@.(B * [$B8F=P7A<0(B] * int atokCEOpen( int sock, int clntid, _XatokRecPtr acomm ) * * [$B0z?t(B] * $B7?(B : $BL>(B $B>N(B : IO : $B@b(B $BL@(B * int : sock : i : ATOK12X $B$H$N@\B3(BSOCKET * int : clntid : i : $B%/%i%$%"%s%H(BID * _XatokRecPtr : acomm : i/o : kinput2$BMQJQ49%P%C%U%!(B * * [$BJV$jCM(B] * -1 : CONTEXT$B:n@.%(%i!<(B * 1 : CONTEXT $B:n@.@.8y(B * * [$B;HMQ4X?t(B] * AtokClntCEOpen( ) * XatokBufferConvert( ) * [$B5!G=(B] * $B4{$K@\B3$5$l$F$$$F!"%/%i%$%"%s%H(BID$B$,3d$jEv$F$i$l$F$$$k(B * $B%;%C%7%g%s$KBP$7!"(BATOK12CE $B$H$N(BCONTEXT$B$rDI2C:n@.$9$k!#(B */ int atokCEOpen(sock, clntid, acomm) int sock; int clntid; _XatokRecPtr acomm; { wchar dummy[128] ; /* BufferConvert $B$N$?$a$N(B TMP */ int status ; /* BufferConvert $B$N$?$a$N(B TMP */ if ( AtokClntCEOpen( sock, clntid, &acomm->NETrqst, &acomm->NETrslt ) < 0 ) { return -1 ; } XatokBufferConvert( acomm, ( WORD ) -1, &acomm->NETrslt, dummy, &status, &status, &status, &status ) ; acomm->mode.modeKANDSP = atokModeSet( acomm, IME_PRV_SETKANDSP, ATCEPRVAPI_READCMD ) ; acomm->mode.modeHEN = atokModeSet( acomm, IME_PRV_SETHENMODE, ATCEPRVAPI_READCMD ) ; acomm->mode.modeGAKU = atokModeSet( acomm, IME_PRV_SETGAKUMODE, ATCEPRVAPI_READCMD ) ; acomm->mode.modeKOTE = atokModeSet( acomm, IME_PRV_SETKOTEMODE, ATCEPRVAPI_READCMD ) ; acomm->mode.modeOKURI = atokModeSet( acomm, IME_PRV_SETOKURIMODE, ATCEPRVAPI_READCMD ) ; acomm->mode.modeROT = atokModeSet( acomm, IME_PRV_SETROTMODEF, ATCEPRVAPI_READCMD ) ; return 1 ; } /* Page */ /* * [$B4X?tL>(B] * atokKanjiOn * [$BI=Bj(B] * $B4A;z(BON * [$B8F=P7A<0(B] * int atokKanjiOn( _XatokRecPtr acomm ) * [$B0z?t(B] * $B7?(B : $BL>(B $B>N(B : IO : $B@b(B $BL@(B * _XatokRecPtr : acomm : i/o : kinput2$BMQJQ49%P%C%U%!(B * * [$BJV$jCM(B] * 0 $BL$K~(B : $B%(%i!<(B * 0 : OK * * [$B;HMQ4X?t(B] * atokClntCommunicate( ) * [$B5!G=(B] * CE $B$N%b!<%I$r4A;z(BON$B$H$9$k!#(B * */ int atokKanjiOn(acomm) _XatokRecPtr acomm; { int status ; acomm->convStatus = M_KEYCONV ; acomm->convStatus = acomm->oldStatus ; acomm->NETrqst.ceCmd = IME_PRV_KANJION ; acomm->curAux = acomm->menuAux ; status = AtokClntCommunicate( acomm->sock, &acomm->NETrqst, &acomm->NETrslt ) ; return status ; } int atokKanjiOff(acomm) _XatokRecPtr acomm; { int status ; acomm->oldStatus = acomm->convStatus ; acomm->convStatus = M_NOKEYCONV ; acomm->NETrqst.ceCmd = IME_PRV_KANJIOFF ; acomm->curAux = acomm->menuAux ; status = AtokClntCommunicate( acomm->sock, &acomm->NETrqst, &acomm->NETrslt ) ; return status ; } /* Page */ /* * [$B4X?tL>(B] * atokWordStyleList( ) * [$BI=Bj(B] * $BIJ;l%j%9%H$N<hF@(B * [$B8F=P7A<0(B] * int atokWordStyleList( _XatokRecPtr acomm ) * * [$B0z?t(B] * $B7?(B : $BL>(B $B>N(B : I O : $B@b(B $BL@(B * _XatokRecPtr : acomm : i/o : kinput2$BMQJQ49%P%C%U%!(B * * [$BJV$jCM(B] * -1 : $BAw?.%(%i!<(B * N : $BIJ;l$N8D?t(B * * [$B;HMQ4X?t(B] * atokClntCommunicate( ) * [$B5!G=(B] * $B<-=q$KEPO?$9$k$?$a$NIJ;l%j%9%H$r<hF@$9$k!#(B * $BIJ;l%j%9%H$O(B S-JIS $B$GAw$i$l$FMh$k!#(Bkinput2 $BFbIt$G$O(B * EUC $B$G4IM}$7$F$$$k$?$a!"$3$3$G%3!<%IJQ49$r9T$J$&!#(B * $BIJ;l%j%9%H$O!"8uJd%j%9%H$r4IM}$9$k$N$HF1$8%P%C%U%!$G(B * $B4IM}$9$k!#$=$N%P%C%U%!$,<hF@$5$l$F$$$J$$>l9g$K$O!"(B * $B?7$?$K<hF@$9$k!#(B */ int atokWordStyleList(acomm) _XatokRecPtr acomm; { int size ; int i, j, n ; int len ; ATOKDEHINSTR *sptr ; char euc[BUFSIZ] ; if ( acomm->hinsiPtr ) { goto make_cand ; } acomm->NETrqst.ceCmd = IME_PRV_WORDSYLECOUNT ; if ( AtokClntCommunicate( acomm->sock, &acomm->NETrqst, &acomm->NETrslt ) < 0 ) { return -1 ; } #ifdef ATOK_DEBUG printf( "CHECK %d\n", acomm->NETrslt.header.CEOutinf ) ; #endif /* ATOK_DEBUG */ acomm->hinsiNum = acomm->NETrslt.header.CEOutinf ; acomm->NETrqst.ceCmd = IME_PRV_WORDSTYLELIST ; acomm->NETrqst.AtCEIncode = acomm->hinsiNum ; #ifdef ATOK_DEBUG printf( "\311\312\273\354\301\355\277\364 %d\n"/*=$BIJ;lAm?t(B %d\n=*/, acomm->hinsiNum ) ; #endif /* ATOK_DEBUG */ AtokClntCommunicate( acomm->sock, &acomm->NETrqst, &acomm->NETrslt ) ; size = sizeof( ATOKDEHINSTR ) * acomm->hinsiNum ; acomm->hinsiPtr = ( ATOKDEHINSTR * )malloc( size ) ; sptr = acomm->NETrslt.header.wordPtr ; memcpy( acomm->hinsiPtr, sptr, size ) ; make_cand: size = 0 ; /* * S-JIS $B$GAw$i$l$F$-$?IJ;l%j%9%H%G!<%?$r(B kinput2$BB&$G07$($k$h$&$K(B * EUC $B$KJQ49$9$k!#(B */ for( i = 0 ; i < acomm->hinsiNum ; i++ ) { size += s2e( acomm->hinsiPtr[i].szHinsiStr, strlen( acomm->hinsiPtr[i].szHinsiStr ), euc, sizeof( euc )) ; } /* * $BIJ;l%j%9%H$r4IM}$9$k%P%C%U%!$O8uJd%j%9%H$r4IM}$9$k%P%C%U%!$H(B * $BF1$8NN0h$H$7!"4{$K3NJ]$5$l$F$$$k>l9g$K$O$=$NNN0h$O3NJ]$7$J$$!#(B * $B%P%C%U%!$r6&M-=PMh$k$N$O!"8uJd$r=PNOCf$K!"IJ;l%j%9%H$r(B * $B=PNO$9$k;v$,$J$$$+$i$G$"$j!"F1;~$K=PNO$9$k;v$,$"$k>l9g$K$O(B * $BNN0h$rJL$K$H$k$h$&$K=$@5$9$kI,MW$,$"$k!#(B */ if ( acomm->kohoSize == 0 ) { acomm->kohoStrPtr = ( WCHAR * )malloc( size * sizeof( WCHAR )) ; acomm->kohoLenPtr = ( BYTE * )malloc( acomm->hinsiNum * sizeof( BYTE )) ; acomm->kohoSfxPtr = ( BYTE * )malloc( acomm->hinsiNum * sizeof( BYTE )) ; acomm->kohoSize = acomm->hinsiNum ; acomm->kohoStrLen = size ; } if ( acomm->kohoSize < acomm->hinsiNum ) { acomm->kohoLenPtr = ( BYTE * )realloc( acomm->kohoLenPtr, acomm->hinsiNum * sizeof( BYTE )) ; acomm->kohoSfxPtr = ( BYTE * )realloc( acomm->kohoSfxPtr, acomm->hinsiNum * sizeof( BYTE )) ; acomm->kohoSize = n ; } if ( acomm->kohoStrLen < size ) { acomm->kohoStrPtr = ( WCHAR * )realloc( acomm->kohoStrPtr, size * sizeof( WCHAR )) ; acomm->kohoStrLen = size ; } len = 0 ; for( i = 0 ; i < acomm->hinsiNum ; i++ ) { n = strlen( acomm->hinsiPtr[i].szHinsiStr ) ; n = sjis2ucs( acomm->hinsiPtr[i].szHinsiStr, n, &acomm->kohoStrPtr[len], size -len, 0 ) ; acomm->kohoLenPtr[i] = n ; len += n ; } acomm->kohoNum2 = acomm->hinsiNum ; acomm->kohoPos = 0 ; return acomm->hinsiNum ; } /* Page */ /* * [$B4X?tL>(B] * atokCandidate( ) * [$BI=Bj(B] * $B8uJd%j%9%H$N<hF@!?@_Dj(B * [$B8F=P7A<0(B] * int atokCandidate( _XatokRecPtr acomm, int nbr ) * * [$B0z?t(B] * $B7?(B : $BL>(B $B>N(B : I O : $B@b(B $BL@(B * _XatokRecPtr : acomm : i/o : kinput2$BMQJQ49%P%C%U%!(B * int : nbr : i : $B@_Dj$9$kHV9f(B * * [$BJV$jCM(B] * 0 $BL$K~(B : $BAw?.%(%i!<(B * 0 : OK * * [$B;HMQ4X?t(B] * atokClntCommunicate( ) * [$B5!G=(B] * $B8uJd%j%9%H$h$j!"8=:_A*Br$5$l$F$$$k8uJdHV9f$r@_Dj$9$k!#(B */ int atokCandidate(acomm, nbr) _XatokRecPtr acomm; int nbr; { int status ; /* * if $BJ8I,MW$J$7(B */ if ( nbr != ATCEPRVAPI_READCMD ) { acomm->NETrqst.AtCEIncode = nbr ; } else { acomm->NETrqst.AtCEIncode = ATCEPRVAPI_READCMD ; } acomm->NETrqst.ceCmd = IME_PRV_CANDLIST ; status = AtokClntCommunicate( acomm->sock, &acomm->NETrqst, &acomm->NETrslt ) ; return status ; } /* Page */ /* * [$B4X?tL>(B] * atokWordRegister( ) * [$BI=Bj(B] * $BC18l$NEPO?(B * [$B8F=P7A<0(B] * atokWordRegister( _XatokRecPtr acomm, wchar *word, * int wlen, wchar *yomi, int ylen, int hinshi ) * * [$B0z?t(B] * $B7?(B : $BL>(B $B>N(B : I O : $B@b(B $BL@(B * _XatokRecPtr : acomm : i/o : kinput2$BMQJQ49%P%C%U%!(B * wchar : *word : i : $BEPO?C18l(B * int : wlen : i : $BEPO?C18lD9$5(B * wchar : *yomi : i : $BC18l$h$_(B * int : ylen : i : $BC18l$h$_$J$,$5(B * int : hinshi : i : $BIJ;lHV9f(B * * * [$BJV$jCM(B] * -1 : $BAw?.$G$-$J$$!#(B * 0 : $B@5>o=*N;(B * 1 : $B$3$NFI$_$G$O$3$l0J>eEPO?IT2D(B * 2 : $B$3$l0J>eEPO?IT2D(B * 3 : $B<-=q@_DjIT@5(B * 4 : $BI=5-$KITE,@Z$JJ8;z$r4^$`(B * 5 : $BEPO?$G$-$J$$!#(B * 6 : $BFI$_$KITE,@Z$JJ8;z$r4^$`(B * 7 : $B4{$KEPO?$5$l$F$$$k!#(B * * [$B;HMQ4X?t(B] * atokClntCommunicate( ) * wcs2euc( ) * euc2ucs( ) * [$B5!G=(B] * $BC18lEPO?$r9T$J$&!#(B * $BC18lI=5-!"$h$_$O(B $B$=$l$>$F(B UCS$B%3!<%I$GEPO?$9$k!#(B * kinput2 $B$G4IM}$7$F$$$k;~$O(B * $BC18lI=5-$O(B WCHAR, $BFI$_%3!<%I$O(BEUC$B$G$"$k$N$G$=$l$>$l(B * UCS $B$X$NJQ49$r0lEY9T$J$&!#(B * $BIJ;lHV9f$O!"#1$+$i;O$^$kJ*$G$"$k!#(B */ int atokWordRegister(acomm, word, wlen, yomi, ylen, hinshi) _XatokRecPtr acomm; wchar *word; int wlen; wchar *yomi; int ylen; int hinshi; { AtokReqPacket *req ; unsigned char *eucp ; WCHAR *ucs_wp ; /* $BC18l(B UCS $BJ8;zNs(B */ WCHAR *ucs_yp ; /* $BFI$_(B UCS $BJ8;zNs(B */ unsigned char *sjp ; int len ; int alen ; int i ; if ( wlen > ylen ) alen = wlen ; else alen = ylen ; acomm->NETrqst.ceCmd = IME_PRV_REGISTERWORDEX ; req = &acomm->NETrqst ; /* printf( "wlen %d, ylen %d\n", wlen, ylen ) ; */ eucp = ( unsigned char * )malloc( alen * sizeof( WCHAR ) + 1 ) ; sjp = ( unsigned char * )malloc( ylen * sizeof( WCHAR ) + 1 ) ; /* * $BC18lJ8;zNs$r(B WCS -> EUC -> UCS $BJQ49$9$k!#(B */ bzero( eucp, alen ) ; wcs2euc( word, wlen, eucp ) ; len = strlen( eucp ) ; ucs_wp = ( WCHAR * )malloc(( len + 1 ) * sizeof( WCHAR )) ; euc2ucs( eucp, strlen( eucp ), ucs_wp, len, 0x3013 ) ; #if 0 printf( "\303\261\270\354 WCS CODE -> "/*=$BC18l(B WCS CODE -> =*/ ) ; for( i = 0 ; i <= wlen ; i++ ) { printf( "0x%x ", word[i] ) ; } printf( "\303\261\270\354 EUC CODE -> "/*=$BC18l(B EUC CODE -> =*/ ) ; for( i = 0 ; i <= len ; i++ ) { printf( "0x%x ", eucp[i] ) ; } printf( "\n" ) ; printf( "\303\261\270\354 EUC [%s]\n"/*=$BC18l(B EUC [%s]\n=*/, eucp ) ; printf( "\303\261\270\354 UCS CODE -> "/*=$BC18l(B UCS CODE -> =*/ ) ; for( i = 0 ; i <= wlen ; i++ ) { /* printf( "0x%x ", ucs_wp[i] ) ; */ } printf( "\n" ) ; #endif /* * $BFI$_J8;zNs$r(B WCS -> EUC -> UCS $BJQ49$9$k!#(B */ bzero( eucp, alen ) ; wcs2euc( yomi, ylen, eucp ) ; len = strlen( eucp ) ; ucs_yp = ( WCHAR * )malloc(( len + 1 ) * sizeof( WCHAR )) ; euc2ucs( eucp, strlen( eucp ), ucs_yp, len, 0x3013 ) ; #if 0 printf( "\306\311\244\337 EUC CODE -->"/*=$BFI$_(B EUC CODE -->=*/ ) ; for( i = 0 ; i <= len ; i++ ) { printf( "0x%x ", eucp[i] ) ; } printf( "\n" ) ; printf( "\306\311\244\337 EUC [%s]\n"/*=$BFI$_(B EUC [%s]\n=*/, eucp ) ; for( i = 0 ; i <= strlen( eucp ) ; i++ ) { printf( "0x%0x ", eucp[i] ) ; } printf( "\n" ) ; printf( "\306\311\244\337 UCS CODE -> "/*=$BFI$_(B UCS CODE -> =*/ ) ; for( i = 0 ; i <= ylen ; i++ ) { printf( "0x%x ", ucs_yp[i] ) ; } printf( "\n" ) ; #endif /* * $BAw?.%Q%i%a!<%?$N:n@.(B */ req->Kind[0] = T_WCHAR ; req->Size[0] = wlen ; req->ArgPtr[0] = ucs_wp ; req->Kind[1] = T_WCHAR ; req->Size[1] = ylen ; req->ArgPtr[1] = ucs_yp ; req->Ctr[0] = hinshi ; AtokClntCommunicate( acomm->sock, &acomm->NETrqst, &acomm->NETrslt ) ; free( ucs_wp ) ; free( ucs_yp ) ; free( eucp ) ; /* printf( "$BEPO?7k2L(B %d\n", acomm->NETrslt.header.CEOutinf ) ; */ return acomm->NETrslt.header.CEOutinf ; } /* End of if.c */