/************************************************* * conv.c * * * * Copyright (C) 1995-1999 Microsoft Inc. * * * *************************************************/ #include "conv.h" DWORD dwBaseWordNum; HGLOBAL hCreateWord; HGLOBAL hWordIndex; HGLOBAL hEncode; #ifdef UNICODE TCHAR Title[] = {0x6D4F, 0x89C8, 0x0000}; TCHAR szVer[] = {0x8F93, 0x5165, 0x6CD5, 0x0020, 0x7248, 0x672C, 0x0000}; #else BYTE Title[] = "浏览"; BYTE szVer[] = "输入法 版本"; #endif /***************************************************************************** FUNCTION: ConvConv(HANDLE hWnd,LPCSTR lpSrcFileName, LPCSTR lpszMBFileName) PURPOSE: Processes MB conversion . PARAMETERS: hWnd - window handle of the parent window. lpSrcFileName - pointer to source text file name. lpszMBFileName - pointer to destinate .mb file name. RETURN VALUE: TRUE - conversion completed FALSE - conversion not completed HISTORY: ****************************************************************************/ BOOL ConvConv(HANDLE hWnd,LPCTSTR lpSrcFileName, LPCTSTR lpszMBFileName) { int nTemp; DWORD dwDBCS; DWORD dwRuleOffset, dwRuleLen; DWORD dwDesOffset, dwDesLen; DWORD i; int nPages; TCHAR szDBCS[512]; //dwRuleOffset: Rule segment's offset in source file MAINID MainID; LPMAININDEX lpMainIndex; LPCREATEWORD lpCreateWords; DESCRIPTION Descript; LPWORDINDEX lpWordIndex; LPRULE lpRule; HANDLE hReConvIndex, hMainIndex; LPRECONVINDEX lpReConvIndex; LPENCODEAREA lpEncode; DispInfo(hWnd,IDS_CONVERTINFO); nTemp = (int)ConvGetDescript(hWnd,lpSrcFileName,&dwDesOffset, &dwDesLen,&Descript,FALSE); if(nTemp == -ERR_FILENOTOPEN || nTemp < -4 ) return FALSE; hMainIndex = GlobalAlloc(GMEM_MOVEABLE|GMEM_ZEROINIT,sizeof(MAININDEX)*NUMTABLES); if(!(lpMainIndex = GlobalLock(hMainIndex) ) ) { ProcessError(ERR_GLOBALLOCK,hWnd,ERR); return FALSE; } ConvInit(&Descript,&MainID,lpMainIndex); nPages = 1; dwBaseWordNum = 0; nTemp = sizeof(WORDINDEX)*GMEM_PAGESIZE; hWordIndex=GlobalAlloc(GMEM_MOVEABLE|GMEM_ZEROINIT, nTemp); hCreateWord = GlobalAlloc(GMEM_MOVEABLE|GMEM_ZEROINIT, (DWORD)Descript.wMaxCodes*NUM_OF_ENCODE*sizeof(TCHAR)); if(!hMainIndex||!hCreateWord || !hWordIndex || !hRule) { ProcessError(ERR_OUTOFMEMORY,hWnd,ERR); goto err; } if(!(lpCreateWords = GlobalLock(hCreateWord) ) ||!(lpWordIndex = (LPWORDINDEX) GlobalLock(hWordIndex)) ||!(lpRule = GlobalLock(hRule)) ) { ProcessError(ERR_GLOBALLOCK,hWnd,ERR); goto err; } if(ConvGetRule(hWnd,lpSrcFileName,&dwRuleOffset,&dwRuleLen, lpRule,&Descript)<=0) goto err; hSRCFile = Create_File(hWnd,lpSrcFileName,GENERIC_READ,OPEN_EXISTING); if (hSRCFile == (HANDLE)-1) return FALSE; hMBFile = Create_File(hWnd,lpszMBFileName,GENERIC_READ|GENERIC_WRITE, CREATE_ALWAYS); if (hMBFile == (HANDLE)-1) { CloseHandle(hSRCFile); return FALSE; } if(!ConvWriteMainID(hMBFile,&MainID)) { ProcessError(ERR_WRITEID,hWnd,ERR); goto err; } if(!ConvWriteMainIndex(hMBFile,lpMainIndex)) { ProcessError(ERR_WRITEMAININDEX,hWnd,ERR); goto err; } if(!ConvWriteDescript(hMBFile, &Descript, lpMainIndex)) { ProcessError(ERR_WRITEDESCRIPT,hWnd,ERR); goto err; } if(lpMainIndex[TAG_RULE-1].dwLength != 0) if(!ConvWriteRule( hMBFile,Descript.wNumRules,lpRule, lpMainIndex)) { ProcessError(ERR_WRITERULE,hWnd,ERR); goto err; } hReConvIndex = GlobalAlloc(GMEM_MOVEABLE|GMEM_ZEROINIT, (DWORD)Descript.wMaxCodes*NUM_OF_ENCODE*sizeof(TCHAR)); if(!hReConvIndex) { ProcessError(ERR_OUTOFMEMORY,hWnd,ERR); goto err; } if(!(lpReConvIndex = GlobalLock(hReConvIndex)) || !(lpEncode = GlobalLock(hEncode)) ) { ProcessError(ERR_GLOBALLOCK,hWnd,ERR); goto err; } DispInfo(hWnd,IDS_READTEXTINFO); if(!ReadSRCFile(hWnd,&nPages,hSRCFile,lpCreateWords, lpWordIndex,&dwDBCS,&Descript,lpReConvIndex)) { goto err; } DispInfo(hWnd,IDS_WRCRTINFO); //****** fill code mapping ***** ConvWriteEncode(hMBFile,lpEncode,lpMainIndex); if(Descript.wNumRules != 0) { LoadString(NULL,IDS_ISCHECKCRTWORD,szDBCS, sizeof(szDBCS)/sizeof(TCHAR)); if(ErrMessage(hWnd, szDBCS)) { if(!CheckCrtData(hWnd,lpCreateWords,lpEncode,Descript.wMaxCodes) ) { ProcessError(ERR_GB2312NOTENTIRE,hWnd,ERR); goto err; } } } //******* Debug ******* if(lpMainIndex[TAG_CRTWORDCODE-1].dwLength != 0) ConvWriteCrtData(hMBFile,lpCreateWords,lpMainIndex); if(lpMainIndex[TAG_RECONVINDEX-1].dwLength != 0) ConvWriteReConvIdx(hMBFile,lpReConvIndex,lpMainIndex); GlobalUnlock(hEncode); //****95.10.12 auto add code for phrases not exist code SetCursor (LoadCursor (NULL, IDC_WAIT)); if( Descript.wNumRules != 0) { for(i=0; i 1 && (lstrlen(lpWordIndex[i].szCode) == 0) ) { SetFilePointer(hSRCFile,lpWordIndex[i].dwOffset,0,FILE_BEGIN); nTemp = 2*(DWORD)lpWordIndex[i].wDBCSLen; if (!ReadFile(hSRCFile,szDBCS,nTemp,&dwDBCS,NULL)) goto err; szDBCS[nTemp] = 0; ConvBatCreate(hWnd,Descript,lpRule, lpCreateWords,szDBCS, lpWordIndex[i].szCode); if(lpWordIndex[i].szCode[0] == TEXT(',') && lpWordIndex[i].szCode[1] == TEXT('z')) continue; if(lstrlen(lpWordIndex[i].szCode) == 0) { goto err; } } } } SetCursor (LoadCursor (NULL, IDC_ARROW)); DispInfo(hWnd,IDS_SORT); ConvSort(hWnd,lpWordIndex,dwBaseWordNum); SetFilePointer(hMBFile,lpMainIndex[TAG_BASEDICINDEX-1].dwOffset,0,FILE_BEGIN); //***** fill index area with null ***** nTemp = Descript.wNumCodes; nTemp = sizeof(DWORD)*(nTemp+1)*nTemp; WriteFile(hMBFile,NULL,nTemp,&nTemp,NULL); //***** fill index area and length area ***** ConvCalc(hWnd,hMBFile,lpWordIndex,lpMainIndex,&Descript); //***** fill dictionary area ***** WriteMBFile(hWnd,hSRCFile,hMBFile,lpWordIndex,lpMainIndex,&Descript); MainID.dwNumWords = dwBaseWordNum; //***** fill changed MainID ***** ConvWriteMainID(hMBFile,&MainID); GlobalUnlock(hRule); if(hCreateWord) GlobalFree(hCreateWord); GlobalUnlock(hReConvIndex); GlobalFree(hReConvIndex); GlobalUnlock(hWordIndex); GlobalFree(hWordIndex); CloseHandle(hMBFile); CloseHandle(hSRCFile); ProcessError(ERR_CONVEND, hWnd, INFO); return TRUE; err: if(hSRCFile) CloseHandle(hSRCFile); if(hMBFile) CloseHandle(hMBFile); if(hMainIndex) GlobalFree(hMainIndex); if(hWordIndex) GlobalFree(hWordIndex); if(hCreateWord) GlobalFree(hCreateWord); if(hReConvIndex) GlobalFree(hReConvIndex); if(hRule) GlobalUnlock(hRule); return FALSE; } /***************************************************************************** FUNCTION: ConvReadFile(HANDLE hWnd,LPCSTR lpSrcFileName, LPCSTR lpDestFile) PURPOSE: Processes source text file sorting. PARAMETERS: hWnd - window handle of the parent window. lpSrcFileName - pointer to source text file name. lpDestFile - pointer to destinate sorted text file name. RETURN VALUE: TRUE - sorting completed FALSE - sorting not completed HISTORY: ****************************************************************************/ BOOL ConvReadFile(HANDLE hWnd, LPCTSTR lpSrcFileName, LPCTSTR lpDestFile) { DWORD i,j; DWORD dwRuleOffset, dwRuleLen; DWORD dwDesOffset, dwDesLen; DWORD dwReadBytes; DWORD dwFstOffset=0; DWORD dwOffset=0; TCHAR szStr[512],szDBCS[512]; TCHAR *Buffer; BOOL bReadText = FALSE, bSameFile=FALSE; int nRet; int nPages; BOOL IsGenCmb = FALSE; HANDLE hRule0=NULL; LPCREATEWORD lpCreateWords; LPWORDINDEX lpWordIndex; LPRULE lpRule; DESCRIPTION Descript; HANDLE hDlgItem; Buffer = (TCHAR *)LocalAlloc(LMEM_FIXED, MAXREADBUFFER * sizeof(TCHAR)); if (!Buffer) return (-ERR_OUTOFMEMORY); nRet = (int)ConvGetDescript(hWnd,lpSrcFileName,&dwDesOffset, &dwDesLen,&Descript,FALSE); if(nRet == -ERR_FILENOTOPEN) { LocalFree(Buffer); return FALSE; } if((-nRet)&7) bReadText = TRUE; if(Descript.wMaxCodes <= 0) Descript.wMaxCodes = MAXCODELEN; nPages = 1; dwBaseWordNum = 0; dwReadBytes = sizeof(WORDINDEX)*GMEM_PAGESIZE; hCreateWord = GlobalAlloc(GMEM_MOVEABLE|GMEM_ZEROINIT, MAXCODELEN*NUM_OF_ENCODE*sizeof(TCHAR)); hWordIndex=GlobalAlloc(GMEM_MOVEABLE|GMEM_ZEROINIT, dwReadBytes); if(!hWordIndex ) { ProcessError(ERR_OUTOFMEMORY,hWnd,ERR); goto err; } if(!hCreateWord ) { ProcessError(ERR_OUTOFMEMORY,hWnd,ERR); goto err; } if(!(lpCreateWords = GlobalLock(hCreateWord) ) ||!(lpWordIndex = (LPWORDINDEX) GlobalLock(hWordIndex)) ) { ProcessError(ERR_GLOBALLOCK,hWnd,ERR); goto err; } hRule0= GlobalAlloc(GMEM_MOVEABLE|GMEM_ZEROINIT, sizeof(RULE)*MAXCODELEN); if(!(lpRule = GlobalLock(hRule0)) ) { ProcessError(ERR_GLOBALLOCK,hWnd,ERR); goto err; } if(ConvGetRule(hWnd,lpSrcFileName,&dwRuleOffset,&dwRuleLen, lpRule,&Descript) == -ERR_FILENOTOPEN) goto err; hSRCFile = Create_File(hWnd,lpSrcFileName,GENERIC_READ,OPEN_EXISTING); if (hSRCFile == (HANDLE)-1) goto err; if(lstrcmpi(lpDestFile,lpSrcFileName)==0) { bSameFile = TRUE; LoadString(NULL,IDS_OVERWRITE,szStr, sizeof(szStr)/sizeof(TCHAR)); StringCchPrintf(szDBCS, ARRAYSIZE(szDBCS), TEXT("\'%s\'\n%s"),lpSrcFileName,szStr); if(!ErrMessage(hWnd, szDBCS)) { CloseHandle(hSRCFile); goto err; } #ifdef UNICODE if(!_waccess(TEXT(TempFile),0)) #else if(!_access(TEXT(TempFile),0)) #endif DeleteFile(TEXT(TempFile)); hMBFile = Create_File(hWnd,TEXT(TempFile),GENERIC_WRITE|GENERIC_READ,CREATE_ALWAYS); } else hMBFile = Create_File(hWnd,lpDestFile,GENERIC_WRITE|GENERIC_READ,CREATE_ALWAYS); if(hMBFile==(HANDLE)-1) { CloseHandle(hSRCFile); goto err; } CloseHandle(hMBFile); DispInfo(hWnd,IDS_READTEXTINFO); SetFilePointer(hSRCFile,0,0,FILE_BEGIN); szStr[0] = 0; j = 0; SetCursor (LoadCursor (NULL, IDC_WAIT)); SetDlgItemText (hWnd,TM_TOTALINFO,TEXT("")); LoadString(NULL,IDS_SORTWORDS,szStr,sizeof(szStr)/sizeof(TCHAR)); SetDlgItemText (hWnd,TM_TOTAL,szStr); SetDlgItemInt (hWnd,TM_TOTALNUM,dwBaseWordNum,FALSE); hDlgItem=GetDlgItem(hWnd,TM_CONVNUM); InvalidateRect (hWnd,NULL,FALSE); while(ReadFile(hSRCFile,Buffer,MAXREADBUFFER,&dwReadBytes,NULL)) { dwReadBytes = dwReadBytes/sizeof(TCHAR); for(i=0;i<(int)dwReadBytes;i++) { if(Buffer[i] == 0x0d || Buffer[i] == 0xfeff) continue; if(Buffer[i] == TEXT('\n')) { szStr[j]=0; j=0; if(lstrcmpi(szStr,TEXT(TextSeg))==0) { bReadText = TRUE; continue; } if(lstrcmpi(szStr,TEXT(RuleSeg))==0 || lstrcmpi(szStr,TEXT(DescriptSeg))==0) { bReadText = FALSE; continue; } if(bReadText) { trim(szStr); if(lstrlen(szStr) != 0) { nRet = SimpleSplit(hWnd,&nPages,szStr,lpCreateWords,lpWordIndex,Descript.wMaxCodes); if(nRet == 1) { lpWordIndex[dwBaseWordNum-1].dwOffset = dwOffset; searchPos(lpWordIndex,dwBaseWordNum); if(dwBaseWordNum%100 == 0) { SetDlgItemInt (hWnd,TM_TOTALNUM,dwBaseWordNum,FALSE); InvalidateRect(hDlgItem,NULL,FALSE); } } } } else lstrcpy(szStr,TEXT("")); continue; } else { if(j == 0) dwOffset = dwFstOffset + i*sizeof(TCHAR); szStr[j]=Buffer[i]; j++; } } if(dwReadBytes*sizeof(TCHAR) < MAXREADBUFFER) break; dwFstOffset += MAXREADBUFFER; }; SetDlgItemInt (hWnd,TM_TOTALNUM,dwBaseWordNum,FALSE); InvalidateRect(hDlgItem,NULL,FALSE); if(bSameFile) { if(dwDesLen != 0) ConvSaveDescript(TEXT(TempFile),&Descript, 0,0); if(dwRuleLen != 0) ConvSaveRule(hWnd,TEXT(TempFile), dwDesLen, 0, lpRule, Descript.wNumRules); hMBFile= Create_File(hWnd,TEXT(TempFile),GENERIC_READ|GENERIC_WRITE,OPEN_EXISTING); } else { if(dwDesLen != 0) ConvSaveDescript(lpDestFile,&Descript, 0,0); if(dwRuleLen != 0) ConvSaveRule(hWnd,lpDestFile, dwDesLen, 0, lpRule, Descript.wNumRules); hMBFile= Create_File(hWnd,lpDestFile,GENERIC_READ|GENERIC_WRITE,OPEN_EXISTING); } SetCursor (LoadCursor (NULL, IDC_ARROW)); if (hMBFile == (HANDLE)-1) { CloseHandle(hSRCFile); goto err; } SetCursor (LoadCursor (NULL, IDC_WAIT)); DispInfo(hWnd,IDS_WRITETEXTINFO); { #ifdef UNICODE TCHAR cmbStr[] = {0x662F, 0x5426, 0x751F, 0x6210, 0x91CD, 0x7801, 0x8868, 0x0028, 0x0059, 0x002F, 0x004E, 0x0029, 0x003F, 0x0000}; #else BYTE cmbStr[] = "是否生成重码表(Y/N)?"; #endif //UNICODE TCHAR cmbExt[] = TEXT(".CMB"); LPTSTR lpString; TCHAR cmbFileName[MAX_PATH]; IsGenCmb = ErrMessage(hWnd, cmbStr); if(IsGenCmb) { StringCchCopy(cmbFileName, ARRAYSIZE(cmbFileName), lpSrcFileName); if( (lpString = _tcsrchr(cmbFileName, TEXT('.'))) != NULL) *lpString = 0; StringCchCat(cmbFileName, ARRAYSIZE(cmbFileName), cmbExt); hCmbFile= Create_File(hWnd, cmbFileName, GENERIC_READ|GENERIC_WRITE, CREATE_ALWAYS); if(hCmbFile == (HANDLE)-1) { CloseHandle(hSRCFile); CloseHandle(hMBFile); goto err; } } } SetCursor (LoadCursor (NULL, IDC_ARROW)); WriteSortFile(hWnd,hSRCFile,hMBFile,lpWordIndex,lpCreateWords); GlobalUnlock(hCreateWord); GlobalFree(hCreateWord); GlobalFree(hWordIndex); SetCursor (LoadCursor (NULL, IDC_ARROW)); if(hRule0) GlobalFree(hRule0); CloseHandle(hSRCFile); CloseHandle(hMBFile); if(hCmbFile > 0) CloseHandle(hCmbFile); if(bSameFile) { DeleteFile(lpSrcFileName); nRet = MoveFile(TEXT(TempFile),lpSrcFileName); } LoadString(NULL,IDS_SORTEND,szStr,ARRAYSIZE(szStr)); #ifdef UNICODE { TCHAR UniTmp[]={0x8BCD, 0x8BED, 0x6392, 0x5E8F, 0x0000}; MessageBox(hWnd,szStr,UniTmp,MB_OK); } #else MessageBox(hWnd,szStr,"词语排序",MB_OK); #endif LocalFree(Buffer); return TRUE; err: if(!_taccess(TEXT(TempFile),0)) DeleteFile(TEXT(TempFile)); if(hWordIndex) GlobalFree(hWordIndex); if(hCreateWord) GlobalFree(hCreateWord); if(hRule0) GlobalFree(hRule0); LocalFree(Buffer); return FALSE; } /***************************************************************************** FUNCTION: ConvReConv(HANDLE hWnd,LPCSTR lpSrcFileName, LPCSTR lpszMBFileName) PURPOSE: Processes MB reconversion . PARAMETERS: hWnd - window handle of the parent window. lpSrcFileName - pointer to source .mb file name. lpszMBFileName - pointer to destinate text file name. RETURN VALUE: TRUE - reconversion completed FALSE - reconversion not completed HISTORY: 05-21-95 Yehfew Tie modifyed. ****************************************************************************/ BOOL ConvReConv(HANDLE hWnd,LPCTSTR lpSrcFileName,LPCTSTR lpMBFileName) { DWORD dwDesOffset,dwDesLen; HANDLE hRule0; MAINID MainID; LPRULE lpRule; DESCRIPTION Descript; HANDLE hReConvIndex; LPCREATEWORD lpCreateWords, lpReConvIndex; MAININDEX MainIndex[NUMTABLES]; hMBFile = Create_File(hWnd,lpMBFileName,GENERIC_READ,OPEN_EXISTING); if (hMBFile == (HANDLE)-1) return FALSE; DispInfo(hWnd,IDS_RECONVINFO); ConvGetMainID(hMBFile,&MainID); if(!ConvGetMainIndex(hWnd,hMBFile,MainIndex)) { CloseHandle(hMBFile); return FALSE; } hSRCFile = Create_File(hWnd,lpSrcFileName, GENERIC_READ|GENERIC_WRITE,CREATE_ALWAYS); if (hSRCFile == (HANDLE)-1) return FALSE; CloseHandle(hSRCFile); ConvReadDescript(hMBFile,&Descript, MainIndex); ConvSaveDescript(lpSrcFileName,&Descript, 0,0); ConvGetDescript(hWnd,lpSrcFileName,&dwDesOffset, &dwDesLen,&Descript,FALSE); hCreateWord = GlobalAlloc(GMEM_MOVEABLE|GMEM_ZEROINIT, (DWORD)Descript.wMaxCodes*NUM_OF_ENCODE*sizeof(TCHAR)); if(!hCreateWord ) { ProcessError(ERR_OUTOFMEMORY,hWnd,ERR); return FALSE; } if(!(lpCreateWords = GlobalLock(hCreateWord)) ) { ProcessError(ERR_GLOBALLOCK,hWnd,ERR); return FALSE; } hReConvIndex = GlobalAlloc(GMEM_MOVEABLE|GMEM_ZEROINIT, (DWORD)Descript.wMaxCodes*NUM_OF_ENCODE*sizeof(TCHAR)); if(!hReConvIndex ) { ProcessError(ERR_OUTOFMEMORY,hWnd,ERR); CloseHandle(hMBFile); GlobalFree(hCreateWord); return FALSE; } if( !(lpReConvIndex = GlobalLock(hReConvIndex)) ) { ProcessError(ERR_GLOBALLOCK,hWnd,ERR); GlobalFree(hReConvIndex); CloseHandle(hMBFile); GlobalFree(hCreateWord); return FALSE; } if(Descript.wNumRules != 0) { hRule0 = GlobalAlloc(GMEM_MOVEABLE|GMEM_ZEROINIT, sizeof(RULE)*Descript.wNumRules); if(!hRule0) { ProcessError(ERR_OUTOFMEMORY,hWnd,ERR); GlobalFree(hReConvIndex); CloseHandle(hMBFile); GlobalFree(hCreateWord); return FALSE; } if(!(lpRule = GlobalLock(hRule0)) ) { ProcessError(ERR_GLOBALLOCK,hWnd,ERR); CloseHandle(hMBFile); GlobalFree(hCreateWord); GlobalFree(hRule0); GlobalFree(hReConvIndex); return FALSE; } ConvReadRule(hMBFile,Descript.wNumRules ,lpRule, MainIndex); ConvSaveRule(hWnd,lpSrcFileName, dwDesLen, 0, lpRule, Descript.wNumRules); } ConvGetCrtData(hMBFile, lpCreateWords, MainIndex); ConvGetReConvIndex(hMBFile, lpReConvIndex,MainIndex); hSRCFile = Create_File(hWnd,lpSrcFileName, GENERIC_READ|GENERIC_WRITE,OPEN_EXISTING); if (hSRCFile == (HANDLE)-1) return FALSE; ConvWriteBaseWord(hWnd,hSRCFile,hMBFile,MainID, MainIndex[TAG_BASEDIC-1].dwOffset, lpCreateWords, lpReConvIndex,Descript.wMaxCodes); // DispInfo(hWnd,IDS_RECONVEND); bug#57932 CloseHandle(hSRCFile); CloseHandle(hMBFile); GlobalFree(hCreateWord); GlobalFree(hReConvIndex); if(Descript.wNumRules != 0) GlobalFree(hRule0); ProcessError(ERR_RECONVEND, hWnd, INFO); return TRUE; } void ConvInit(LPDESCRIPTION lpDescript, LPMAINID lpMainID, LPMAININDEX lpMainIndex) { DWORD dwTotal; int i; //*** initializes struct MainID *** lstrcpy(lpMainID->szVersion,TEXT("95.01")); lpMainID->dwLanguageID = WIN95_PRC; #ifdef UNICODE lpMainID->dwEncodeID = UNICODE_IME; #else lpMainID->dwEncodeID = GBK_IME; #endif lpMainID->dwNumTables = NUMTABLES; lpMainID->dwNumWords = dwBaseWordNum; lpMainID->dwFileFlag = 0; if(lpDescript->byMaxElement > 1 ) lpMainID->dwFileFlag |= FFLG_MULTIELEMENT; if(lpDescript->wNumRules > 0) lpMainID->dwFileFlag |= FFLG_RULE; //*** set tables tag **** lpMainIndex[TAG_DESCRIPTION-1].dwTag = TAG_DESCRIPTION; lpMainIndex[TAG_RULE-1].dwTag = TAG_RULE; lpMainIndex[TAG_ENCODE-1].dwTag = TAG_ENCODE; lpMainIndex[TAG_CRTWORDCODE-1].dwTag = TAG_CRTWORDCODE; lpMainIndex[TAG_RECONVINDEX-1].dwTag = TAG_RECONVINDEX; lpMainIndex[TAG_BASEDICINDEX-1].dwTag = TAG_BASEDICINDEX; lpMainIndex[TAG_BASEDIC-1].dwTag = TAG_BASEDIC; //*** set tables length **** lpMainIndex[TAG_DESCRIPTION-1].dwLength = sizeof(DESCRIPTION); lpMainIndex[TAG_RULE-1].dwLength= sizeof(RULE)* lpDescript->wNumRules; lpMainIndex[TAG_ENCODE-1].dwLength = 2*sizeof(DWORD) + NUMENCODEAREA*sizeof(ENCODEAREA); lpMainIndex[TAG_CRTWORDCODE-1].dwLength = (DWORD)NUM_OF_ENCODE*(DWORD)lpDescript->wMaxCodes*sizeof(TCHAR); lpMainIndex[TAG_RECONVINDEX-1].dwLength = (DWORD)lpDescript->wMaxCodes*NUM_OF_ENCODE*sizeof(TCHAR); switch(lpMainID->dwFileFlag) { case FFLG_RULE|FFLG_SINGLEELEMENT: lpMainIndex[TAG_RECONVINDEX-1].dwLength = 0; break; case FFLG_RULE|FFLG_MULTIELEMENT: break; case FFLG_NORULE|FFLG_SINGLEELEMENT: case FFLG_NORULE|FFLG_MULTIELEMENT: lpMainIndex[TAG_RULE-1].dwLength = 0; lpMainIndex[TAG_CRTWORDCODE-1].dwLength = 0; break; default: break; } lpMainIndex[TAG_BASEDICINDEX-1].dwLength =( (DWORD)lpDescript->wNumCodes+1)* (DWORD)lpDescript->wNumCodes*sizeof(DWORD)*2+MAXNUMCODES+CODEMAPOFFSET; lpMainIndex[TAG_BASEDIC-1].dwLength = 0; //***** set tables offset ***** dwTotal = sizeof(MAINID) + sizeof(MAININDEX)*NUMTABLES; lpMainIndex[TAG_DESCRIPTION-1].dwOffset = dwTotal; dwTotal += lpMainIndex[TAG_DESCRIPTION-1].dwLength; lpMainIndex[TAG_RULE-1].dwOffset = dwTotal; dwTotal += lpMainIndex[TAG_RULE-1].dwLength; lpMainIndex[TAG_ENCODE-1].dwOffset = dwTotal; dwTotal += lpMainIndex[TAG_ENCODE-1].dwLength; lpMainIndex[TAG_CRTWORDCODE-1].dwOffset = dwTotal; dwTotal += lpMainIndex[TAG_CRTWORDCODE-1].dwLength; lpMainIndex[TAG_RECONVINDEX-1].dwOffset = dwTotal; dwTotal += lpMainIndex[TAG_RECONVINDEX-1].dwLength; lpMainIndex[TAG_BASEDICINDEX-1].dwOffset = dwTotal; dwTotal += lpMainIndex[TAG_BASEDICINDEX-1].dwLength; lpMainIndex[TAG_BASEDIC-1].dwOffset = dwTotal; for(i=0; iwNumCodes; hNumXYWords = GlobalAlloc(GMEM_MOVEABLE|GMEM_ZEROINIT,sizeof(DWORD)*((NumCodes+1)*NumCodes+1L)); hDicIndex = GlobalAlloc(GMEM_MOVEABLE|GMEM_ZEROINIT,sizeof(DWORD)*(NumCodes+1)*NumCodes); if(!hNumXYWords || !hDicIndex) { ProcessError(ERR_OUTOFMEMORY,hWnd,ERR); return FALSE; } if( !(lpNumXYWords = GlobalLock(hNumXYWords)) ||!(lpDicIndex = GlobalLock(hDicIndex)) ) { ProcessError(ERR_GLOBALLOCK,hWnd,ERR); GlobalFree(hNumXYWords); GlobalFree(hDicIndex); return FALSE; } StringCchCopy(Code, ARRAYSIZE(Code), lpDescript->szUsedCode); FstAdr = lpMainIndex[TAG_BASEDIC-1].dwOffset; NumX=0; NumY=0; dwXStart=0; dwYStart=0; dwOffset=0; lpNumXYWords[0]=0; lpDicIndex[0]=0; for(i =0; i= 126 ) bySwap = 126; dwRecLen += 2*(DWORD)bySwap+sizeof(TCHAR); while( lpWordIndex[i].szCode[0] != Code[NumX] ) { if(!bStart && NumY == 0) { lpNumXYWords[NumX*(NumCodes+1)+NumY+1] = i; lpDicIndex[NumX*(NumCodes+1)+NumY+1] = dwOffset; } while(NumY < NumCodes-1 ) { NumY ++; lpNumXYWords[NumX*(NumCodes+1)+NumY+1] = i; lpDicIndex[NumX*(NumCodes+1)+NumY+1] = dwOffset; } NumX ++; if(NumX >= NumCodes) break; lpNumXYWords[NumX*(NumCodes+1)] = i; lpDicIndex[NumX*(NumCodes+1)] = dwOffset; NumY = 0; bStart = FALSE; } if(NumX >= NumCodes) break; cc = lpWordIndex[i].szCode[1]; if(!bStart && cc != 0 && NumY == 0) { lpNumXYWords[NumX*(NumCodes+1)+1] = i; lpDicIndex[NumX*(NumCodes+1)+1] = dwOffset; bStart = TRUE; } while(bStart && cc != 0 && cc != Code[NumY] && NumY < NumCodes - 1 ) { NumY ++; lpNumXYWords[NumX*(NumCodes+1)+NumY+1] = i; lpDicIndex[NumX*(NumCodes+1)+NumY+1] = dwOffset; } dwOffset += dwRecLen; if(i == dwBaseWordNum-1) { j = NumX*(NumCodes+1) + NumY + 1; while(j < (NumCodes+1)*NumCodes - 1 ) { j ++; lpNumXYWords[j] = i + 1; lpDicIndex[j] = dwOffset; } lpNumXYWords[NumCodes*(NumCodes+1)] = i; } } for(i = 0; i < NumCodes ; i++) { for(j = 0; j < NumCodes + 1; j++) { if(j == 0) { lpNumXYWords[i*(NumCodes+1)] = lpNumXYWords[(i+1)*(NumCodes+1)] - lpNumXYWords[i*(NumCodes+1)]; } else { lpNumXYWords[i*(NumCodes+1)+j] = lpNumXYWords[i*(NumCodes+1)+j+1] - lpNumXYWords[i*(NumCodes+1)+j]; lpDicIndex[i*(NumCodes+1)+j] = lpDicIndex[i*(NumCodes+1)+j] - lpDicIndex[i*(NumCodes+1)]; } } } lpMainIndex[TAG_BASEDIC-1].dwLength = dwOffset; lpMainIndex[TAG_BASEDIC-1].dwCheckSum = TAG_BASEDIC + lpMainIndex[TAG_BASEDIC-1].dwOffset+ dwOffset; for(i=0; i< NumCodes - 1;i++) { dwRecLen = lpDicIndex[(i+1)*(NumCodes+1)]-lpDicIndex[(NumCodes+1)*i]; dwMaxXLen = (dwRecLen>dwMaxXLen)? dwRecLen:dwMaxXLen; } dwRecLen = dwOffset - lpDicIndex[(NumCodes+1)*(NumCodes-1)]; dwMaxXLen = (dwRecLen>dwMaxXLen)? dwRecLen:dwMaxXLen; ConvWriteMainIndex(hMBFile,lpMainIndex); ConvWriteCodeIndex(hMBFile,&dwMaxXLen,lpDescript->szUsedCode,lpMainIndex); ConvWriteDicIndex(hMBFile,lpDicIndex,lpDescript->wNumCodes,lpMainIndex); ConvWriteNumXYWords(hMBFile,lpNumXYWords, lpDescript->wNumCodes,lpMainIndex); GlobalUnlock(hDicIndex); GlobalUnlock(hNumXYWords); GlobalFree(hDicIndex); GlobalFree(hNumXYWords); return TRUE; } BOOL WriteMBFile(HANDLE hWnd, HANDLE hSRCFile, HANDLE hMBFile, LPWORDINDEX lpWordIndex, LPMAININDEX lpMainIndex, LPDESCRIPTION lpDescript) { DWORD i,dwBytes,NumCodes,FstAdr; WORD bySwap; TCHAR szStr[256]; TCHAR Code[MAXNUMCODES]; DWORD dwReadSum; HANDLE hDlgItem; SetCursor (LoadCursor (NULL, IDC_WAIT)); SetDlgItemText(hWnd,TM_TOTALINFO,TEXT("")); LoadString(NULL,IDS_TOTALINFO,szStr,sizeof(szStr)/sizeof(TCHAR)); SetDlgItemText(hWnd,TM_TOTAL,szStr); LoadString(NULL,IDS_CONVWORDS,szStr,sizeof(szStr)/sizeof(TCHAR)); SetDlgItemText(hWnd,TM_CONVINFO,szStr); SetDlgItemInt(hWnd,TM_TOTALNUM,dwBaseWordNum,FALSE); dwReadSum = 0; SetDlgItemInt(hWnd,TM_CONVNUM,dwReadSum,FALSE); InvalidateRect(hWnd,NULL,FALSE); NumCodes=lpDescript->wNumCodes; lstrncpy(Code,NumCodes,lpDescript->szUsedCode); FstAdr = lpMainIndex[TAG_BASEDIC-1].dwOffset; SetFilePointer(hMBFile,FstAdr,0, FILE_BEGIN); for(i =0; i= 126 ) bySwap = 126; WriteFile(hMBFile,&bySwap,sizeof(TCHAR),&dwBytes,NULL); WriteFile(hMBFile,szStr,2*bySwap,&dwBytes,NULL); dwReadSum ++; if(dwReadSum%100 ==0 || dwReadSum == dwBaseWordNum) { SetDlgItemInt(hWnd,TM_CONVNUM,dwReadSum,FALSE); hDlgItem=GetDlgItem(hWnd,TM_CONVNUM); InvalidateRect(hDlgItem,NULL,FALSE); } } SetCursor (LoadCursor (NULL, IDC_ARROW)); return TRUE; } BOOL WriteSortFile(HANDLE hWnd, HANDLE hSRCFile, HANDLE hDestFile, LPWORDINDEX lpWordIndex, LPCREATEWORD lpCreateWords) { DWORD i, k, dwBytes; WORD wRecLen; BYTE bySwap; TCHAR szStr[512],szDBCS[512]; TCHAR szCode[13],szCreate[13]; BOOL IsGenCmb = (hCmbFile)?TRUE:FALSE; BOOL bExistNext = FALSE; DWORD dwReadSum; SetFilePointer(hDestFile,0,0, FILE_END); dwReadSum = 0; for(i =0; i=0 && k < NUM_OF_ENCODE) { lstrncpy(szCreate,MAXCODELEN,&lpCreateWords[k*MAXCODELEN]); szCreate[MAXCODELEN]=0; if(lstrlen(szCreate)) StringCchPrintf(szStr,ARRAYSIZE(szStr),TEXT("%s%s %s\r\n"),szDBCS,szCode,szCreate); else StringCchPrintf(szStr,ARRAYSIZE(szStr),TEXT("%s%s\r\n"),szDBCS,szCode); } else StringCchPrintf(szStr,ARRAYSIZE(szStr),TEXT("%s%s\r\n"),szDBCS,szCode); } else StringCchPrintf(szStr,ARRAYSIZE(szStr),TEXT("%s%s\r\n"),szDBCS,szCode); WriteFile(hDestFile,szStr,lstrlen(szStr)*sizeof(TCHAR),&dwBytes,NULL); if(IsGenCmb) { if(i != dwBaseWordNum - 1 && _wcsicmp(lpWordIndex[i].szCode, lpWordIndex[i+1].szCode) == 0) { StringCchPrintf(szStr,ARRAYSIZE(szStr),TEXT("%s%s\r\n"),szCode,szDBCS); WriteFile(hCmbFile,szStr,lstrlen(szStr)*sizeof(TCHAR),&dwBytes,NULL); bExistNext = TRUE; dwReadSum ++; } else { if(bExistNext) { StringCchPrintf(szStr,ARRAYSIZE(szStr),TEXT("%s%s\r\n"),szCode,szDBCS); WriteFile(hCmbFile,szStr,lstrlen(szStr)*sizeof(TCHAR),&dwBytes,NULL); } bExistNext = FALSE; } } } if(IsGenCmb) { #ifdef UNICODE TCHAR UniTmp[] = {0x5171, 0x8BA1, 0x91CD, 0x7801, 0x8BCD, 0x6761, 0x6570, 0x0000}; StringCchPrintf(szStr,ARRAYSIZE(szStr),TEXT("%ws = %d\n"), UniTmp, dwReadSum); #else StringCchPrintf(szStr,ARRAYSIZE(szStr),"共计重码词条数 = %ld\n", dwReadSum); #endif WriteFile(hCmbFile,szStr,lstrlen(szStr)*sizeof(TCHAR),&dwBytes,NULL); } return TRUE; } int SimpleSplit(HANDLE hWnd, LPINT nPages, LPTSTR szStr, LPCREATEWORD lpCreateWords, LPWORDINDEX lpWordIndex, WORD wMaxCodes) { register int i=0; int nDBCS=0, nCodes=0, nCreate = 0; TCHAR szDBCS[512],szCode[13],szCreate[128]; if(ParseDBCSstr(hWnd,szStr,szDBCS,szCode,szCreate,wMaxCodes) != TRUE) { if(lstrlen(szDBCS) == 0) { LoadString(NULL, IDS_NOTEXISTDBCS, szCreate, sizeof(szCreate)/sizeof(TCHAR)); StringCchPrintf(szDBCS, ARRAYSIZE(szDBCS), TEXT("\'%s%lu)"),szCreate,dwLineNo); FatalMessage(hWnd,szDBCS); } return FALSE; } nDBCS = lstrlen(szDBCS); DelIllegalCode(szCode); nCodes = lstrlen(szCode); nCreate = lstrlen(szCreate); dwBaseWordNum ++; lpWordIndex[dwBaseWordNum-1].wDBCSLen =(WORD)(nDBCS*sizeof(TCHAR)/2); lstrcpy(lpWordIndex[dwBaseWordNum-1].szCode,szCode); if(nDBCS == 2/sizeof(TCHAR)) { i = EncodeToNo(szDBCS); if(i>=0 && i < NUM_OF_ENCODE) { if(nCreate != 0) lstrncpy(lpCreateWords+i*MAXCODELEN, MAXCODELEN, szCreate); } } return TRUE; } int WordSplit(HANDLE hWnd, LPINT nPages, LPTSTR szStr, LPCREATEWORD lpCreateWords, LPWORDINDEX lpWordIndex, LPDESCRIPTION lpDescript, LPRECONVINDEX lpReConvIndex) { int i, nDBCS=0, nCodes=0, nCreate = 0; TCHAR szTemp[512],szTmpStr[256]; TCHAR szDBCS[512],szCode[13],szCreate[128]; if(ParseDBCSstr(hWnd,szStr,szDBCS,szCode,szCreate,lpDescript->wMaxCodes) != TRUE) { if(lstrlen(szDBCS) == 0) { LoadString(NULL, IDS_NOTEXISTDBCS, szTmpStr, sizeof(szTmpStr)/sizeof(TCHAR)); StringCchPrintf(szTemp, ARRAYSIZE(szTemp), TEXT("\'%s%lu)"),szTmpStr,dwLineNo); FatalMessage(hWnd,szTemp); } return FALSE; } if ( lstrlen(szDBCS) > 126 ) { // if the string is longer than 126, the rest will be cut. // so show a message to end user. LoadString(NULL, IDS_DBCSTOOLONG, szTmpStr, sizeof(szTmpStr)/sizeof(TCHAR)); #ifdef UNICODE { TCHAR UniTmp[] = {0x0027, 0x0025, 0x0077, 0x0073, 0x0027, 0x0020, 0x0020, 0x0020, 0x0028, 0x884C, 0x003A, 0x0025, 0x006C, 0x0075, 0x0029, 0x0025, 0x0077, 0x0073, 0x000D, 0x000A, 0x000D, 0x000A, 0x9000, 0x51FA, 0x5426, 0x003F, 0x0020, 0x0000}; StringCchPrintf(szTemp, ARRAYSIZE(szTemp), UniTmp, szDBCS,dwLineNo,szTmpStr); } #else StringCchPrintf(szTemp, ARRAYSIZE(szTemp),"\'%s\'%s(行:%lu)\n退出否? ",szDBCS,szTmpStr,dwLineNo); #endif if (ErrMessage(hWnd,szTemp)) return FALSE; } if(!CheckCodeLegal(hWnd,szDBCS,szCode,szCreate,lpDescript)) return FALSE; nDBCS = lstrlen(szDBCS); nCodes = lstrlen(szCode); nCreate = lstrlen(szCreate); if(nDBCS == 0) return -1; if(nDBCS == 2/sizeof(TCHAR)) { i = EncodeToNo(szDBCS); if(i < 0 || i >= NUM_OF_ENCODE) return FALSE; if(nCodes == 0) { LoadString(NULL, IDS_CODEEMPTY, szTmpStr, sizeof(szTmpStr)/sizeof(TCHAR)); #ifdef UNICODE { TCHAR UniTmp[] = {0x005C, 0x0027, 0x0025, 0x0077, 0x0073, 0x005C, 0x0027, 0x0025, 0x0077, 0x0073, 0x0028, 0x884C, 0x003A, 0x0025, 0x006C, 0x0075, 0x0029, 0x005C, 0x006E, 0x9000, 0x51FA, 0x5426, 0x003F, 0x0020, 0x0000}; StringCchPrintf(szTemp, ARRAYSIZE(szTemp), UniTmp, szDBCS,szTmpStr,dwLineNo); } #else StringCchPrintf(szTemp, ARRAYSIZE(szTemp),"\'%s\'%s(行:%lu)\n退出否? ",szDBCS,szTmpStr,dwLineNo); #endif \\UNICODE if(ErrMessage(hWnd,szTemp)) return FALSE; } //**** write create words if(lpDescript->wNumRules != 0 && nCreate != 0) { if(nCreate > lpDescript->wMaxCodes) { LoadString(NULL,IDS_DBCSCODE,szTmpStr,sizeof(szTmpStr)/sizeof(TCHAR)); #ifdef UNICODE { TCHAR UniTmp[] = {0x005C, 0x0027, 0x0025, 0x0077, 0x0073, 0x0025, 0x0077, 0x0073, 0x005C, 0x0027, 0x0020, 0x0025, 0x0064, 0x0021, 0x0028, 0x884C, 0x003A, 0x0025, 0x006C, 0x0075, 0x0029, 0x005C, 0x006E, 0x9000, 0x51FA, 0x5426, 0x003F, 0x0000}; StringCchPrintf(szTemp, ARRAYSIZE(szTemp),UniTmp, szDBCS,szTmpStr, lpDescript->byMaxElement,dwLineNo); } #else StringCchPrintf(szTemp, ARRAYSIZE(szTemp),"\'%s%s\' %d!(行:%lu)\n退出否?", szDBCS,szTmpStr, lpDescript->byMaxElement,dwLineNo); #endif \\UNICODE if( ErrMessage(hWnd,szTemp)) return FALSE; } lstrncpy(szTmpStr,lpDescript->wMaxCodes, lpCreateWords+i*(DWORD)lpDescript->wMaxCodes); szTmpStr[lpDescript->wMaxCodes] = 0; if(!(WriteCrtFlag[i/8] & (1 << (7 - (i%8))) ) ) lstrncpy(lpCreateWords+i*(DWORD)lpDescript->wMaxCodes, lpDescript->wMaxCodes, szCreate); WriteCrtFlag[i/8] |= (1 << (7 - (i%8)) ); } } else if(nDBCS>2*sizeof(TCHAR) && nCodes==0 && lpDescript->wNumRules==0) { LoadString(NULL,IDS_CODEEMPTY,szTmpStr,sizeof(szTmpStr)/sizeof(TCHAR)); #ifdef UNICODE { TCHAR UniTmp[] = {0x005C, 0x0027, 0x0025, 0x0077, 0x0073, 0x005C, 0x0027, 0x0025, 0x0077, 0x0073, 0x0028, 0x884C, 0x003A, 0x0025, 0x006C, 0x0064, 0x0029, 0x0000}; StringCchPrintf(szTemp, ARRAYSIZE(szTemp),UniTmp, szDBCS,szTmpStr,dwLineNo); } #else StringCchPrintf(szTemp, ARRAYSIZE(szTemp),"\'%s\'%s(行:%ld)", szDBCS,szTmpStr,dwLineNo); #endif WarnMessage(hWnd,szTemp); return FALSE; } dwBaseWordNum ++; if(dwBaseWordNum >(DWORD)(*nPages)*GMEM_PAGESIZE) { GlobalUnlock(hWordIndex); hWordIndex = IndexReAlloc(hWordIndex,nPages); if(!hWordIndex) { ProcessError(ERR_OUTOFMEMORY,hWnd,ERR); return FALSE; } lpWordIndex = (LPWORDINDEX) GlobalLock(hWordIndex); if( !lpWordIndex ) { ProcessError(ERR_GLOBALLOCK,hWnd,ERR); return FALSE; } } lpWordIndex[dwBaseWordNum-1].wDBCSLen =(WORD)(nDBCS*sizeof(TCHAR)/2); lstrcpy(lpWordIndex[dwBaseWordNum-1].szCode,szCode); ConvReconvIndex(hWnd,szDBCS,lpCreateWords,lpWordIndex[dwBaseWordNum-1],lpDescript,lpReConvIndex); return TRUE; } BOOL ConvWriteBaseWord (HANDLE hWnd, HANDLE hSRCFile, HANDLE hMBFile, MAINID MainID, DWORD dwOffset, LPCREATEWORD lpCreateWords, LPRECONVINDEX lpReConvIndex, DWORD MaxCodes) { TCHAR szCode[13],szCreate[13],szDBCS[512],szReCode[13]; TCHAR szStr[512]; static TCHAR ReadBuf[MAXREADBUFFER]; static TCHAR WriteBuf[2*MAXREADBUFFER]; DWORD dwReadBytes,dwRecLen,i,j,k,dwReadWords=0; DWORD dwFileFlag = MainID.dwFileFlag; DWORD dwNumWords = MainID.dwNumWords; DWORD dwReadSum; HWND hDlgItem; SetFilePointer(hMBFile,dwOffset,0,FILE_BEGIN); SetFilePointer(hSRCFile,0,0,FILE_END); SetDlgItemText(hWnd,TM_TOTALINFO,TEXT("")); LoadString(NULL,IDS_TOTALINFO,szStr,sizeof(szStr)/sizeof(TCHAR)); SetDlgItemText(hWnd,TM_TOTAL,szStr); LoadString(NULL,IDS_RECONVWORDS,szStr,sizeof(szStr)/sizeof(TCHAR)); SetDlgItemText(hWnd,TM_CONVINFO,szStr); SetDlgItemInt(hWnd,TM_TOTALNUM,dwNumWords,FALSE); dwReadSum = 0; SetDlgItemInt(hWnd,TM_CONVNUM,dwReadSum,FALSE); InvalidateRect(hWnd,NULL,FALSE); i=0; do { if (!ReadFile(hMBFile,ReadBuf,sizeof(ReadBuf),&dwReadBytes,NULL)) break; i=0; if(dwReadBytes == 0 ) break; WriteBuf[0]=0; dwReadBytes = dwReadBytes/sizeof(TCHAR); while( i < dwReadBytes-1 ) { j = (DWORD)ReadBuf[i]+1; dwRecLen = j+(DWORD)ReadBuf[i+j]*2/sizeof(TCHAR)+1; if( (dwReadBytes*sizeof(TCHAR) < MAXREADBUFFER) || ((i+j) < (dwReadBytes-1) && (i+dwRecLen) < (dwReadBytes-1) ) ) { lstrncpy(szCode,ReadBuf[i],&ReadBuf[i+1]); szCode[ReadBuf[i]] = 0; lstrncpy(szDBCS,ReadBuf[i+j]*2/sizeof(TCHAR),&ReadBuf[i+j+1]); szDBCS[ReadBuf[i+j]*2/sizeof(TCHAR)] = 0; if(ReadBuf[i+j]==1 &&(dwFileFlag&FFLG_RULE)) { k = EncodeToNo(szDBCS); if((long)k>=0 && k < NUM_OF_ENCODE) { lstrncpy(szCreate,MaxCodes,&lpCreateWords[k*MaxCodes]); lstrncpy(szReCode,MaxCodes,&lpReConvIndex[k*MaxCodes]); szCreate[MaxCodes]=0; szReCode[MaxCodes]=0; if(lstrlen(szCreate) != 0 && lstrcmpi(szCreate,szCode) != 0) StringCchPrintf(szStr, ARRAYSIZE(szStr),TEXT("%s%s %s\r\n"),szDBCS,szCode,szCreate); else StringCchPrintf(szStr, ARRAYSIZE(szStr),TEXT("%s%s\r\n"),szDBCS,szCode); } else StringCchPrintf(szStr, ARRAYSIZE(szStr),TEXT("%s%s\r\n"),szDBCS,szCode); } else StringCchPrintf(szStr, ARRAYSIZE(szStr),TEXT("%s%s\r\n"),szDBCS,szCode); lstrcat(WriteBuf,szStr); dwReadWords ++; dwReadSum = dwReadWords; if(dwReadSum%100 ==0 || dwReadSum == dwNumWords) { SetDlgItemInt(hWnd,TM_CONVNUM,dwReadSum,FALSE); hDlgItem=GetDlgItem(hWnd,TM_CONVNUM); InvalidateRect(hDlgItem,NULL,FALSE); } i += dwRecLen; } else { SetFilePointer(hMBFile,(i-dwReadBytes)*sizeof(TCHAR),0,FILE_CURRENT); break; } } WriteFile(hSRCFile,WriteBuf,lstrlen(WriteBuf)*sizeof(TCHAR),&k,NULL); }while (dwReadBytes == MAXREADBUFFER) ; return TRUE; } BOOL ConvBatCreate (HANDLE hWnd, DESCRIPTION Descript, LPRULE lpRule, LPCREATEWORD lpCreateWord, LPTSTR szWordStr, LPTSTR lpCode) { int nWordLen=lstrlen(szWordStr)*sizeof(TCHAR)/2; DWORD i,j,k,dwCodeLen; DWORD dwNumRules = Descript.wNumRules; WORD wMaxCodes = Descript.wMaxCodes; TCHAR szDBCS[3],szCode[MAXCODELEN+1]; BOOL bReturn = FALSE; lpCode[0] = 0; if(dwNumRules == 0) { ProcessError(ERR_NORULE,hWnd,ERR); return FALSE; } for(i=0; i= lpRule[i].byLength) ||(lpRule[i].byLogicOpra == 2 && nWordLen <= lpRule[i].byLength) ) { int retCodeLen = 0; for(j=0; j (DWORD)nWordLen) k = (DWORD)nWordLen; if(lpRule[i].CodeUnit[j].dwDirectMode == 0) lstrncpy(szDBCS,2,&szWordStr[2*(k-1)]); else lstrncpy(szDBCS,2,&szWordStr[2*(nWordLen-k)]); szDBCS[2] = 0; k = EncodeToNo(szDBCS); if((long)k>=0 && k< NUM_OF_ENCODE ) { lstrncpy(szCode,wMaxCodes,&lpCreateWord[wMaxCodes*k]); szCode[wMaxCodes] = 0; dwCodeLen = lstrlen(szCode); k = lpRule[i].CodeUnit[j].wCodePosition; if(k == 0) { if(retCodeLen + dwCodeLen > Descript.wMaxCodes) szCode[Descript.wMaxCodes - retCodeLen] = 0; lstrcat(lpCode,szCode); } else { if(k > dwCodeLen) k = dwCodeLen; lpCode[j] = (szCode[k-1] == 0)?((k > 1)? szCode[k-2]:Descript.szUsedCode[0]):szCode[k-1]; } } else lpCode[j] = (j > 0)?lpCode[j-1]:Descript.szUsedCode[0]; retCodeLen = lstrlen(lpCode); } bReturn = TRUE; break; } if(!bReturn) ProcessError(ERR_NOTDEFRULE,hWnd,ERR); lpCode[wMaxCodes] = 0; return bReturn; } BOOL searchPos(LPWORDINDEX lpWordIndex, DWORD dwNumWords) { DWORD i, retPos; WORDINDEX InsWordIndex = lpWordIndex[dwNumWords-1]; if(dwNumWords == 1) return TRUE; retPos = bSearch(lpWordIndex, 0, dwNumWords-2, InsWordIndex); if(retPos == dwNumWords - 1) return TRUE; memmove(&lpWordIndex[retPos+1], &lpWordIndex[retPos], sizeof(WORDINDEX)*(dwNumWords - 1 - retPos) ); lpWordIndex[retPos] = InsWordIndex; return TRUE; } DWORD bSearch(LPWORDINDEX lpWordIndex, DWORD left, DWORD right, WORDINDEX InsWordIndex) { WORDINDEX MidWordIndex; DWORD mid; if(left > right) return left; mid = (left + right)/2; MidWordIndex = lpWordIndex[mid]; if(_wcsicmp(MidWordIndex.szCode, InsWordIndex.szCode) <= 0) { if(mid == right || _wcsicmp(lpWordIndex[mid+1].szCode, InsWordIndex.szCode) > 0) return mid+1; else return bSearch(lpWordIndex, mid+1, right, InsWordIndex); } else { if(mid == left || _wcsicmp(lpWordIndex[mid-1].szCode, InsWordIndex.szCode) <= 0) return mid; else // return bSearch(lpWordIndex, left, mid, InsWordIndex); return bSearch(lpWordIndex, left, mid-1, InsWordIndex); } return 0; } //***** end 95.10.17