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.0.7"
8 /* NKF_VERSION
\82Ì
\83\8f\83C
\83h
\95¶
\8e\9a */
9 #define DLL_VERSION "2.0.7.0 1"
11 #define DLL_VERSIONW L"2.0.7.0 1"
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(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;
131 return std_gc_buf[--std_gc_ndx];
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 char *codename = "BINARY";
186 if (!is_inputcode_mixed) {
187 if (strcmp(input_codename, "") == 0) {
190 codename = input_codename;
193 if (filename != NULL) {
194 guessbuffA = realloc(guessbuffA,(strlen(filename) + GUESS + 1) * sizeof (char) );
195 sprintf(guessbuffA,"%s:%s", filename,codename);
197 guessbuffA = realloc(guessbuffA,(GUESS + 1) * sizeof (char) );
198 sprintf(guessbuffA,"%s", codename);
202 #ifdef UNICODESUPPORT
204 print_guessed_codeW (filename)
207 char *codename = "BINARY";
208 if (!is_inputcode_mixed) {
209 if (strcmp(input_codename, "") == 0) {
212 codename = input_codename;
215 if (filename != NULL) {
216 guessbuffW = realloc(guessbuffW,(wcslen(filename) + GUESS + 1) * sizeof (wchar_t) );
217 swprintf(guessbuffW,L"%s:%s",filename,tounicode(codename));
219 guessbuffW = realloc(guessbuffW,(GUESS + 1) * sizeof (wchar_t));
220 swprintf(guessbuffW,L"%s",tounicode(codename));
223 #endif /*UNICODESUPPORT*/
226 **
\83p
\83b
\83`
\90§
\8dì
\8eÒ
227 ** void@merope.pleiades.or.jp (Kusakabe Youichi)
228 ** NIDE Naoyuki <nide@ics.nara-wu.ac.jp>
229 ** ohta@src.ricoh.co.jp (Junn Ohta)
230 ** inouet@strl.nhk.or.jp (Tomoyuki Inoue)
231 ** kiri@pulser.win.or.jp (Tetsuaki Kiriyama)
232 ** Kimihiko Sato <sato@sail.t.u-tokyo.ac.jp>
233 ** a_kuroe@kuroe.aoba.yokohama.jp (Akihiko Kuroe)
234 ** kono@ie.u-ryukyu.ac.jp (Shinji Kono)
235 ** GHG00637@nifty-serve.or.jp (COW)
255 #ifdef UNICODESUPPORT
260 #endif /*UNICODESUPPORT*/
263 #ifndef DLLDBG /* DLLDBG @@*/
264 int WINAPI DllEntryPoint(HINSTANCE hinst,unsigned long reason,void* lpReserved)
268 #endif /* DLLDBG @@*/
270 static LPSTR nkfverA = NKF_VERSION;
271 static LPSTR dllverA = DLL_VERSION;
272 #ifdef UNICODESUPPORT
273 static LPWSTR nkfverW = NKF_VERSIONW;
274 static LPWSTR dllverW = DLL_VERSIONW;
275 #endif /*UNICODESUPPORT*/
277 BOOL scp(LPSTR s,LPSTR t,DWORD n)
280 if ( (*s = *t) == 0 ) return TRUE;
291 #ifdef UNICODESUPPORT
292 BOOL wscp(LPWSTR s,LPWSTR t,DWORD n)
295 if ( (*s = *t) == 0 ) return TRUE;
305 #endif /*UNICODESUPPORT*/
307 void CALLBACK GetNkfVersion(LPSTR verStr){
308 strcpy(verStr,dllverA);
311 BOOL WINAPI GetNkfVersionSafeA(LPSTR verStr,DWORD nBufferLength /*in TCHARs*/,LPDWORD lpTCHARsReturned /*in TCHARs*/)
313 *lpTCHARsReturned = strlen(dllverA) + 1;
314 if ( verStr == NULL || nBufferLength == 0 ) return FALSE;
315 return scp(verStr,dllverA,nBufferLength);
318 BOOL WINAPI GetNkfVersionSafeW(LPWSTR verStr,DWORD nBufferLength /*in TCHARs*/,LPDWORD lpTCHARsReturned /*in TCHARs*/)
320 #ifdef UNICODESUPPORT
321 *lpTCHARsReturned = wcslen(dllverW) + 1;
322 if ( verStr == NULL || nBufferLength == 0 ) return FALSE;
323 wcsncpy(verStr,dllverW,nBufferLength);
324 if ( wcslen(dllverW) >= nBufferLength ) {
325 *(verStr + nBufferLength - 1) = 0;
329 #else /*UNICODESUPPORT*/
331 #endif /*UNICODESUPPORT*/
334 int CALLBACK SetNkfOption(LPCSTR optStr)
338 if ( *optStr == '-' ) {
342 p = malloc(strlen(optStr) + 2);
343 if ( p == NULL ) return -1;
345 strcpy(p + 1,optStr);
353 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;
371 noutmax = nOutBufferLength;
375 ninmax = nInBufferLength;
378 *lpBytesReturned = nout;
379 if ( nout < noutmax ) *cout = 0;
383 void CALLBACK ToHankaku(LPSTR inStr)
388 len = strlen(inStr) + 1;
390 if ( p == NULL ) return;
398 BOOL WINAPI ToHankakuSafe(LPSTR outStr,DWORD nOutBufferLength /*in Bytes*/,LPDWORD lpBytesReturned /*in Bytes*/,LPCSTR inStr,DWORD nInBufferLength /*in Bytes*/)
402 return NkfConvertSafe(outStr,nOutBufferLength,lpBytesReturned,inStr,nInBufferLength);
405 void CALLBACK ToZenkakuKana(LPSTR outStr, LPCSTR inStr)
409 NkfConvert(outStr, inStr);
412 BOOL WINAPI ToZenkakuKanaSafe(LPSTR outStr,DWORD nOutBufferLength /*in Bytes*/,LPDWORD lpBytesReturned /*in Bytes*/,LPCSTR inStr,DWORD nInBufferLength /*in Bytes*/)
416 return NkfConvertSafe(outStr,nOutBufferLength,lpBytesReturned,inStr,nInBufferLength);
419 void CALLBACK EncodeSubject(LPSTR outStr ,LPCSTR inStr){
422 NkfConvert(outStr, inStr);
425 BOOL WINAPI EncodeSubjectSafe(LPSTR outStr,DWORD nOutBufferLength /*in Bytes*/,LPDWORD lpBytesReturned /*in Bytes*/,LPCSTR inStr,DWORD nInBufferLength /*in Bytes*/)
429 return NkfConvertSafe(outStr,nOutBufferLength,lpBytesReturned,inStr,nInBufferLength);
433 void CALLBACK ToMime(LPSTR outStr ,LPCSTR inStr)
435 EncodeSubject(outStr,inStr);
440 int CALLBACK NkfGetKanjiCode(VOID)
443 //if(iconv == s_iconv)iCode=0; /* 0:
\83V
\83t
\83gJIS */
444 if(iconv == w_iconv)iCode=3; /* UTF-8 */
445 else if(iconv == w_iconv16){
446 if(utf16_mode == UTF16BE_INPUT)iCode=5; /* 5:UTF-16BE */
447 else iCode=4; /* 4:UTF-16LE */
448 }else if(iconv == e_iconv){
449 if(estab_f == FALSE)iCode=2; /* 2:ISO-2022-JP */
450 else iCode=1; /* 1:EUC */
454 #endif /*GETKANJICODE*/
457 void CALLBACK NkfFileConvert1(LPCSTR fName)
461 char tempfname[MAX_PATH];
466 len = GetTempPath(sizeof d,d);
467 tempdname = malloc(len + 1);
468 if ( tempdname == NULL ) return;
469 len = GetTempPath(len + 1,tempdname);
470 sts = GetTempFileName(tempdname,"NKF",0,tempfname);
472 sts = CopyFileA(fName,tempfname,FALSE);
474 if ((fin = fopen(tempfname, "rb")) != NULL) {
475 if ((fout = fopen(fName, "wb")) != NULL) {
489 DeleteFile(tempfname);
494 #endif /*FILECONVERT1*/
496 BOOL WINAPI NkfFileConvert1SafeA(LPCSTR fName,DWORD nBufferLength /*in TCHARs*/)
500 char tempfname[MAX_PATH];
510 if ( nBufferLength == 0 ) return ret;
511 if ( *p == 0 ) break;
515 if ( chmod(fName,_S_IREAD | _S_IWRITE) == -1 ) return ret;
516 len = GetTempPath(sizeof d,d);
517 tempdname = malloc(len + 1);
518 if ( tempdname == NULL ) return FALSE;
519 len = GetTempPath(len + 1,tempdname);
520 sts = GetTempFileName(tempdname,"NKF",0,tempfname);
522 sts = CopyFileA(fName,tempfname,FALSE);
524 if ((fin = fopen(tempfname, "rb")) != NULL) {
525 if ((fout = fopen(fName, "wb")) != NULL) {
540 DeleteFileA(tempfname);
547 BOOL WINAPI NkfFileConvert1SafeW(LPCWSTR fName,DWORD nBufferLength /*in TCHARs*/)
549 #ifdef UNICODESUPPORT
552 wchar_t tempfname[MAX_PATH];
562 if ( nBufferLength == 0 ) return ret;
563 if ( *p == 0 ) break;
567 if ( _wchmod(fName,_S_IREAD | _S_IWRITE) == -1 ) return ret;
568 len = GetTempPathW(sizeof d / sizeof(WCHAR),d);
569 tempdname = malloc((len + 1) * sizeof(WCHAR));
570 if ( tempdname == NULL ) return FALSE;
571 len = GetTempPathW(len + 1,tempdname);
572 sts = GetTempFileNameW(tempdname,L"NKF",0,tempfname);
574 sts = CopyFileW(fName,tempfname,FALSE);
576 if ((fin = _wfopen(tempfname,L"rb")) != NULL) {
577 if ((fout = _wfopen(fName,L"wb")) != NULL) {
592 DeleteFileW(tempfname);
597 #else /*UNICODESUPPORT*/
599 #endif /*UNICODESUPPORT*/
603 void CALLBACK NkfFileConvert2(LPCSTR fInName,LPCSTR fOutName)
607 if ((fin = fopen(fInName, "rb")) == NULL) return;
608 if((fout=fopen(fOutName, "wb")) == NULL) {
624 #endif /*FILECONVERT2*/
626 BOOL WINAPI NkfFileConvert2SafeA(LPCSTR fInName,DWORD fInBufferLength /*in TCHARs*/,LPCSTR fOutName,DWORD fOutBufferLength /*in TCHARs*/)
636 if ( fInBufferLength == 0 ) return ret;
637 if ( *p == 0 ) break;
643 if ( fOutBufferLength == 0 ) return ret;
644 if ( *p == 0 ) break;
648 if ((fin = fopen(fInName, "rb")) != NULL) {
649 if((fout=fopen(fOutName, "wb")) != NULL) {
667 BOOL WINAPI NkfFileConvert2SafeW(LPCWSTR fInName,DWORD fInBufferLength /*in TCHARs*/,LPCWSTR fOutName,DWORD fOutBufferLength /*in TCHARs*/)
669 #ifdef UNICODESUPPORT
678 if ( fInBufferLength == 0 ) return ret;
679 if ( *p == 0 ) break;
685 if ( fOutBufferLength == 0 ) return ret;
686 if ( *p == 0 ) break;
690 if ( (fin = _wfopen(fInName,L"rb")) != NULL) {
691 if( (fout = _wfopen(fOutName,L"wb")) != NULL) {
707 #else /*UNICODESUPPORT*/
709 #endif /*UNICODESUPPORT*/
712 BOOL WINAPI GetNkfGuessA(LPSTR outStr,DWORD nBufferLength /*in TCHARs*/,LPDWORD lpTCHARsReturned /*in TCHARs*/)
714 if ( outStr == NULL || nBufferLength == 0 ) return FALSE;
715 print_guessed_code(NULL);
716 *lpTCHARsReturned = strlen(guessbuffA) + 1;
717 return scp(outStr,guessbuffA,nBufferLength);
720 BOOL WINAPI GetNkfGuessW(LPWSTR outStr,DWORD nBufferLength /*in TCHARs*/,LPDWORD lpTCHARsReturned /*in TCHARs*/)
722 #ifdef UNICODESUPPORT
723 if ( outStr == NULL || nBufferLength == 0 ) return FALSE;
724 print_guessed_codeW(NULL);
725 *lpTCHARsReturned = wcslen(guessbuffW) + 1;
726 return wscp(outStr,guessbuffW,nBufferLength);
727 #else /*UNICODESUPPORT*/
729 #endif /*UNICODESUPPORT*/
738 } NkfSupportFunctions = {
739 sizeof(NkfSupportFunctions),
743 1 /* nkf32103a.lzh uminchu 1.03 */
744 /* | 2 */ /* nkf32dll.zip 0.91 */
745 #if defined(TOMIME) && defined(GETKANJICODE) && defined(FILECONVERT1) && defined(FILECONVERT2)
746 | 4 /* nkf32204.zip Kaneto 2.0.4.0 */
749 #ifdef UNICODESUPPORT
751 #endif /*UNICODESUPPORT*/
755 BOOL WINAPI GetNkfSupportFunctions(void *outStr,DWORD nBufferLength /*in Bytes*/,LPDWORD lpBytesReturned /*in Bytes*/)
757 *lpBytesReturned = sizeof NkfSupportFunctions;
758 if ( outStr == NULL || nBufferLength == 0 ) return FALSE;
759 NkfSupportFunctions.copyrightA = CopyRight;
760 memcpy(outStr,&NkfSupportFunctions,sizeof NkfSupportFunctions > nBufferLength ? nBufferLength : sizeof NkfSupportFunctions);
764 BOOL WINAPI NkfUsage(LPSTR outStr,DWORD nBufferLength /*in Bytes*/,LPDWORD lpBytesReturned /*in Bytes*/)
767 ulen = nBufferLength;
770 if ( uret == TRUE ) {
771 *lpBytesReturned = nBufferLength - ulen;
776 /* nkf32.dll main end */
778 #ifdef DLLDBG /* DLLDBG @@*/
780 unsigned char buff[65536];
781 unsigned char buff2[65536];
782 unsigned char buff3[65536];
783 unsigned char buff4[65536];
784 char *code[] = {"
\83V
\83t
\83gJIS","EUC","ISO-2022-JP","UTF-8","UTF-16LE","UTF-16BE"};
790 void mimeencode(unsigned char *buff2)
792 memset(buff,0,sizeof buff);
793 EncodeSubject(buff,buff2);
794 printf("EncodeSubject(%s)=%s\n",buff2,buff);
795 memset(buff,0,sizeof buff);
797 printf("ToMime(%s)=%s\n",buff2,buff);
798 memset(buff,0,sizeof buff);
799 sts = EncodeSubjectSafe(buff,sizeof buff,&len,buff2,strlen(buff2));
800 printf("EncodeSubjectSafe(%s)=%d len=%d '%s'\n",buff,sts,len,buff);
801 dumpn(buff2,strlen(buff2));
805 void convert(char *arg,unsigned char *buff2)
807 sts = SetNkfOption(arg);
808 printf("SetNkfOption(%s)=%d\n",arg,sts);
809 memset(buff,0,sizeof buff);
810 NkfConvert(buff,buff2);
811 printf("NkfConvert(%s)=%s\n",buff2,buff);
812 n = NkfGetKanjiCode();
813 printf("NkfGetKanjiCode()=%d\n",n);
814 sts = SetNkfOption(arg);
815 printf("SetNkfOption(%s)=%d\n",arg,sts);
816 memset(buff,0,sizeof buff);
817 sts = NkfConvertSafe(buff,sizeof buff,&len,buff2,strlen(buff2));
818 printf("NkfConvertSafe(%s)=%d len=%d '%s'\n",buff2,sts,len,buff);
819 dumpn(buff2,strlen(buff2));
821 n = NkfGetKanjiCode();
822 printf("NkfGetKanjiCode()=%d\n",n);
825 void guess(unsigned char *buff2)
829 sts = SetNkfOption(g);
830 printf("SetNkfOption(%s)=%d\n",g,sts);
831 memset(buff,0,sizeof buff);
832 NkfConvert(buff,buff2);
833 printf("NkfConvert(%s)=%s\n",buff2,buff);
834 dumpn(buff2,strlen(buff2));
835 n = NkfGetKanjiCode();
836 printf("NkfGetKanjiCode()=%d %s\n",n,code[n]);
837 memset(buff,0,sizeof buff);
838 sts = GetNkfGuessA(buff,sizeof buff,&len);
839 printf("GetNkfGuessA()=%d len=%d '%s'\n",sts,len,buff);
841 memset(buff,0,sizeof buff);
842 sts = GetNkfGuessW((LPWSTR)buff,sizeof buff / sizeof(WCHAR),&len);
843 printf("GetNkfGuessW()=%d len=%d\n",sts,len);
844 dumpn(buff,len * sizeof(WCHAR));
853 if ( fp == NULL ) return;
854 n = fread(buff,1,sizeof buff,fp);
856 printf("dumpf(%s,%d)\n",f,n);
860 void mkfile(char *f,char *p)
865 if ( fp == NULL ) return;
871 void file(char *arg2,char *arg3,unsigned char *buf)
873 sts = SetNkfOption(arg2);
874 printf("SetNkfOption(%s)=%d\n",arg2,sts);
876 NkfFileConvert1(arg3);
877 printf("NkfFileConvert1(%s)\n",arg3);
879 sts = SetNkfOption(arg2);
880 printf("SetNkfOption(%s)=%d\n",arg2,sts);
882 sts = NkfFileConvert1SafeA(arg3,strlen(arg3) + 1);
883 printf("NkfFileConvert1SafeA(%s)=%d\n",arg3,sts);
885 sts = SetNkfOption(arg2);
886 printf("SetNkfOption(%s)=%d\n",arg2,sts);
888 sts = MultiByteToWideChar(CP_OEMCP,MB_PRECOMPOSED,arg3,-1,(wchar_t *)buff,sizeof(buff) / sizeof(wchar_t));
889 printf("MultiByteToWideChar(%s)=%d\n",arg3,sts);
890 dumpn(buff,(wcslen((wchar_t *)buff) + 1) * sizeof(wchar_t));
891 sts = NkfFileConvert1SafeW((wchar_t *)buff,sizeof buff / sizeof(wchar_t) /*wcslen((wchar_t *)buff) + 1*/);
892 printf("NkfFileConvert1SafeW()=%d\n",sts);
896 void file2(char *arg2,char *arg3,char *arg4,unsigned char *buf)
898 sts = SetNkfOption(arg2);
899 printf("SetNkfOption(%s)=%d\n",arg2,sts);
901 NkfFileConvert2(arg3,arg4);
902 printf("NkfFileConvert1(%s,%s)\n",arg3,arg4);
905 sts = SetNkfOption(arg2);
906 printf("SetNkfOption(%s)=%d\n",arg2,sts);
908 sts = NkfFileConvert2SafeA(arg3,strlen(arg3) + 1,arg4,strlen(arg4) + 1);
909 printf("NkfFileConvert2SafeA(%s,%s)=%d\n",arg3,arg4,sts);
912 sts = SetNkfOption(arg2);
913 printf("SetNkfOption(%s)=%d\n",arg2,sts);
915 sts = MultiByteToWideChar(CP_OEMCP,MB_PRECOMPOSED,arg3,-1,(wchar_t *)buff,sizeof(buff) / sizeof(wchar_t));
916 printf("MultiByteToWideChar(%s)=%d\n",arg3,sts);
917 dumpn(buff,(wcslen((wchar_t *)buff) + 1) * sizeof(wchar_t));
918 sts = MultiByteToWideChar(CP_OEMCP,MB_PRECOMPOSED,arg4,-1,(wchar_t *)buff4,sizeof(buff4) / sizeof(wchar_t));
919 printf("MultiByteToWideChar(%s)=%d\n",arg4,sts);
920 dumpn(buff4,(wcslen((wchar_t *)buff4) + 1) * sizeof(wchar_t));
921 sts = NkfFileConvert2SafeW((wchar_t *)buff,sizeof buff / sizeof(wchar_t) ,(wchar_t *)buff4,sizeof buff4 / sizeof(wchar_t));
922 printf("NkfFileConvert2SafeW()=%d\n",sts);
927 int main(int argc,char **argv)
929 struct NKFSUPPORTFUNCTIONS fnc;
931 if ( argc < 2 ) return 0;
932 switch ( *argv[1] ) {
934 memset(buff,0,sizeof buff);
936 printf("GetNkfVersion() '%s'\n",buff);
937 sts = GetNkfVersionSafeA(buff,sizeof buff,&len);
938 printf("GetNkfVersionSafeA()=%d len=%d '%s'\n",sts,len,buff);
939 sts = GetNkfVersionSafeW((LPWSTR)buff,sizeof buff / sizeof(WCHAR),&len);
940 printf("GetNkfVersionSafeW()=%d len=%d\n",sts,len);
941 dumpn(buff,len * sizeof(WCHAR));
942 sts = GetNkfSupportFunctions(&fnc,sizeof fnc,&len);
943 printf("GetNkfSupportFunctions()=%d len=%d\n",sts,len);
944 printf("size=%d\n",fnc.size);
945 printf("copyrightA='%s'\n",fnc.copyrightA);
946 printf("versionA='%s'\n",fnc.versionA);
947 printf("dateA='%s'\n",fnc.dateA);
948 printf("functions=%d %x\n",fnc.functions,fnc.functions);
951 if ( argc < 3 ) return 0;
955 if ( argc < 2 ) return 0;
960 if ( argc < 4 ) return 0;
961 convert(argv[2],argv[3]);
964 if ( argc < 3 ) return 0;
966 convert(argv[2],buff2);
969 if ( argc < 3 ) return 0;
973 if ( argc < 2 ) return 0;
978 if ( argc < 5 ) return 0;
979 file(argv[2],argv[3],argv[4]);
982 if ( argc < 4 ) return 0;
984 file(argv[2],argv[3],buff3);
987 if ( argc < 6 ) return 0;
988 file2(argv[2],argv[3],argv[4],argv[5]);
991 if ( argc < 5 ) return 0;
993 file2(argv[2],argv[3],argv[4],buff3);
996 sts = NkfUsage(buff,sizeof buff,&len);
997 printf("strlen(buff)=%d\n",strlen(buff));
998 printf("NkfUsage()=%d len=%d \n%s",sts,len,buff);
1004 #endif /* DLLDBG @@*/