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.2"
8 /* NKF_VERSION
\82Ì
\83\8f\83C
\83h
\95¶
\8e\9a */
9 #define DLL_VERSION "2.1.2.0 2"
11 #define DLL_VERSIONW L"2.1.2.0 2"
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];
462 len = GetTempPath(sizeof d,d);
463 tempdname = malloc(len + 1);
464 if ( tempdname == NULL ) return;
465 len = GetTempPath(len + 1,tempdname);
466 sts = GetTempFileName(tempdname,"NKF",0,tempfname);
468 sts = CopyFileA(fName,tempfname,FALSE);
470 if ((fin = fopen(tempfname, "rb")) != NULL) {
471 if ((fout = fopen(fName, "wb")) != NULL) {
485 DeleteFile(tempfname);
490 #endif /*FILECONVERT1*/
492 BOOL WINAPI NkfFileConvert1SafeA(LPCSTR fName,DWORD nBufferLength /*in TCHARs*/)
496 char tempfname[MAX_PATH];
507 if ( nBufferLength == 0 ) return ret;
508 if ( *p == 0 ) break;
512 if ( chmod(fName,_S_IREAD | _S_IWRITE) == -1 ) return ret;
513 len = GetTempPath(sizeof d,d);
514 tempdname = malloc(len + 1);
515 if ( tempdname == NULL ) return FALSE;
516 len = GetTempPath(len + 1,tempdname);
517 sts = GetTempFileName(tempdname,"NKF",0,tempfname);
519 sts = CopyFileA(fName,tempfname,FALSE);
521 if ((fin = fopen(tempfname, "rb")) != NULL) {
522 if ((fout = fopen(fName, "wb")) != NULL) {
537 DeleteFileA(tempfname);
544 BOOL WINAPI NkfFileConvert1SafeW(LPCWSTR fName,DWORD nBufferLength /*in TCHARs*/)
546 #ifdef UNICODESUPPORT
549 wchar_t tempfname[MAX_PATH];
560 if ( nBufferLength == 0 ) return ret;
561 if ( *p == 0 ) break;
565 if ( _wchmod(fName,_S_IREAD | _S_IWRITE) == -1 ) return ret;
566 len = GetTempPathW(sizeof d / sizeof(WCHAR),d);
567 tempdname = malloc((len + 1) * sizeof(WCHAR));
568 if ( tempdname == NULL ) return FALSE;
569 len = GetTempPathW(len + 1,tempdname);
570 sts = GetTempFileNameW(tempdname,L"NKF",0,tempfname);
572 sts = CopyFileW(fName,tempfname,FALSE);
574 if ((fin = _wfopen(tempfname,L"rb")) != NULL) {
575 if ((fout = _wfopen(fName,L"wb")) != NULL) {
590 DeleteFileW(tempfname);
595 #else /*UNICODESUPPORT*/
597 #endif /*UNICODESUPPORT*/
601 void CALLBACK NkfFileConvert2(LPCSTR fInName,LPCSTR fOutName)
606 if ((fin = fopen(fInName, "rb")) == NULL) return;
607 if((fout=fopen(fOutName, "wb")) == NULL) {
623 #endif /*FILECONVERT2*/
625 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
679 if ( fInBufferLength == 0 ) return ret;
680 if ( *p == 0 ) break;
686 if ( fOutBufferLength == 0 ) return ret;
687 if ( *p == 0 ) break;
691 if ( (fin = _wfopen(fInName,L"rb")) != NULL) {
692 if( (fout = _wfopen(fOutName,L"wb")) != NULL) {
708 #else /*UNICODESUPPORT*/
710 #endif /*UNICODESUPPORT*/
713 BOOL WINAPI GetNkfGuessA(LPSTR outStr,DWORD nBufferLength /*in TCHARs*/,LPDWORD lpTCHARsReturned /*in TCHARs*/)
715 if ( outStr == NULL || nBufferLength == 0 ) return FALSE;
716 print_guessed_code(NULL);
717 *lpTCHARsReturned = strlen(guessbuffA) + 1;
718 return scp(outStr,guessbuffA,nBufferLength);
721 BOOL WINAPI GetNkfGuessW(LPWSTR outStr,DWORD nBufferLength /*in TCHARs*/,LPDWORD lpTCHARsReturned /*in TCHARs*/)
723 #ifdef UNICODESUPPORT
724 if ( outStr == NULL || nBufferLength == 0 ) return FALSE;
725 print_guessed_codeW(NULL);
726 *lpTCHARsReturned = wcslen(guessbuffW) + 1;
727 return wscp(outStr,guessbuffW,nBufferLength);
728 #else /*UNICODESUPPORT*/
730 #endif /*UNICODESUPPORT*/
739 } NkfSupportFunctions = {
740 sizeof(NkfSupportFunctions),
744 1 /* nkf32103a.lzh uminchu 1.03 */
745 /* | 2 */ /* nkf32dll.zip 0.91 */
746 #if defined(TOMIME) && defined(GETKANJICODE) && defined(FILECONVERT1) && defined(FILECONVERT2)
747 | 4 /* nkf32204.zip Kaneto 2.0.4.0 */
750 #ifdef UNICODESUPPORT
752 #endif /*UNICODESUPPORT*/
756 BOOL WINAPI GetNkfSupportFunctions(void *outStr,DWORD nBufferLength /*in Bytes*/,LPDWORD lpBytesReturned /*in Bytes*/)
758 *lpBytesReturned = sizeof NkfSupportFunctions;
759 if ( outStr == NULL || nBufferLength == 0 ) return FALSE;
760 NkfSupportFunctions.copyrightA = COPY_RIGHT;
761 memcpy(outStr,&NkfSupportFunctions,sizeof NkfSupportFunctions > nBufferLength ? nBufferLength : sizeof NkfSupportFunctions);
765 BOOL WINAPI NkfUsage(LPSTR outStr,DWORD nBufferLength /*in Bytes*/,LPDWORD lpBytesReturned /*in Bytes*/)
768 ulen = nBufferLength;
771 if ( uret == TRUE ) {
772 *lpBytesReturned = nBufferLength - ulen;
777 /* nkf32.dll main end */
779 #ifdef DLLDBG /* DLLDBG @@*/
781 unsigned char buff[65536];
782 unsigned char buff2[65536];
783 unsigned char buff3[65536];
784 unsigned char buff4[65536];
785 char *code[] = {"
\83V
\83t
\83gJIS","EUC","ISO-2022-JP","UTF-8","UTF-16LE","UTF-16BE"};
791 void mimeencode(unsigned char *buff2)
793 memset(buff,0,sizeof buff);
794 EncodeSubject(buff,buff2);
795 printf("EncodeSubject(%s)=%s\n",buff2,buff);
796 memset(buff,0,sizeof buff);
798 printf("ToMime(%s)=%s\n",buff2,buff);
799 memset(buff,0,sizeof buff);
800 sts = EncodeSubjectSafe(buff,sizeof buff,&len,buff2,strlen(buff2));
801 printf("EncodeSubjectSafe(%s)=%d len=%d '%s'\n",buff,sts,len,buff);
802 dumpn(buff2,strlen(buff2));
806 void convert(char *arg,unsigned char *buff2)
808 sts = SetNkfOption(arg);
809 printf("SetNkfOption(%s)=%d\n",arg,sts);
810 memset(buff,0,sizeof buff);
811 NkfConvert(buff,buff2);
812 printf("NkfConvert(%s)=%s\n",buff2,buff);
813 n = NkfGetKanjiCode();
814 printf("NkfGetKanjiCode()=%d\n",n);
815 sts = SetNkfOption(arg);
816 printf("SetNkfOption(%s)=%d\n",arg,sts);
817 memset(buff,0,sizeof buff);
818 sts = NkfConvertSafe(buff,sizeof buff,&len,buff2,strlen(buff2));
819 printf("NkfConvertSafe(%s)=%d len=%d '%s'\n",buff2,sts,len,buff);
820 dumpn(buff2,strlen(buff2));
822 n = NkfGetKanjiCode();
823 printf("NkfGetKanjiCode()=%d\n",n);
826 void guess(unsigned char *buff2)
830 sts = SetNkfOption(g);
831 printf("SetNkfOption(%s)=%d\n",g,sts);
832 memset(buff,0,sizeof buff);
833 NkfConvert(buff,buff2);
834 printf("NkfConvert(%s)=%s\n",buff2,buff);
835 dumpn(buff2,strlen(buff2));
836 n = NkfGetKanjiCode();
837 printf("NkfGetKanjiCode()=%d %s\n",n,code[n]);
838 memset(buff,0,sizeof buff);
839 sts = GetNkfGuessA(buff,sizeof buff,&len);
840 printf("GetNkfGuessA()=%d len=%d '%s'\n",sts,len,buff);
842 memset(buff,0,sizeof buff);
843 sts = GetNkfGuessW((LPWSTR)buff,sizeof buff / sizeof(WCHAR),&len);
844 printf("GetNkfGuessW()=%d len=%d\n",sts,len);
845 dumpn(buff,len * sizeof(WCHAR));
854 if ( fp == NULL ) return;
855 n = fread(buff,1,sizeof buff,fp);
857 printf("dumpf(%s,%d)\n",f,n);
861 void mkfile(char *f,char *p)
866 if ( fp == NULL ) return;
872 void file(char *arg2,char *arg3,unsigned char *buf)
874 sts = SetNkfOption(arg2);
875 printf("SetNkfOption(%s)=%d\n",arg2,sts);
877 NkfFileConvert1(arg3);
878 printf("NkfFileConvert1(%s)\n",arg3);
880 sts = SetNkfOption(arg2);
881 printf("SetNkfOption(%s)=%d\n",arg2,sts);
883 sts = NkfFileConvert1SafeA(arg3,strlen(arg3) + 1);
884 printf("NkfFileConvert1SafeA(%s)=%d\n",arg3,sts);
886 sts = SetNkfOption(arg2);
887 printf("SetNkfOption(%s)=%d\n",arg2,sts);
889 sts = MultiByteToWideChar(CP_OEMCP,MB_PRECOMPOSED,arg3,-1,(wchar_t *)buff,sizeof(buff) / sizeof(wchar_t));
890 printf("MultiByteToWideChar(%s)=%d\n",arg3,sts);
891 dumpn(buff,(wcslen((wchar_t *)buff) + 1) * sizeof(wchar_t));
892 sts = NkfFileConvert1SafeW((wchar_t *)buff,sizeof buff / sizeof(wchar_t) /*wcslen((wchar_t *)buff) + 1*/);
893 printf("NkfFileConvert1SafeW()=%d\n",sts);
897 void file2(char *arg2,char *arg3,char *arg4,unsigned char *buf)
899 sts = SetNkfOption(arg2);
900 printf("SetNkfOption(%s)=%d\n",arg2,sts);
902 NkfFileConvert2(arg3,arg4);
903 printf("NkfFileConvert1(%s,%s)\n",arg3,arg4);
906 sts = SetNkfOption(arg2);
907 printf("SetNkfOption(%s)=%d\n",arg2,sts);
909 sts = NkfFileConvert2SafeA(arg3,strlen(arg3) + 1,arg4,strlen(arg4) + 1);
910 printf("NkfFileConvert2SafeA(%s,%s)=%d\n",arg3,arg4,sts);
913 sts = SetNkfOption(arg2);
914 printf("SetNkfOption(%s)=%d\n",arg2,sts);
916 sts = MultiByteToWideChar(CP_OEMCP,MB_PRECOMPOSED,arg3,-1,(wchar_t *)buff,sizeof(buff) / sizeof(wchar_t));
917 printf("MultiByteToWideChar(%s)=%d\n",arg3,sts);
918 dumpn(buff,(wcslen((wchar_t *)buff) + 1) * sizeof(wchar_t));
919 sts = MultiByteToWideChar(CP_OEMCP,MB_PRECOMPOSED,arg4,-1,(wchar_t *)buff4,sizeof(buff4) / sizeof(wchar_t));
920 printf("MultiByteToWideChar(%s)=%d\n",arg4,sts);
921 dumpn(buff4,(wcslen((wchar_t *)buff4) + 1) * sizeof(wchar_t));
922 sts = NkfFileConvert2SafeW((wchar_t *)buff,sizeof buff / sizeof(wchar_t) ,(wchar_t *)buff4,sizeof buff4 / sizeof(wchar_t));
923 printf("NkfFileConvert2SafeW()=%d\n",sts);
928 int main(int argc,char **argv)
930 struct NKFSUPPORTFUNCTIONS fnc;
932 if ( argc < 2 ) return 0;
933 switch ( *argv[1] ) {
935 memset(buff,0,sizeof buff);
937 printf("GetNkfVersion() '%s'\n",buff);
938 sts = GetNkfVersionSafeA(buff,sizeof buff,&len);
939 printf("GetNkfVersionSafeA()=%d len=%d '%s'\n",sts,len,buff);
940 sts = GetNkfVersionSafeW((LPWSTR)buff,sizeof buff / sizeof(WCHAR),&len);
941 printf("GetNkfVersionSafeW()=%d len=%d\n",sts,len);
942 dumpn(buff,len * sizeof(WCHAR));
943 sts = GetNkfSupportFunctions(&fnc,sizeof fnc,&len);
944 printf("GetNkfSupportFunctions()=%d len=%d\n",sts,len);
945 printf("size=%d\n",fnc.size);
946 printf("copyrightA='%s'\n",fnc.copyrightA);
947 printf("versionA='%s'\n",fnc.versionA);
948 printf("dateA='%s'\n",fnc.dateA);
949 printf("functions=%d %x\n",fnc.functions,fnc.functions);
952 if ( argc < 3 ) return 0;
956 if ( argc < 2 ) return 0;
961 if ( argc < 4 ) return 0;
962 convert(argv[2],argv[3]);
965 if ( argc < 3 ) return 0;
967 convert(argv[2],buff2);
970 if ( argc < 3 ) return 0;
974 if ( argc < 2 ) return 0;
979 if ( argc < 5 ) return 0;
980 file(argv[2],argv[3],argv[4]);
983 if ( argc < 4 ) return 0;
985 file(argv[2],argv[3],buff3);
988 if ( argc < 6 ) return 0;
989 file2(argv[2],argv[3],argv[4],argv[5]);
992 if ( argc < 5 ) return 0;
994 file2(argv[2],argv[3],argv[4],buff3);
997 sts = NkfUsage(buff,sizeof buff,&len);
998 printf("strlen(buff)=%d\n",strlen(buff));
999 printf("NkfUsage()=%d len=%d \n%s",sts,len,buff);
1005 #endif /* DLLDBG @@*/