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.8"
8 /* NKF_VERSION
\82Ì
\83\8f\83C
\83h
\95¶
\8e\9a */
9 #define DLL_VERSION "2.0.8.0 1"
11 #define DLL_VERSIONW L"2.0.8.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(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;
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 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 int CALLBACK SetNkfOption(LPSTR optStr)
327 if ( *optStr == '-' ) {
331 p = malloc(strlen(optStr) + 2);
332 if ( p == NULL ) return -1;
334 strcpy(p + 1,optStr);
342 void CALLBACK NkfConvert(LPSTR outStr, LPCSTR inStr)
356 BOOL WINAPI NkfConvertSafe(LPSTR outStr,DWORD nOutBufferLength /*in Bytes*/,LPDWORD lpBytesReturned /*in Bytes*/, LPCSTR inStr,DWORD nInBufferLength /*in Bytes*/){
357 if ( inStr == NULL ) return FALSE;
360 noutmax = nOutBufferLength;
364 ninmax = nInBufferLength;
367 *lpBytesReturned = nout;
368 if ( nout < noutmax ) *cout = 0;
372 void CALLBACK ToHankaku(LPSTR inStr)
377 len = strlen(inStr) + 1;
379 if ( p == NULL ) return;
387 BOOL WINAPI ToHankakuSafe(LPSTR outStr,DWORD nOutBufferLength /*in Bytes*/,LPDWORD lpBytesReturned /*in Bytes*/,LPCSTR inStr,DWORD nInBufferLength /*in Bytes*/)
391 return NkfConvertSafe(outStr,nOutBufferLength,lpBytesReturned,inStr,nInBufferLength);
394 void CALLBACK ToZenkakuKana(LPSTR outStr, LPCSTR inStr)
398 NkfConvert(outStr, inStr);
401 BOOL WINAPI ToZenkakuKanaSafe(LPSTR outStr,DWORD nOutBufferLength /*in Bytes*/,LPDWORD lpBytesReturned /*in Bytes*/,LPCSTR inStr,DWORD nInBufferLength /*in Bytes*/)
405 return NkfConvertSafe(outStr,nOutBufferLength,lpBytesReturned,inStr,nInBufferLength);
408 void CALLBACK EncodeSubject(LPSTR outStr ,LPCSTR inStr){
411 NkfConvert(outStr, inStr);
414 BOOL WINAPI EncodeSubjectSafe(LPSTR outStr,DWORD nOutBufferLength /*in Bytes*/,LPDWORD lpBytesReturned /*in Bytes*/,LPCSTR inStr,DWORD nInBufferLength /*in Bytes*/)
418 return NkfConvertSafe(outStr,nOutBufferLength,lpBytesReturned,inStr,nInBufferLength);
422 void CALLBACK ToMime(LPSTR outStr ,LPCSTR inStr)
424 EncodeSubject(outStr,inStr);
429 int CALLBACK NkfGetKanjiCode(VOID)
432 /* if(iconv == s_iconv)iCode=0; */ /* 0:
\83V
\83t
\83gJIS */
433 if(iconv == w_iconv)iCode=3; /* UTF-8 */
434 else if(iconv == w_iconv16){
435 if(input_endian == ENDIAN_BIG)iCode=5; /* 5:UTF-16BE */
436 else iCode=4; /* 4:UTF-16LE */
437 }else if(iconv == e_iconv){
438 if(estab_f == FALSE)iCode=2; /* 2:ISO-2022-JP */
439 else iCode=1; /* 1:EUC */
443 #endif /*GETKANJICODE*/
446 void CALLBACK NkfFileConvert1(LPCSTR fName)
450 char tempfname[MAX_PATH];
455 len = GetTempPath(sizeof d,d);
456 tempdname = malloc(len + 1);
457 if ( tempdname == NULL ) return;
458 len = GetTempPath(len + 1,tempdname);
459 sts = GetTempFileName(tempdname,"NKF",0,tempfname);
461 sts = CopyFileA(fName,tempfname,FALSE);
463 if ((fin = fopen(tempfname, "rb")) != NULL) {
464 if ((fout = fopen(fName, "wb")) != NULL) {
478 DeleteFile(tempfname);
483 #endif /*FILECONVERT1*/
485 BOOL WINAPI NkfFileConvert1SafeA(LPCSTR fName,DWORD nBufferLength /*in TCHARs*/)
489 char tempfname[MAX_PATH];
499 if ( nBufferLength == 0 ) return ret;
500 if ( *p == 0 ) break;
504 if ( chmod(fName,_S_IREAD | _S_IWRITE) == -1 ) return ret;
505 len = GetTempPath(sizeof d,d);
506 tempdname = malloc(len + 1);
507 if ( tempdname == NULL ) return FALSE;
508 len = GetTempPath(len + 1,tempdname);
509 sts = GetTempFileName(tempdname,"NKF",0,tempfname);
511 sts = CopyFileA(fName,tempfname,FALSE);
513 if ((fin = fopen(tempfname, "rb")) != NULL) {
514 if ((fout = fopen(fName, "wb")) != NULL) {
529 DeleteFileA(tempfname);
536 BOOL WINAPI NkfFileConvert1SafeW(LPCWSTR fName,DWORD nBufferLength /*in TCHARs*/)
538 #ifdef UNICODESUPPORT
541 wchar_t tempfname[MAX_PATH];
551 if ( nBufferLength == 0 ) return ret;
552 if ( *p == 0 ) break;
556 if ( _wchmod(fName,_S_IREAD | _S_IWRITE) == -1 ) return ret;
557 len = GetTempPathW(sizeof d / sizeof(WCHAR),d);
558 tempdname = malloc((len + 1) * sizeof(WCHAR));
559 if ( tempdname == NULL ) return FALSE;
560 len = GetTempPathW(len + 1,tempdname);
561 sts = GetTempFileNameW(tempdname,L"NKF",0,tempfname);
563 sts = CopyFileW(fName,tempfname,FALSE);
565 if ((fin = _wfopen(tempfname,L"rb")) != NULL) {
566 if ((fout = _wfopen(fName,L"wb")) != NULL) {
581 DeleteFileW(tempfname);
586 #else /*UNICODESUPPORT*/
588 #endif /*UNICODESUPPORT*/
592 void CALLBACK NkfFileConvert2(LPCSTR fInName,LPCSTR fOutName)
596 if ((fin = fopen(fInName, "rb")) == NULL) return;
597 if((fout=fopen(fOutName, "wb")) == NULL) {
613 #endif /*FILECONVERT2*/
615 BOOL WINAPI NkfFileConvert2SafeA(LPCSTR fInName,DWORD fInBufferLength /*in TCHARs*/,LPCSTR fOutName,DWORD fOutBufferLength /*in TCHARs*/)
625 if ( fInBufferLength == 0 ) return ret;
626 if ( *p == 0 ) break;
632 if ( fOutBufferLength == 0 ) return ret;
633 if ( *p == 0 ) break;
637 if ((fin = fopen(fInName, "rb")) != NULL) {
638 if((fout=fopen(fOutName, "wb")) != NULL) {
656 BOOL WINAPI NkfFileConvert2SafeW(LPCWSTR fInName,DWORD fInBufferLength /*in TCHARs*/,LPCWSTR fOutName,DWORD fOutBufferLength /*in TCHARs*/)
658 #ifdef UNICODESUPPORT
667 if ( fInBufferLength == 0 ) return ret;
668 if ( *p == 0 ) break;
674 if ( fOutBufferLength == 0 ) return ret;
675 if ( *p == 0 ) break;
679 if ( (fin = _wfopen(fInName,L"rb")) != NULL) {
680 if( (fout = _wfopen(fOutName,L"wb")) != NULL) {
696 #else /*UNICODESUPPORT*/
698 #endif /*UNICODESUPPORT*/
701 BOOL WINAPI GetNkfGuessA(LPSTR outStr,DWORD nBufferLength /*in TCHARs*/,LPDWORD lpTCHARsReturned /*in TCHARs*/)
703 if ( outStr == NULL || nBufferLength == 0 ) return FALSE;
704 print_guessed_code(NULL);
705 *lpTCHARsReturned = strlen(guessbuffA) + 1;
706 return scp(outStr,guessbuffA,nBufferLength);
709 BOOL WINAPI GetNkfGuessW(LPWSTR outStr,DWORD nBufferLength /*in TCHARs*/,LPDWORD lpTCHARsReturned /*in TCHARs*/)
711 #ifdef UNICODESUPPORT
712 if ( outStr == NULL || nBufferLength == 0 ) return FALSE;
713 print_guessed_codeW(NULL);
714 *lpTCHARsReturned = wcslen(guessbuffW) + 1;
715 return wscp(outStr,guessbuffW,nBufferLength);
716 #else /*UNICODESUPPORT*/
718 #endif /*UNICODESUPPORT*/
727 } NkfSupportFunctions = {
728 sizeof(NkfSupportFunctions),
732 1 /* nkf32103a.lzh uminchu 1.03 */
733 /* | 2 */ /* nkf32dll.zip 0.91 */
734 #if defined(TOMIME) && defined(GETKANJICODE) && defined(FILECONVERT1) && defined(FILECONVERT2)
735 | 4 /* nkf32204.zip Kaneto 2.0.4.0 */
738 #ifdef UNICODESUPPORT
740 #endif /*UNICODESUPPORT*/
744 BOOL WINAPI GetNkfSupportFunctions(void *outStr,DWORD nBufferLength /*in Bytes*/,LPDWORD lpBytesReturned /*in Bytes*/)
746 *lpBytesReturned = sizeof NkfSupportFunctions;
747 if ( outStr == NULL || nBufferLength == 0 ) return FALSE;
748 NkfSupportFunctions.copyrightA = COPY_RIGHT;
749 memcpy(outStr,&NkfSupportFunctions,sizeof NkfSupportFunctions > nBufferLength ? nBufferLength : sizeof NkfSupportFunctions);
753 BOOL WINAPI NkfUsage(LPSTR outStr,DWORD nBufferLength /*in Bytes*/,LPDWORD lpBytesReturned /*in Bytes*/)
756 ulen = nBufferLength;
759 if ( uret == TRUE ) {
760 *lpBytesReturned = nBufferLength - ulen;
765 /* nkf32.dll main end */
767 #ifdef DLLDBG /* DLLDBG @@*/
769 unsigned char buff[65536];
770 unsigned char buff2[65536];
771 unsigned char buff3[65536];
772 unsigned char buff4[65536];
773 char *code[] = {"
\83V
\83t
\83gJIS","EUC","ISO-2022-JP","UTF-8","UTF-16LE","UTF-16BE"};
779 void mimeencode(unsigned char *buff2)
781 memset(buff,0,sizeof buff);
782 EncodeSubject(buff,buff2);
783 printf("EncodeSubject(%s)=%s\n",buff2,buff);
784 memset(buff,0,sizeof buff);
786 printf("ToMime(%s)=%s\n",buff2,buff);
787 memset(buff,0,sizeof buff);
788 sts = EncodeSubjectSafe(buff,sizeof buff,&len,buff2,strlen(buff2));
789 printf("EncodeSubjectSafe(%s)=%d len=%d '%s'\n",buff,sts,len,buff);
790 dumpn(buff2,strlen(buff2));
794 void convert(char *arg,unsigned char *buff2)
796 sts = SetNkfOption(arg);
797 printf("SetNkfOption(%s)=%d\n",arg,sts);
798 memset(buff,0,sizeof buff);
799 NkfConvert(buff,buff2);
800 printf("NkfConvert(%s)=%s\n",buff2,buff);
801 n = NkfGetKanjiCode();
802 printf("NkfGetKanjiCode()=%d\n",n);
803 sts = SetNkfOption(arg);
804 printf("SetNkfOption(%s)=%d\n",arg,sts);
805 memset(buff,0,sizeof buff);
806 sts = NkfConvertSafe(buff,sizeof buff,&len,buff2,strlen(buff2));
807 printf("NkfConvertSafe(%s)=%d len=%d '%s'\n",buff2,sts,len,buff);
808 dumpn(buff2,strlen(buff2));
810 n = NkfGetKanjiCode();
811 printf("NkfGetKanjiCode()=%d\n",n);
814 void guess(unsigned char *buff2)
818 sts = SetNkfOption(g);
819 printf("SetNkfOption(%s)=%d\n",g,sts);
820 memset(buff,0,sizeof buff);
821 NkfConvert(buff,buff2);
822 printf("NkfConvert(%s)=%s\n",buff2,buff);
823 dumpn(buff2,strlen(buff2));
824 n = NkfGetKanjiCode();
825 printf("NkfGetKanjiCode()=%d %s\n",n,code[n]);
826 memset(buff,0,sizeof buff);
827 sts = GetNkfGuessA(buff,sizeof buff,&len);
828 printf("GetNkfGuessA()=%d len=%d '%s'\n",sts,len,buff);
830 memset(buff,0,sizeof buff);
831 sts = GetNkfGuessW((LPWSTR)buff,sizeof buff / sizeof(WCHAR),&len);
832 printf("GetNkfGuessW()=%d len=%d\n",sts,len);
833 dumpn(buff,len * sizeof(WCHAR));
842 if ( fp == NULL ) return;
843 n = fread(buff,1,sizeof buff,fp);
845 printf("dumpf(%s,%d)\n",f,n);
849 void mkfile(char *f,char *p)
854 if ( fp == NULL ) return;
860 void file(char *arg2,char *arg3,unsigned char *buf)
862 sts = SetNkfOption(arg2);
863 printf("SetNkfOption(%s)=%d\n",arg2,sts);
865 NkfFileConvert1(arg3);
866 printf("NkfFileConvert1(%s)\n",arg3);
868 sts = SetNkfOption(arg2);
869 printf("SetNkfOption(%s)=%d\n",arg2,sts);
871 sts = NkfFileConvert1SafeA(arg3,strlen(arg3) + 1);
872 printf("NkfFileConvert1SafeA(%s)=%d\n",arg3,sts);
874 sts = SetNkfOption(arg2);
875 printf("SetNkfOption(%s)=%d\n",arg2,sts);
877 sts = MultiByteToWideChar(CP_OEMCP,MB_PRECOMPOSED,arg3,-1,(wchar_t *)buff,sizeof(buff) / sizeof(wchar_t));
878 printf("MultiByteToWideChar(%s)=%d\n",arg3,sts);
879 dumpn(buff,(wcslen((wchar_t *)buff) + 1) * sizeof(wchar_t));
880 sts = NkfFileConvert1SafeW((wchar_t *)buff,sizeof buff / sizeof(wchar_t) /*wcslen((wchar_t *)buff) + 1*/);
881 printf("NkfFileConvert1SafeW()=%d\n",sts);
885 void file2(char *arg2,char *arg3,char *arg4,unsigned char *buf)
887 sts = SetNkfOption(arg2);
888 printf("SetNkfOption(%s)=%d\n",arg2,sts);
890 NkfFileConvert2(arg3,arg4);
891 printf("NkfFileConvert1(%s,%s)\n",arg3,arg4);
894 sts = SetNkfOption(arg2);
895 printf("SetNkfOption(%s)=%d\n",arg2,sts);
897 sts = NkfFileConvert2SafeA(arg3,strlen(arg3) + 1,arg4,strlen(arg4) + 1);
898 printf("NkfFileConvert2SafeA(%s,%s)=%d\n",arg3,arg4,sts);
901 sts = SetNkfOption(arg2);
902 printf("SetNkfOption(%s)=%d\n",arg2,sts);
904 sts = MultiByteToWideChar(CP_OEMCP,MB_PRECOMPOSED,arg3,-1,(wchar_t *)buff,sizeof(buff) / sizeof(wchar_t));
905 printf("MultiByteToWideChar(%s)=%d\n",arg3,sts);
906 dumpn(buff,(wcslen((wchar_t *)buff) + 1) * sizeof(wchar_t));
907 sts = MultiByteToWideChar(CP_OEMCP,MB_PRECOMPOSED,arg4,-1,(wchar_t *)buff4,sizeof(buff4) / sizeof(wchar_t));
908 printf("MultiByteToWideChar(%s)=%d\n",arg4,sts);
909 dumpn(buff4,(wcslen((wchar_t *)buff4) + 1) * sizeof(wchar_t));
910 sts = NkfFileConvert2SafeW((wchar_t *)buff,sizeof buff / sizeof(wchar_t) ,(wchar_t *)buff4,sizeof buff4 / sizeof(wchar_t));
911 printf("NkfFileConvert2SafeW()=%d\n",sts);
916 int main(int argc,char **argv)
918 struct NKFSUPPORTFUNCTIONS fnc;
920 if ( argc < 2 ) return 0;
921 switch ( *argv[1] ) {
923 memset(buff,0,sizeof buff);
925 printf("GetNkfVersion() '%s'\n",buff);
926 sts = GetNkfVersionSafeA(buff,sizeof buff,&len);
927 printf("GetNkfVersionSafeA()=%d len=%d '%s'\n",sts,len,buff);
928 sts = GetNkfVersionSafeW((LPWSTR)buff,sizeof buff / sizeof(WCHAR),&len);
929 printf("GetNkfVersionSafeW()=%d len=%d\n",sts,len);
930 dumpn(buff,len * sizeof(WCHAR));
931 sts = GetNkfSupportFunctions(&fnc,sizeof fnc,&len);
932 printf("GetNkfSupportFunctions()=%d len=%d\n",sts,len);
933 printf("size=%d\n",fnc.size);
934 printf("copyrightA='%s'\n",fnc.copyrightA);
935 printf("versionA='%s'\n",fnc.versionA);
936 printf("dateA='%s'\n",fnc.dateA);
937 printf("functions=%d %x\n",fnc.functions,fnc.functions);
940 if ( argc < 3 ) return 0;
944 if ( argc < 2 ) return 0;
949 if ( argc < 4 ) return 0;
950 convert(argv[2],argv[3]);
953 if ( argc < 3 ) return 0;
955 convert(argv[2],buff2);
958 if ( argc < 3 ) return 0;
962 if ( argc < 2 ) return 0;
967 if ( argc < 5 ) return 0;
968 file(argv[2],argv[3],argv[4]);
971 if ( argc < 4 ) return 0;
973 file(argv[2],argv[3],buff3);
976 if ( argc < 6 ) return 0;
977 file2(argv[2],argv[3],argv[4],argv[5]);
980 if ( argc < 5 ) return 0;
982 file2(argv[2],argv[3],argv[4],buff3);
985 sts = NkfUsage(buff,sizeof buff,&len);
986 printf("strlen(buff)=%d\n",strlen(buff));
987 printf("NkfUsage()=%d len=%d \n%s",sts,len,buff);
993 #endif /* DLLDBG @@*/