1 /* nkf32.dll nfk32dll.c */
2 /* e-mail:tkaneto@nifty.com */
3 /* URL: http://www1.ttcn.ne.jp/~kaneto */
6 /*
\82±
\82¿
\82ç
\82Ì
\83o
\81[
\83W
\83\87\83\93\82à
\8dX
\90V
\82µ
\82Ä
\82
\82¾
\82³
\82¢
\81B */
7 #define NKF_VERSIONW L"2.1.0"
8 /* NKF_VERSION
\82Ì
\83\8f\83C
\83h
\95¶
\8e\9a */
9 #define DLL_VERSION "2.1.0.0 0"
11 #define DLL_VERSIONW L"2.1.0.0 0"
12 /* DLL
\82ª
\95Ô
\82· DLL_VERSION
\82Ì
\83\8f\83C
\83h
\95¶
\8e\9a */
19 #ifdef DLLDBG /* DLLDBG @@*/
22 void dumpn(unsigned char *buff,unsigned n)
31 printf("%02x ",*buff++);
43 void mkfile(char *f,char *p);
50 char *guessbuffA = NULL;
52 wchar_t *guessbuffW = NULL;
53 UINT guessCodePage = CP_OEMCP;
54 DWORD guessdwFlags = MB_PRECOMPOSED;
56 wchar_t *tounicode(const char *p)
58 static wchar_t buff[GUESS];
61 sts = MultiByteToWideChar(guessCodePage,guessdwFlags,p,-1,buff,sizeof(buff) / sizeof(wchar_t));
68 #endif /*UNICODESUPPORT*/
74 int dllprintf(FILE *fp,char *fmt,...)
79 if ( uret != FALSE && ulen >= 1 && fmt != NULL && *fmt != 0 ) {
81 sts = _vsnprintf(ubuff,ulen - 1,fmt,argp);
93 /** Network Kanji Filter. (PDS Version)
94 ************************************************************************
95 ** Copyright (C) 1987, Fujitsu LTD. (Itaru ICHIKAWA)
96 **
\98A
\97\8d\90æ
\81F
\81i
\8a\94\81j
\95x
\8em
\92Ê
\8c¤
\8b\86\8f\8a\81@
\83\
\83t
\83g
\82R
\8c¤
\81@
\8es
\90ì
\81@
\8e\8a
97 **
\81iE-Mail Address: ichikawa@flab.fujitsu.co.jp
\81j
98 ** Copyright (C) 1996,1998
100 **
\98A
\97\8d\90æ
\81F
\97®
\8b\85\91å
\8aw
\8fî
\95ñ
\8dH
\8aw
\89È
\89Í
\96ì
\90^
\8e¡ mime/X0208 support
101 **
\81iE-Mail Address: kono@ie.u-ryukyu.ac.jp
\81j
102 **
\98A
\97\8d\90æ
\81F COW for DOS & Win16 & Win32 & OS/2
103 **
\81iE-Mail Address: GHG00637@niftyserve.or.p
\81j
105 **
\82±
\82Ì
\83\
\81[
\83X
\82Ì
\82¢
\82©
\82È
\82é
\95¡
\8eÊ
\81C
\89ü
\95Ï
\81C
\8fC
\90³
\82à
\8b\96\91ø
\82µ
\82Ü
\82·
\81B
\82½
\82¾
\82µ
\81A
106 **
\82»
\82Ì
\8dÛ
\82É
\82Í
\81A
\92N
\82ª
\8dv
\8c£
\82µ
\82½
\82ð
\8e¦
\82·
\82±
\82Ì
\95\94\95ª
\82ð
\8ec
\82·
\82±
\82Æ
\81B
107 **
\8dÄ
\94z
\95z
\82â
\8eG
\8e\8f\82Ì
\95t
\98^
\82È
\82Ç
\82Ì
\96â
\82¢
\8d\87\82í
\82¹
\82à
\95K
\97v
\82 \82è
\82Ü
\82¹
\82ñ
\81B
108 **
\89c
\97\98\97\98\97p
\82à
\8fã
\8bL
\82É
\94½
\82µ
\82È
\82¢
\94Í
\88Í
\82Å
\8b\96\89Â
\82µ
\82Ü
\82·
\81B
109 **
\83o
\83C
\83i
\83\8a\82Ì
\94z
\95z
\82Ì
\8dÛ
\82É
\82Íversion message
\82ð
\95Û
\91¶
\82·
\82é
\82±
\82Æ
\82ð
\8fð
\8c\8f\82Æ
\82µ
\82Ü
\82·
\81B
110 **
\82±
\82Ì
\83v
\83\8d\83O
\83\89\83\80\82É
\82Â
\82¢
\82Ä
\82Í
\93Á
\82É
\89½
\82Ì
\95Û
\8fØ
\82à
\82µ
\82È
\82¢
\81A
\88«
\82µ
\82©
\82ç
\82¸
\81B
112 ** Everyone is permitted to do anything on this program
113 ** including copying, modifying, improving,
114 ** as long as you don't try to pretend that you wrote it.
115 ** i.e., the above copyright notice has to appear in all copies.
116 ** Binary distribution requires original version messages.
117 ** You don't have to ask before copying, redistribution or publishing.
118 ** THE AUTHOR DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE.
119 ***********************************************************************/
121 static const unsigned char *cin = NULL;
123 static int ninmax = -1;
124 static int std_getc_mode = 1;
130 if (!nkf_buf_empty_p(nkf_state->std_gc_buf)) {
131 return nkf_buf_pop(nkf_state->std_gc_buf);
133 if ( std_getc_mode == 1 ) {
136 if ( std_getc_mode == 2 && cin != NULL ) {
138 if ( nin >= ninmax ) {
156 static FILE *fout = NULL;
157 static unsigned char *cout = NULL;
158 static int nout = -1;
159 static int noutmax = -1;
160 static int std_putc_mode = 1;
168 if ( (std_putc_mode & 1) && fout != NULL ) {
171 if ( (std_putc_mode & 4) && nout != -1 ) {
172 if ( noutmax >= 0 && nout >= noutmax ) std_putc_mode &= ~2;
175 if ( (std_putc_mode & 2) && cout != NULL ) {
182 print_guessed_code (filename)
185 const char *codename = get_guessed_code();
186 if (filename != NULL) {
187 guessbuffA = realloc(guessbuffA,(strlen(filename) + GUESS + 1) * sizeof (char) );
188 sprintf(guessbuffA,"%s:%s", filename,codename);
190 guessbuffA = realloc(guessbuffA,(GUESS + 1) * sizeof (char) );
191 sprintf(guessbuffA,"%s", codename);
195 #ifdef UNICODESUPPORT
197 print_guessed_codeW (filename)
200 const char *codename = get_guessed_code();
202 if (filename != NULL) {
203 size = (wcslen(filename) + GUESS + 1) * sizeof (wchar_t);
204 guessbuffW = realloc(guessbuffW, size);
205 _snwprintf(guessbuffW, size, L"%s:%s", filename, tounicode(codename));
207 size = (GUESS + 1) * sizeof (wchar_t);
208 guessbuffW = realloc(guessbuffW, size);
209 _snwprintf(guessbuffW, size, L"%s", tounicode(codename));
212 #endif /*UNICODESUPPORT*/
215 **
\83p
\83b
\83`
\90§
\8dì
\8eÒ
216 ** void@merope.pleiades.or.jp (Kusakabe Youichi)
217 ** NIDE Naoyuki <nide@ics.nara-wu.ac.jp>
218 ** ohta@src.ricoh.co.jp (Junn Ohta)
219 ** inouet@strl.nhk.or.jp (Tomoyuki Inoue)
220 ** kiri@pulser.win.or.jp (Tetsuaki Kiriyama)
221 ** Kimihiko Sato <sato@sail.t.u-tokyo.ac.jp>
222 ** a_kuroe@kuroe.aoba.yokohama.jp (Akihiko Kuroe)
223 ** kono@ie.u-ryukyu.ac.jp (Shinji Kono)
224 ** GHG00637@nifty-serve.or.jp (COW)
244 #ifdef UNICODESUPPORT
249 #endif /*UNICODESUPPORT*/
252 #ifndef DLLDBG /* DLLDBG @@*/
253 int WINAPI DllEntryPoint(HINSTANCE hinst,unsigned long reason,void* lpReserved)
257 #endif /* DLLDBG @@*/
259 static LPSTR nkfverA = NKF_VERSION;
260 static LPSTR dllverA = DLL_VERSION;
261 #ifdef UNICODESUPPORT
262 static LPWSTR nkfverW = NKF_VERSIONW;
263 static LPWSTR dllverW = DLL_VERSIONW;
264 #endif /*UNICODESUPPORT*/
266 BOOL scp(LPSTR s,LPSTR t,DWORD n)
269 if ( (*s = *t) == 0 ) return TRUE;
280 #ifdef UNICODESUPPORT
281 BOOL wscp(LPWSTR s,LPWSTR t,DWORD n)
284 if ( (*s = *t) == 0 ) return TRUE;
294 #endif /*UNICODESUPPORT*/
296 void CALLBACK GetNkfVersion(LPSTR verStr){
297 strcpy(verStr,dllverA);
300 BOOL WINAPI GetNkfVersionSafeA(LPSTR verStr,DWORD nBufferLength /*in TCHARs*/,LPDWORD lpTCHARsReturned /*in TCHARs*/)
302 *lpTCHARsReturned = strlen(dllverA) + 1;
303 if ( verStr == NULL || nBufferLength == 0 ) return FALSE;
304 return scp(verStr,dllverA,nBufferLength);
307 BOOL WINAPI GetNkfVersionSafeW(LPWSTR verStr,DWORD nBufferLength /*in TCHARs*/,LPDWORD lpTCHARsReturned /*in TCHARs*/)
309 #ifdef UNICODESUPPORT
310 *lpTCHARsReturned = wcslen(dllverW) + 1;
311 if ( verStr == NULL || nBufferLength == 0 ) return FALSE;
312 wcsncpy(verStr,dllverW,nBufferLength);
313 if ( wcslen(dllverW) >= nBufferLength ) {
314 *(verStr + nBufferLength - 1) = 0;
318 #else /*UNICODESUPPORT*/
320 #endif /*UNICODESUPPORT*/
323 static LPSTR optStr0 = NULL;
325 int CALLBACK SetNkfOption(LPSTR optStr)
330 if ( *optStr == '-' ) {
331 len = strlen(optStr) + 1;
332 p = realloc(optStr0,len);
335 len = strlen(optStr) + 2;
336 p = realloc(optStr0,len);
338 strcpy(p + 1,optStr);
347 if ( optStr0 != NULL ) {
352 void CALLBACK NkfConvert(LPSTR outStr, LPCSTR inStr)
367 BOOL WINAPI NkfConvertSafe(LPSTR outStr,DWORD nOutBufferLength /*in Bytes*/,LPDWORD lpBytesReturned /*in Bytes*/, LPCSTR inStr,DWORD nInBufferLength /*in Bytes*/){
368 if ( inStr == NULL ) return FALSE;
372 noutmax = nOutBufferLength;
376 ninmax = nInBufferLength;
379 *lpBytesReturned = nout;
380 if ( nout < noutmax ) *cout = 0;
384 void CALLBACK ToHankaku(LPSTR inStr)
389 len = strlen(inStr) + 1;
391 if ( p == NULL ) return;
398 BOOL WINAPI ToHankakuSafe(LPSTR outStr,DWORD nOutBufferLength /*in Bytes*/,LPDWORD lpBytesReturned /*in Bytes*/,LPCSTR inStr,DWORD nInBufferLength /*in Bytes*/)
401 return NkfConvertSafe(outStr,nOutBufferLength,lpBytesReturned,inStr,nInBufferLength);
404 void CALLBACK ToZenkakuKana(LPSTR outStr, LPCSTR inStr)
407 NkfConvert(outStr, inStr);
410 BOOL WINAPI ToZenkakuKanaSafe(LPSTR outStr,DWORD nOutBufferLength /*in Bytes*/,LPDWORD lpBytesReturned /*in Bytes*/,LPCSTR inStr,DWORD nInBufferLength /*in Bytes*/)
413 return NkfConvertSafe(outStr,nOutBufferLength,lpBytesReturned,inStr,nInBufferLength);
416 void CALLBACK EncodeSubject(LPSTR outStr ,LPCSTR inStr){
418 NkfConvert(outStr, inStr);
421 BOOL WINAPI EncodeSubjectSafe(LPSTR outStr,DWORD nOutBufferLength /*in Bytes*/,LPDWORD lpBytesReturned /*in Bytes*/,LPCSTR inStr,DWORD nInBufferLength /*in Bytes*/)
424 return NkfConvertSafe(outStr,nOutBufferLength,lpBytesReturned,inStr,nInBufferLength);
428 void CALLBACK ToMime(LPSTR outStr ,LPCSTR inStr)
430 EncodeSubject(outStr,inStr);
435 int CALLBACK NkfGetKanjiCode(VOID)
438 /* if(iconv == s_iconv)iCode=0; */ /* 0:
\83V
\83t
\83gJIS */
439 if(iconv == w_iconv)iCode=3; /* UTF-8 */
440 else if(iconv == w_iconv16){
441 if(input_endian == ENDIAN_BIG)iCode=5; /* 5:UTF-16BE */
442 else iCode=4; /* 4:UTF-16LE */
443 }else if(iconv == e_iconv){
444 if(estab_f == FALSE)iCode=2; /* 2:ISO-2022-JP */
445 else iCode=1; /* 1:EUC */
449 #endif /*GETKANJICODE*/
452 void CALLBACK NkfFileConvert1(LPCSTR fName)
456 char tempfname[MAX_PATH];
461 len = GetTempPath(sizeof d,d);
462 tempdname = malloc(len + 1);
463 if ( tempdname == NULL ) return;
464 len = GetTempPath(len + 1,tempdname);
465 sts = GetTempFileName(tempdname,"NKF",0,tempfname);
467 sts = CopyFileA(fName,tempfname,FALSE);
469 if ((fin = fopen(tempfname, "rb")) != NULL) {
470 if ((fout = fopen(fName, "wb")) != NULL) {
484 DeleteFile(tempfname);
489 #endif /*FILECONVERT1*/
491 BOOL WINAPI NkfFileConvert1SafeA(LPCSTR fName,DWORD nBufferLength /*in TCHARs*/)
495 char tempfname[MAX_PATH];
505 if ( nBufferLength == 0 ) return ret;
506 if ( *p == 0 ) break;
510 if ( chmod(fName,_S_IREAD | _S_IWRITE) == -1 ) return ret;
511 len = GetTempPath(sizeof d,d);
512 tempdname = malloc(len + 1);
513 if ( tempdname == NULL ) return FALSE;
514 len = GetTempPath(len + 1,tempdname);
515 sts = GetTempFileName(tempdname,"NKF",0,tempfname);
517 sts = CopyFileA(fName,tempfname,FALSE);
519 if ((fin = fopen(tempfname, "rb")) != NULL) {
520 if ((fout = fopen(fName, "wb")) != NULL) {
535 DeleteFileA(tempfname);
542 BOOL WINAPI NkfFileConvert1SafeW(LPCWSTR fName,DWORD nBufferLength /*in TCHARs*/)
544 #ifdef UNICODESUPPORT
547 wchar_t tempfname[MAX_PATH];
557 if ( nBufferLength == 0 ) return ret;
558 if ( *p == 0 ) break;
562 if ( _wchmod(fName,_S_IREAD | _S_IWRITE) == -1 ) return ret;
563 len = GetTempPathW(sizeof d / sizeof(WCHAR),d);
564 tempdname = malloc((len + 1) * sizeof(WCHAR));
565 if ( tempdname == NULL ) return FALSE;
566 len = GetTempPathW(len + 1,tempdname);
567 sts = GetTempFileNameW(tempdname,L"NKF",0,tempfname);
569 sts = CopyFileW(fName,tempfname,FALSE);
571 if ((fin = _wfopen(tempfname,L"rb")) != NULL) {
572 if ((fout = _wfopen(fName,L"wb")) != NULL) {
587 DeleteFileW(tempfname);
592 #else /*UNICODESUPPORT*/
594 #endif /*UNICODESUPPORT*/
598 void CALLBACK NkfFileConvert2(LPCSTR fInName,LPCSTR fOutName)
602 if ((fin = fopen(fInName, "rb")) == NULL) return;
603 if((fout=fopen(fOutName, "wb")) == NULL) {
619 #endif /*FILECONVERT2*/
621 BOOL WINAPI NkfFileConvert2SafeA(LPCSTR fInName,DWORD fInBufferLength /*in TCHARs*/,LPCSTR fOutName,DWORD fOutBufferLength /*in TCHARs*/)
631 if ( fInBufferLength == 0 ) return ret;
632 if ( *p == 0 ) break;
638 if ( fOutBufferLength == 0 ) return ret;
639 if ( *p == 0 ) break;
643 if ((fin = fopen(fInName, "rb")) != NULL) {
644 if((fout=fopen(fOutName, "wb")) != NULL) {
662 BOOL WINAPI NkfFileConvert2SafeW(LPCWSTR fInName,DWORD fInBufferLength /*in TCHARs*/,LPCWSTR fOutName,DWORD fOutBufferLength /*in TCHARs*/)
664 #ifdef UNICODESUPPORT
673 if ( fInBufferLength == 0 ) return ret;
674 if ( *p == 0 ) break;
680 if ( fOutBufferLength == 0 ) return ret;
681 if ( *p == 0 ) break;
685 if ( (fin = _wfopen(fInName,L"rb")) != NULL) {
686 if( (fout = _wfopen(fOutName,L"wb")) != NULL) {
702 #else /*UNICODESUPPORT*/
704 #endif /*UNICODESUPPORT*/
707 BOOL WINAPI GetNkfGuessA(LPSTR outStr,DWORD nBufferLength /*in TCHARs*/,LPDWORD lpTCHARsReturned /*in TCHARs*/)
709 if ( outStr == NULL || nBufferLength == 0 ) return FALSE;
710 print_guessed_code(NULL);
711 *lpTCHARsReturned = strlen(guessbuffA) + 1;
712 return scp(outStr,guessbuffA,nBufferLength);
715 BOOL WINAPI GetNkfGuessW(LPWSTR outStr,DWORD nBufferLength /*in TCHARs*/,LPDWORD lpTCHARsReturned /*in TCHARs*/)
717 #ifdef UNICODESUPPORT
718 if ( outStr == NULL || nBufferLength == 0 ) return FALSE;
719 print_guessed_codeW(NULL);
720 *lpTCHARsReturned = wcslen(guessbuffW) + 1;
721 return wscp(outStr,guessbuffW,nBufferLength);
722 #else /*UNICODESUPPORT*/
724 #endif /*UNICODESUPPORT*/
733 } NkfSupportFunctions = {
734 sizeof(NkfSupportFunctions),
738 1 /* nkf32103a.lzh uminchu 1.03 */
739 /* | 2 */ /* nkf32dll.zip 0.91 */
740 #if defined(TOMIME) && defined(GETKANJICODE) && defined(FILECONVERT1) && defined(FILECONVERT2)
741 | 4 /* nkf32204.zip Kaneto 2.0.4.0 */
744 #ifdef UNICODESUPPORT
746 #endif /*UNICODESUPPORT*/
750 BOOL WINAPI GetNkfSupportFunctions(void *outStr,DWORD nBufferLength /*in Bytes*/,LPDWORD lpBytesReturned /*in Bytes*/)
752 *lpBytesReturned = sizeof NkfSupportFunctions;
753 if ( outStr == NULL || nBufferLength == 0 ) return FALSE;
754 NkfSupportFunctions.copyrightA = COPY_RIGHT;
755 memcpy(outStr,&NkfSupportFunctions,sizeof NkfSupportFunctions > nBufferLength ? nBufferLength : sizeof NkfSupportFunctions);
759 BOOL WINAPI NkfUsage(LPSTR outStr,DWORD nBufferLength /*in Bytes*/,LPDWORD lpBytesReturned /*in Bytes*/)
762 ulen = nBufferLength;
765 if ( uret == TRUE ) {
766 *lpBytesReturned = nBufferLength - ulen;
771 /* nkf32.dll main end */
773 #ifdef DLLDBG /* DLLDBG @@*/
775 unsigned char buff[65536];
776 unsigned char buff2[65536];
777 unsigned char buff3[65536];
778 unsigned char buff4[65536];
779 char *code[] = {"
\83V
\83t
\83gJIS","EUC","ISO-2022-JP","UTF-8","UTF-16LE","UTF-16BE"};
785 void mimeencode(unsigned char *buff2)
787 memset(buff,0,sizeof buff);
788 EncodeSubject(buff,buff2);
789 printf("EncodeSubject(%s)=%s\n",buff2,buff);
790 memset(buff,0,sizeof buff);
792 printf("ToMime(%s)=%s\n",buff2,buff);
793 memset(buff,0,sizeof buff);
794 sts = EncodeSubjectSafe(buff,sizeof buff,&len,buff2,strlen(buff2));
795 printf("EncodeSubjectSafe(%s)=%d len=%d '%s'\n",buff,sts,len,buff);
796 dumpn(buff2,strlen(buff2));
800 void convert(char *arg,unsigned char *buff2)
802 sts = SetNkfOption(arg);
803 printf("SetNkfOption(%s)=%d\n",arg,sts);
804 memset(buff,0,sizeof buff);
805 NkfConvert(buff,buff2);
806 printf("NkfConvert(%s)=%s\n",buff2,buff);
807 n = NkfGetKanjiCode();
808 printf("NkfGetKanjiCode()=%d\n",n);
809 sts = SetNkfOption(arg);
810 printf("SetNkfOption(%s)=%d\n",arg,sts);
811 memset(buff,0,sizeof buff);
812 sts = NkfConvertSafe(buff,sizeof buff,&len,buff2,strlen(buff2));
813 printf("NkfConvertSafe(%s)=%d len=%d '%s'\n",buff2,sts,len,buff);
814 dumpn(buff2,strlen(buff2));
816 n = NkfGetKanjiCode();
817 printf("NkfGetKanjiCode()=%d\n",n);
820 void guess(unsigned char *buff2)
824 sts = SetNkfOption(g);
825 printf("SetNkfOption(%s)=%d\n",g,sts);
826 memset(buff,0,sizeof buff);
827 NkfConvert(buff,buff2);
828 printf("NkfConvert(%s)=%s\n",buff2,buff);
829 dumpn(buff2,strlen(buff2));
830 n = NkfGetKanjiCode();
831 printf("NkfGetKanjiCode()=%d %s\n",n,code[n]);
832 memset(buff,0,sizeof buff);
833 sts = GetNkfGuessA(buff,sizeof buff,&len);
834 printf("GetNkfGuessA()=%d len=%d '%s'\n",sts,len,buff);
836 memset(buff,0,sizeof buff);
837 sts = GetNkfGuessW((LPWSTR)buff,sizeof buff / sizeof(WCHAR),&len);
838 printf("GetNkfGuessW()=%d len=%d\n",sts,len);
839 dumpn(buff,len * sizeof(WCHAR));
848 if ( fp == NULL ) return;
849 n = fread(buff,1,sizeof buff,fp);
851 printf("dumpf(%s,%d)\n",f,n);
855 void mkfile(char *f,char *p)
860 if ( fp == NULL ) return;
866 void file(char *arg2,char *arg3,unsigned char *buf)
868 sts = SetNkfOption(arg2);
869 printf("SetNkfOption(%s)=%d\n",arg2,sts);
871 NkfFileConvert1(arg3);
872 printf("NkfFileConvert1(%s)\n",arg3);
874 sts = SetNkfOption(arg2);
875 printf("SetNkfOption(%s)=%d\n",arg2,sts);
877 sts = NkfFileConvert1SafeA(arg3,strlen(arg3) + 1);
878 printf("NkfFileConvert1SafeA(%s)=%d\n",arg3,sts);
880 sts = SetNkfOption(arg2);
881 printf("SetNkfOption(%s)=%d\n",arg2,sts);
883 sts = MultiByteToWideChar(CP_OEMCP,MB_PRECOMPOSED,arg3,-1,(wchar_t *)buff,sizeof(buff) / sizeof(wchar_t));
884 printf("MultiByteToWideChar(%s)=%d\n",arg3,sts);
885 dumpn(buff,(wcslen((wchar_t *)buff) + 1) * sizeof(wchar_t));
886 sts = NkfFileConvert1SafeW((wchar_t *)buff,sizeof buff / sizeof(wchar_t) /*wcslen((wchar_t *)buff) + 1*/);
887 printf("NkfFileConvert1SafeW()=%d\n",sts);
891 void file2(char *arg2,char *arg3,char *arg4,unsigned char *buf)
893 sts = SetNkfOption(arg2);
894 printf("SetNkfOption(%s)=%d\n",arg2,sts);
896 NkfFileConvert2(arg3,arg4);
897 printf("NkfFileConvert1(%s,%s)\n",arg3,arg4);
900 sts = SetNkfOption(arg2);
901 printf("SetNkfOption(%s)=%d\n",arg2,sts);
903 sts = NkfFileConvert2SafeA(arg3,strlen(arg3) + 1,arg4,strlen(arg4) + 1);
904 printf("NkfFileConvert2SafeA(%s,%s)=%d\n",arg3,arg4,sts);
907 sts = SetNkfOption(arg2);
908 printf("SetNkfOption(%s)=%d\n",arg2,sts);
910 sts = MultiByteToWideChar(CP_OEMCP,MB_PRECOMPOSED,arg3,-1,(wchar_t *)buff,sizeof(buff) / sizeof(wchar_t));
911 printf("MultiByteToWideChar(%s)=%d\n",arg3,sts);
912 dumpn(buff,(wcslen((wchar_t *)buff) + 1) * sizeof(wchar_t));
913 sts = MultiByteToWideChar(CP_OEMCP,MB_PRECOMPOSED,arg4,-1,(wchar_t *)buff4,sizeof(buff4) / sizeof(wchar_t));
914 printf("MultiByteToWideChar(%s)=%d\n",arg4,sts);
915 dumpn(buff4,(wcslen((wchar_t *)buff4) + 1) * sizeof(wchar_t));
916 sts = NkfFileConvert2SafeW((wchar_t *)buff,sizeof buff / sizeof(wchar_t) ,(wchar_t *)buff4,sizeof buff4 / sizeof(wchar_t));
917 printf("NkfFileConvert2SafeW()=%d\n",sts);
922 int main(int argc,char **argv)
924 struct NKFSUPPORTFUNCTIONS fnc;
926 if ( argc < 2 ) return 0;
927 switch ( *argv[1] ) {
929 memset(buff,0,sizeof buff);
931 printf("GetNkfVersion() '%s'\n",buff);
932 sts = GetNkfVersionSafeA(buff,sizeof buff,&len);
933 printf("GetNkfVersionSafeA()=%d len=%d '%s'\n",sts,len,buff);
934 sts = GetNkfVersionSafeW((LPWSTR)buff,sizeof buff / sizeof(WCHAR),&len);
935 printf("GetNkfVersionSafeW()=%d len=%d\n",sts,len);
936 dumpn(buff,len * sizeof(WCHAR));
937 sts = GetNkfSupportFunctions(&fnc,sizeof fnc,&len);
938 printf("GetNkfSupportFunctions()=%d len=%d\n",sts,len);
939 printf("size=%d\n",fnc.size);
940 printf("copyrightA='%s'\n",fnc.copyrightA);
941 printf("versionA='%s'\n",fnc.versionA);
942 printf("dateA='%s'\n",fnc.dateA);
943 printf("functions=%d %x\n",fnc.functions,fnc.functions);
946 if ( argc < 3 ) return 0;
950 if ( argc < 2 ) return 0;
955 if ( argc < 4 ) return 0;
956 convert(argv[2],argv[3]);
959 if ( argc < 3 ) return 0;
961 convert(argv[2],buff2);
964 if ( argc < 3 ) return 0;
968 if ( argc < 2 ) return 0;
973 if ( argc < 5 ) return 0;
974 file(argv[2],argv[3],argv[4]);
977 if ( argc < 4 ) return 0;
979 file(argv[2],argv[3],buff3);
982 if ( argc < 6 ) return 0;
983 file2(argv[2],argv[3],argv[4],argv[5]);
986 if ( argc < 5 ) return 0;
988 file2(argv[2],argv[3],argv[4],buff3);
991 sts = NkfUsage(buff,sizeof buff,&len);
992 printf("strlen(buff)=%d\n",strlen(buff));
993 printf("NkfUsage()=%d len=%d \n%s",sts,len,buff);
999 #endif /* DLLDBG @@*/