mirror of https://github.com/tongzx/nt5src
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
797 lines
25 KiB
797 lines
25 KiB
/*===========================================================================*/
|
|
/* Copyright (c) 1987 - 1988, Future Soft Engineering, Inc. */
|
|
/* Houston, Texas */
|
|
/*===========================================================================*/
|
|
|
|
#define NOGDICAPMASKS TRUE
|
|
#define NOVIRTUALKEYCODES TRUE
|
|
#define NOICONS TRUE
|
|
#define NOKEYSTATES TRUE
|
|
#define NOSYSCOMMANDS TRUE
|
|
#define NOATOM TRUE
|
|
#define NOCLIPBOARD TRUE
|
|
#define NODRAWTEXT TRUE
|
|
#define NOMINMAX TRUE
|
|
#define NOSCROLL TRUE
|
|
#define NOHELP TRUE
|
|
#define NOPROFILER TRUE
|
|
#define NODEFERWINDOWPOS TRUE
|
|
#define NOPEN TRUE
|
|
#define NO_TASK_DEFINES TRUE
|
|
#define NOLSTRING TRUE
|
|
#define WIN31
|
|
#define USECOMM
|
|
|
|
#include <windows.h>
|
|
#include "port1632.h"
|
|
#include "dcrc.h"
|
|
#include "dynacomm.h"
|
|
#include "fileopen.h"
|
|
#include "task.h"
|
|
|
|
|
|
/*---------------------------------------------------------------------------*/
|
|
|
|
#define DCS_OLD_FKEYLEVELS 4
|
|
#define DCS_OLD_NUMFKEYS 8
|
|
#define DCS_OLD_FKEYLEN 64
|
|
#define DCS_OLD_FKEYTITLESZ 20
|
|
#define DCS_OLD_XTRALEN 44
|
|
#define DCS_OLD_MDMCMDLEN 32
|
|
#define DCS_OLD_MISCSTRLEN 21
|
|
|
|
|
|
#define TITLEREC struct tagTITLEREC
|
|
|
|
struct tagTITLEREC
|
|
{
|
|
BYTE title[DCS_OLD_FKEYTITLESZ];
|
|
BYTE xtra[DCS_OLD_XTRALEN];
|
|
};
|
|
|
|
|
|
#define oldTrmParams struct tagOldTrmParams
|
|
#define LPOLDSETTINGS oldTrmParams FAR *
|
|
|
|
struct tagOldTrmParams
|
|
{
|
|
INT inpRefNum;
|
|
INT outRefNum;
|
|
INT emulate;
|
|
INT dataBits;
|
|
INT parity;
|
|
INT speed;
|
|
INT stopBits;
|
|
BYTE col80Or132;
|
|
BYTE flowControl;
|
|
BOOL localEcho;
|
|
BOOL lineWrap;
|
|
BOOL inpCRLF;
|
|
BOOL outCRLF;
|
|
BOOL inpLFCR;
|
|
BOOL fCtrlBits;
|
|
STRING fKeyText[DCS_OLD_FKEYLEVELS][DCS_OLD_NUMFKEYS][DCS_OLD_FKEYLEN];
|
|
TITLEREC fKeyTitle[DCS_OLD_FKEYLEVELS][DCS_OLD_NUMFKEYS];
|
|
STRING phone[DCS_OLD_MDMCMDLEN];
|
|
STRING binTXPrefix[DCS_OLD_MDMCMDLEN];
|
|
STRING dialPrefix[DCS_OLD_MDMCMDLEN];
|
|
STRING binTXSuffix[DCS_OLD_MDMCMDLEN];
|
|
STRING dialSuffix[DCS_OLD_MDMCMDLEN];
|
|
STRING binRXPrefix[DCS_OLD_MDMCMDLEN];
|
|
STRING hangPrefix[DCS_OLD_MDMCMDLEN];
|
|
STRING binRXSuffix[DCS_OLD_MDMCMDLEN];
|
|
STRING hangSuffix[DCS_OLD_MDMCMDLEN];
|
|
STRING fastInq[DCS_OLD_MDMCMDLEN];
|
|
STRING originate[DCS_OLD_MDMCMDLEN];
|
|
STRING fastRsp[DCS_OLD_MDMCMDLEN];
|
|
STRING answer[DCS_OLD_MDMCMDLEN];
|
|
STRING strXtra8[DCS_OLD_MDMCMDLEN];
|
|
BOOL flgRetry;
|
|
BYTE padding2;
|
|
INT dlyRetry;
|
|
INT cntRetry;
|
|
BOOL flgSignal;
|
|
BYTE version;
|
|
BOOL carrierFlag;
|
|
BYTE padding3;
|
|
STRING xLinStr[DCS_OLD_MISCSTRLEN+1];
|
|
STRING mdmConnect[DCS_OLD_MISCSTRLEN+1];
|
|
STRING strXtra2[DCS_OLD_MISCSTRLEN+1];
|
|
STRING strXtra3[DCS_OLD_MISCSTRLEN+1];
|
|
STRING strXtra4[DCS_OLD_MISCSTRLEN+1];
|
|
INT rcvBlSz;
|
|
INT sendBlSz;
|
|
INT retryCt;
|
|
BYTE remote;
|
|
BYTE padding9;
|
|
INT xtraInt[4];
|
|
INT xWrapCol;
|
|
BYTE termCursor;
|
|
BOOL cursorBlink;
|
|
BOOL bsKey;
|
|
BYTE language;
|
|
STRING autoExecute[DCS_OLD_FKEYLEN];
|
|
BYTE xTxtType;
|
|
BYTE xChrType;
|
|
INT xChrDelay;
|
|
BYTE xLinType;
|
|
BYTE padding10;
|
|
INT xLinDelay;
|
|
BYTE xMdmType;
|
|
BOOL xWordWrap;
|
|
BYTE xBinType;
|
|
BYTE xBinFork;
|
|
};
|
|
|
|
|
|
/*---------------------------------------------------------------------------*/
|
|
|
|
#define MSSETTINGS struct tagMSSETTINGS
|
|
#define LPMSSETTINGS MSSETTINGS FAR *
|
|
|
|
struct tagMSSETTINGS
|
|
{
|
|
INT iCRC; /* The CRC checksum for the settings */
|
|
INT iVersion; /* The version number */
|
|
BOOL fModem; /* True if port is connected to a modem */
|
|
BOOL fNewLine; /* True if new-line button is on */
|
|
BOOL fLocalEcho; /* True if local-echo button is on */
|
|
BOOL fAutoWrap; /* True if auto-wrap button is on */
|
|
BOOL fVT52; /* True if term is VT52, false if ANSI */
|
|
BOOL fLarge; /* True for large text size */
|
|
BOOL fTone; /* True if dial type is tone */
|
|
BOOL fFast; /* True if dial pulses are short */
|
|
INT clnBuf; /* Count of lines in buffer */
|
|
INT iBaud; /* The baud rate */
|
|
INT iPort; /* The port number */
|
|
INT iByteSize; /* The number of bits per char */
|
|
INT iStopBits; /* The number of stop bits */
|
|
INT iParity; /* The parity method */
|
|
INT iHandshake; /* The handshake method */
|
|
INT iAnswer; /* The number of seconds to wait for answer */
|
|
INT iToneWait; /* Number of seconds to wait for tone */
|
|
CHAR szPhNum[30]; /* The phone number */
|
|
CHAR szFNCapture[128]; /* The capture file name */
|
|
INT iCountry; /* The character translation country code */
|
|
};
|
|
|
|
|
|
/*---------------------------------------------------------------------------*/
|
|
|
|
BOOL termInitSetup(HANDLE); /* ==> termfile.h */
|
|
VOID termCloseEnable(BOOL);
|
|
BOOL termCloseFile(VOID);
|
|
BOOL termCloseAll(VOID);
|
|
BOOL termSaveFile(BOOL);
|
|
BOOL NEAR termReadFile(BYTE *);
|
|
VOID NEAR termCloseWindow(VOID);
|
|
BOOL NEAR termCloseFileInternal(VOID);
|
|
INT TF_ErrProc(WORD, WORD, WORD);
|
|
|
|
BOOL NEAR readTermSettings(INT, WORD); /* mbbx 2.00: was LONG */
|
|
VOID NEAR convertMSToIBM(LPMSSETTINGS, recTrmParams *);
|
|
BOOL NEAR writeTermSettings(INT);
|
|
VOID NEAR convertInternalToVirtual(LPSETTINGS, LPSETTINGS); /* rkhx 2.00 */
|
|
|
|
|
|
/*---------------------------------------------------------------------------*/
|
|
/* termInitSetup() - [mbb] */
|
|
/*---------------------------------------------------------------------------*/
|
|
|
|
BOOL termInitSetup(HANDLE hPrevInstance)
|
|
{
|
|
// sdj: was unref local- WNDCLASS termClass;
|
|
|
|
activTerm = FALSE;
|
|
|
|
strcpy(termData.filePath, fileDocData[FILE_NDX_SETTINGS].filePath);
|
|
*termData.fileName = 0;
|
|
strcpy(termData.fileExt, fileDocData[FILE_NDX_SETTINGS].fileExt);
|
|
LoadString(hInst, STR_TERMINAL, (LPSTR) termData.title, MINRESSTR);
|
|
termData.flags = TF_DEFTITLE;
|
|
|
|
resetEmul(); /* must have init settings! */
|
|
|
|
return(TRUE);
|
|
}
|
|
|
|
|
|
/*---------------------------------------------------------------------------*/
|
|
/* termFile() - [mbb] */
|
|
/*---------------------------------------------------------------------------*/
|
|
|
|
BOOL termFile(BYTE *filePath, BYTE *fileName,BYTE *fileExt,BYTE *title,WORD flags)
|
|
{
|
|
BYTE work[PATHLEN];
|
|
RECT termRect;
|
|
BYTE OEMname[STR255]; /* jtf 3.20 */
|
|
|
|
if(strlen(fileName) > 0) /* mbbx 1.03 ... */
|
|
{
|
|
#ifdef ORGCODE
|
|
strcpy(work, filePath); /* mbbx 2.00: no forced extents... */
|
|
strcpy(work+strlen(work), fileName); /* jtf 3.20 */
|
|
#else
|
|
strcpy(work, filePath); /* mbbx 2.00: no forced extents... */
|
|
strcpy(work+strlen(work), "\\"); /* jtf 3.20 */
|
|
strcpy(work+strlen(work), fileName); /* jtf 3.20 */
|
|
#endif
|
|
|
|
|
|
// JYF -- replace below two lines with following if()
|
|
// to remove the use of AnsiToOem()
|
|
//
|
|
//AnsiToOem((LPSTR) work, (LPSTR) OEMname); /* jtf 3.20 */
|
|
//if(!fileExist(OEMname))
|
|
|
|
if (!fileExist(work))
|
|
return(FALSE);
|
|
}
|
|
|
|
if(termCloseFileInternal())
|
|
{
|
|
if((flags & TF_DEFTITLE) && (strlen(fileName) > 0))
|
|
strcpy(termData.title, fileName);
|
|
else
|
|
strcpy(termData.title, title);
|
|
SetWindowText(hTermWnd, (LPSTR) termData.title);
|
|
setAppTitle();
|
|
|
|
SetCursor(LoadCursor(NULL, IDC_WAIT));
|
|
|
|
strcpy(termData.filePath, filePath);
|
|
strcpy(termData.fileName, fileName);
|
|
strcpy(termData.fileExt, fileExt);
|
|
termData.flags = flags | (termData.flags & (TF_DIM | TF_HIDE));
|
|
|
|
setDefaults(); /* mbbx 2.00: do this first! */
|
|
if(strlen(fileName) > 0)
|
|
{
|
|
if(!termReadFile(work))
|
|
doFileNew(); /* jtf 3.31 */
|
|
}
|
|
|
|
activTerm = TRUE;
|
|
|
|
setFKeyLevel(1, TRUE); /* mbbx 2.00 ... */
|
|
showHidedbmyControls(trmParams.environmentFlags & DCS_EVF_FKEYSSHOW, TRUE); /* jtf 3.20 */
|
|
resetSerial(&trmParams, TRUE, FALSE, 0);
|
|
resetEmul();
|
|
initChildSize(&termRect); /* mbbx 2.00: reset window pos... */
|
|
if(IsZoomed(hTermWnd))
|
|
SetFocus(NULL);
|
|
|
|
if(!(termData.flags & TF_HIDE))
|
|
showTerminal(TRUE, TRUE);
|
|
|
|
SetCursor(LoadCursor(NULL, IDC_ARROW));
|
|
}
|
|
|
|
gotCommEvent = TRUE;
|
|
return(TRUE);
|
|
}
|
|
|
|
|
|
/*---------------------------------------------------------------------------*/
|
|
/* termCloseFile() - [mbb] */
|
|
/*---------------------------------------------------------------------------*/
|
|
|
|
BOOL termCloseFile(VOID)
|
|
{
|
|
BOOL termCloseFile = TRUE;
|
|
|
|
if(activTerm)
|
|
{
|
|
if(termCloseFile = termCloseFileInternal())
|
|
termCloseWindow();
|
|
}
|
|
|
|
return(termCloseFile);
|
|
}
|
|
|
|
|
|
/*---------------------------------------------------------------------------*/
|
|
/* termCloseAll() - [mbb] */
|
|
/*---------------------------------------------------------------------------*/
|
|
|
|
BOOL termCloseAll(VOID)
|
|
{
|
|
return(termCloseFile());
|
|
}
|
|
|
|
|
|
/*---------------------------------------------------------------------------*/
|
|
/* termSaveFile() - [mbb] */
|
|
/*---------------------------------------------------------------------------*/
|
|
|
|
BOOL termSaveFile(BOOL bGetName)
|
|
{
|
|
BOOL termSaveFile = TRUE;
|
|
BYTE titleText[MINRESSTR];
|
|
BYTE filePath[PATHLEN+1];
|
|
INT hFile;
|
|
// sdj: was unref local - OFSTRUCT ofDummy;
|
|
BYTE fileName[PATHLEN];
|
|
|
|
SetCursor(LoadCursor(NULL, IDC_WAIT));
|
|
|
|
if(activTerm)
|
|
{
|
|
if(bGetName || (strlen(termData.fileName) == 0))
|
|
{
|
|
/* rjs swat - default to *.trm if no default term name */
|
|
if(strlen(termData.fileName))
|
|
strcpy(fileName, termData.fileName);
|
|
else
|
|
strcpy(fileName, "*.TRM");
|
|
/* end rjs swat */
|
|
|
|
/* mbbx 1.10: CUA... */
|
|
LoadString(hInst, !bGetName ? STR_SAVE : STR_SAVEAS, (LPSTR) titleText, MINRESSTR);
|
|
|
|
if(termData.filePath[strlen(termData.filePath) - 1] != '\\')
|
|
strcat(termData.filePath, "\\");
|
|
|
|
termSaveFile = FileOpen(termData.filePath, fileName, NULL, termData.fileExt,
|
|
titleText, 0, NULL, FO_PUTFILE | FO_FORCEEXTENT);
|
|
|
|
if(strrchr(fileName, '\\'))
|
|
strcpy(termData.fileName, strrchr(fileName, '\\') + 1);
|
|
else
|
|
strcpy(termData.fileName, fileName);
|
|
}
|
|
|
|
if(termSaveFile)
|
|
{
|
|
setFileDocData(FILE_NDX_SETTINGS, termData.filePath, termData.fileName, NULL, NULL); /* mbbx 2.00: no forced extents... */
|
|
|
|
if(termData.flags & TF_DEFTITLE)
|
|
{
|
|
strcpy(termData.title, termData.fileName);
|
|
SetWindowText(hTermWnd, (LPSTR) termData.fileName);
|
|
setAppTitle(); /* mbbx 1.00 */
|
|
}
|
|
|
|
#ifdef ORGCODE
|
|
strcpy(filePath, termData.filePath);
|
|
strcpy(filePath+strlen(filePath), termData.fileName);
|
|
#else
|
|
|
|
/* jtf 3.20 */
|
|
|
|
strcpy(filePath, termData.filePath);
|
|
strcpy(filePath+strlen(filePath), "\\");
|
|
strcpy(filePath+strlen(filePath), termData.fileName);
|
|
|
|
DEBOUT("termSaveFile: opening the file[%s]\n",filePath);
|
|
DEBOUT("termSaveFile: with flags [%lx]\n",O_WRONLY|O_TRUNC|O_CREAT|S_IWRITE);
|
|
#endif
|
|
if((hFile = _open((LPSTR) filePath, O_WRONLY | O_TRUNC | O_CREAT, S_IWRITE)) != -1)
|
|
{
|
|
if(termSaveFile = writeTermSettings(hFile))
|
|
termData.flags &= ~TF_CHANGED;
|
|
|
|
_close(hFile);
|
|
}
|
|
else
|
|
termSaveFile = FALSE;
|
|
|
|
if(!termSaveFile)
|
|
{
|
|
TF_ErrProc(STREWRERR, MB_OK | MB_ICONHAND, 999);
|
|
strcpy(termData.fileName, ""); /* rjs swat */
|
|
}
|
|
}
|
|
else
|
|
strcpy(termData.fileName, ""); /* rjs swat */
|
|
}
|
|
|
|
SetCursor(LoadCursor(NULL, IDC_ARROW));
|
|
|
|
return(termSaveFile);
|
|
}
|
|
|
|
|
|
/*---------------------------------------------------------------------------*/
|
|
/* termReadFile() - [mbb] */
|
|
/*---------------------------------------------------------------------------*/
|
|
|
|
BOOL NEAR termReadFile(BYTE *filePath)
|
|
{
|
|
BOOL termReadFile = FALSE;
|
|
INT hFile;
|
|
// sdj: was unref local - OFSTRUCT ofDummy;
|
|
// sdj: was unref local - LOGFONT logFont;
|
|
BYTE *junk;
|
|
|
|
/* jtf 3.20 */
|
|
DEBOUT("termReadFile: opening the file[%s]\n",filePath);
|
|
DEBOUT("termReadFile: with flags [%lx]\n",O_RDONLY);
|
|
|
|
junk = strrchr(filePath, '.');
|
|
AnsiUpper((LPSTR)junk);
|
|
|
|
if((hFile = _open((LPSTR) filePath, O_RDONLY)) != -1)
|
|
{
|
|
if(termReadFile = readTermSettings(hFile, _filelength(hFile)))
|
|
{
|
|
resetTermBuffer(); /* mbbx 1.03 */
|
|
icsResetTable((WORD) trmParams.language); /* mbbx 1.04: ics */
|
|
buildTermFont(); /* mbbx 2.00: font selection... */
|
|
trmParams.fResetDevice = TRUE; /* mbbx 2.00: network... */
|
|
trmParams.newDevRef = trmParams.comDevRef;
|
|
trmParams.comDevRef = ITMNOCOM;
|
|
}
|
|
|
|
_close(hFile);
|
|
}
|
|
else
|
|
TF_ErrProc(STRFERROPEN, MB_OK | MB_ICONHAND, 999);
|
|
|
|
return(termReadFile);
|
|
}
|
|
|
|
|
|
/*---------------------------------------------------------------------------*/
|
|
/* termCloseWindow() - [mbb] */
|
|
/*---------------------------------------------------------------------------*/
|
|
|
|
VOID NEAR termCloseWindow(VOID)
|
|
{
|
|
if(IsWindowVisible(hTermWnd))
|
|
{
|
|
if(childZoomStatus(0x0001, 0) && (countChildWindows(FALSE) == 1))
|
|
{
|
|
childZoomStatus(0, 0x4000);
|
|
ShowWindow(hTermWnd, SW_RESTORE);
|
|
}
|
|
/* added typecast to param 2 as HWND -sdj*/
|
|
SetWindowPos(hTermWnd,(HWND) 1, 0, 0, 0, 0, SWP_NOSIZE | SWP_NOMOVE | SWP_HIDEWINDOW);
|
|
selectTopWindow(); /* mbbx 1.03 ... */
|
|
}
|
|
}
|
|
|
|
|
|
/*---------------------------------------------------------------------------*/
|
|
/* termCloseFileInternal() - [mbb] */
|
|
/*---------------------------------------------------------------------------*/
|
|
|
|
BOOL NEAR termCloseFileInternal(VOID)
|
|
{
|
|
BOOL termCloseFileInternal = TRUE;
|
|
if(activTerm)
|
|
{
|
|
if(termData.flags & TF_NOCLOSE) /* mbbx 1.01 */
|
|
{
|
|
termCloseFileInternal = FALSE;
|
|
}
|
|
else if(xferFlag != XFRNONE)
|
|
{
|
|
if(termCloseFileInternal = (TF_ErrProc(STR_STOPXFER, MB_YESNO | MB_ICONEXCLAMATION, 0) == IDYES))
|
|
{
|
|
xferBytes = 0;
|
|
xferEndTimer = 0;
|
|
xferWaitEcho = FALSE;
|
|
xferStopped = TRUE;
|
|
xferEnd();
|
|
|
|
}
|
|
}
|
|
|
|
if(termCloseFileInternal)
|
|
{
|
|
if(termData.flags & TF_CHANGED)
|
|
{
|
|
switch(TF_ErrProc(STR_SAVECHANGES, MB_YESNOCANCEL | MB_ICONEXCLAMATION, 0))
|
|
{
|
|
case IDYES:
|
|
termCloseFileInternal = termSaveFile(FALSE); /* mbbx 2.00 */
|
|
break;
|
|
case IDCANCEL:
|
|
termCloseFileInternal = FALSE;
|
|
break;
|
|
}
|
|
}
|
|
|
|
if(termCloseFileInternal)
|
|
{
|
|
exitSerial();
|
|
activTerm = FALSE;
|
|
}
|
|
}
|
|
}
|
|
|
|
return(termCloseFileInternal);
|
|
}
|
|
|
|
|
|
/*---------------------------------------------------------------------------*/
|
|
/* TF_ErrProc() - */
|
|
/*---------------------------------------------------------------------------*/
|
|
|
|
INT TF_ErrProc(WORD errMess, WORD errType,WORD errCode)
|
|
{
|
|
// sdj: was unref local - INT result;
|
|
//BYTE temp1[PATHLEN]; /* rjs bugs 008 -> from 80 to 255 sdj:see below..*/
|
|
BYTE temp1[256]; /* sdj: rjs just said it should be 255 but left it 80!*/
|
|
/* sdj: with PATHLEN as 80, LoadString was corrupting the */
|
|
/* sdj: stack with a err popup of invalid rcbfile */
|
|
|
|
|
|
|
|
|
|
BYTE temp2[80];
|
|
|
|
|
|
GetWindowText(hItWnd, (LPSTR) temp2, 80);
|
|
if(!strchr(temp2, '-'))
|
|
{
|
|
sprintf(temp1, " - %s", termData.title);
|
|
strcpy(temp2+strlen(temp2), temp1);
|
|
}
|
|
|
|
/* NOTE: some messages use taskState.result to pass fileName to error handler... */
|
|
LoadString(hInst, errMess, (LPSTR) temp1, 255); /* rjs bugs 008 -> from 80 to 255 */
|
|
|
|
MessageBeep(0);
|
|
/* jtf 3.20 this was GetFocus() changed to GetActiveWindow() to stop rip */
|
|
return(MessageBox(GetActiveWindow(), (LPSTR) temp1, (LPSTR) temp2, errType));
|
|
}
|
|
|
|
|
|
/*---------------------------------------------------------------------------*/
|
|
/* */
|
|
/* SETTINGS FILE I/O ROUTINES */
|
|
/* */
|
|
/*---------------------------------------------------------------------------*/
|
|
|
|
/*---------------------------------------------------------------------------*/
|
|
/* readTermSettings() - [mbb] */
|
|
/*---------------------------------------------------------------------------*/
|
|
|
|
BOOL NEAR readTermSettings(INT hFile, WORD fileSize) /* mbbx 2.00: support NEW & OLD DCS and MS settings... */
|
|
//INT hFile;
|
|
//WORD fileSize; /* mbbx 2.00: was LONG */
|
|
{
|
|
BOOL readTermSettings = FALSE;
|
|
HANDLE hData;
|
|
LPSTR lpData;
|
|
BOOL flag; /* jtf 3.31 */
|
|
|
|
flag = TRUE; /* jtf 3.31 */
|
|
|
|
if((hData = GlobalAlloc(GMEM_MOVEABLE, (DWORD) fileSize)) != NULL)
|
|
{
|
|
if((lpData = GlobalLock(hData)) != NULL)
|
|
{
|
|
|
|
/******** this was to debug the 4K trm file/struct compact bug
|
|
now we can avoid this noise on the debug machine, so
|
|
that we get the satisfaction of resolving one more bug(5399)!
|
|
|
|
DbgPrint("sizeof (recTrm) = %lx\n",sizeof(trmParams));
|
|
DbgPrint("Address of trmParams.fileID = %lx\n",&(trmParams.fileID));
|
|
DbgPrint("Address of trmParams.newDevRef = %lx\n",&(trmParams.newDevRef));
|
|
DbgPrint("Address of trmParams.speed = %lx\n",&(trmParams.speed));
|
|
DbgPrint("Address of trmParams.answerBack = %lx\n",&(trmParams.answerBack));
|
|
DbgPrint("Address of trmParams.bufferLines= %lx\n",&(trmParams.bufferLines));
|
|
DbgPrint("Address of trmParams.retryCt = %lx\n",&(trmParams.retryCt));
|
|
DbgPrint("Address of trmParams.xWrapCol = %lx\n",&(trmParams.xWrapCol));
|
|
DbgPrint("Address of trmParams.xLinStr = %lx\n",&(trmParams.xLinStr));
|
|
DbgPrint("Address of trmParams.phone = %lx\n",&(trmParams.phone));
|
|
DbgPrint("Address of trmParams.dialSuffix = %lx\n",&(trmParams.dialSuffix));
|
|
|
|
|
|
**************/
|
|
|
|
|
|
if(_read(hFile, lpData, fileSize) == fileSize)
|
|
{
|
|
readTermSettings = TRUE; /* mbbx 2.00: read OLD DCS... */
|
|
|
|
|
|
switch(fileSize)
|
|
{
|
|
case sizeof(recTrmParams):
|
|
lmovmem(lpData, (LPBYTE) &trmParams, fileSize);
|
|
break;
|
|
case sizeof(MSSETTINGS):
|
|
convertMSToIBM((LPMSSETTINGS) lpData, &trmParams);
|
|
break;
|
|
default:
|
|
TF_ErrProc(STRFERRFILELENGTH, MB_OK | MB_ICONHAND, 999);
|
|
flag = FALSE; /* jtf 3.31 */
|
|
readTermSettings = FALSE;
|
|
break;
|
|
}
|
|
}
|
|
|
|
GlobalUnlock(hData);
|
|
}
|
|
|
|
GlobalFree(hData);
|
|
}
|
|
|
|
if ((!readTermSettings) && (flag))
|
|
TF_ErrProc(STRFERRREAD, MB_OK | MB_ICONHAND, 999);
|
|
|
|
return(readTermSettings);
|
|
}
|
|
|
|
/*---------------------------------------------------------------------------*/
|
|
/* convertMSToIBM() - [mbb] */
|
|
/*---------------------------------------------------------------------------*/
|
|
|
|
#define MS_HSSOFTWARE 0
|
|
#define MS_HSHARDWARE 1
|
|
#define MS_HSNONE 2
|
|
|
|
#define MS_IDS_NONE 0
|
|
#define MS_IDS_BRITISH 1
|
|
#define MS_IDS_DANISH 2
|
|
#define MS_IDS_FINNISH 3
|
|
#define MS_IDS_FRENCH 4
|
|
#define MS_IDS_CANADIAN 5
|
|
#define MS_IDS_GERMAN 6
|
|
#define MS_IDS_ITALIAN 7
|
|
#define MS_IDS_SPANISH 8
|
|
#define MS_IDS_SWEDISH 9
|
|
#define MS_IDS_SWISS 10
|
|
|
|
VOID NEAR convertMSToIBM(LPMSSETTINGS lpMSSettings, recTrmParams *ptrTrmParams)
|
|
{
|
|
|
|
ptrTrmParams->outCRLF = (BYTE) lpMSSettings->fNewLine;
|
|
ptrTrmParams->localEcho = (BYTE) lpMSSettings->fLocalEcho;
|
|
ptrTrmParams->lineWrap = (BYTE) lpMSSettings->fAutoWrap;
|
|
ptrTrmParams->bufferLines = lpMSSettings->clnBuf; /* jtf term */
|
|
|
|
ptrTrmParams->emulate = lpMSSettings->fVT52 ? ITMVT52 : ITMVT100;
|
|
ptrTrmParams->speed = lpMSSettings->iBaud; /* jtf term */
|
|
switch(lpMSSettings->iPort) /* mbbx 2.00: network... */
|
|
{
|
|
case 0: /* jtf term */
|
|
case 1:
|
|
ptrTrmParams->comDevRef = ITMWINCOM;
|
|
ptrTrmParams->comPortRef = ITMCOM1 + (lpMSSettings->iPort); /* jtf term */
|
|
break;
|
|
default:
|
|
ptrTrmParams->comDevRef = ITMNOCOM;
|
|
break;
|
|
}
|
|
|
|
switch(lpMSSettings->iByteSize)
|
|
{
|
|
case 4:
|
|
ptrTrmParams->dataBits = ITMDATA4;
|
|
break;
|
|
case 5:
|
|
ptrTrmParams->dataBits = ITMDATA5;
|
|
break;
|
|
case 6:
|
|
ptrTrmParams->dataBits = ITMDATA6;
|
|
break;
|
|
case 7:
|
|
ptrTrmParams->dataBits = ITMDATA7;
|
|
break;
|
|
default:
|
|
ptrTrmParams->dataBits = ITMDATA8;
|
|
break;
|
|
}
|
|
|
|
switch(lpMSSettings->iStopBits)
|
|
{
|
|
case ONE5STOPBITS:
|
|
ptrTrmParams->stopBits = ITMSTOP5;
|
|
break;
|
|
case TWOSTOPBITS:
|
|
ptrTrmParams->stopBits = ITMSTOP2;
|
|
break;
|
|
default:
|
|
ptrTrmParams->stopBits = ITMSTOP1;
|
|
break;
|
|
}
|
|
|
|
switch(lpMSSettings->iParity)
|
|
{
|
|
case EVENPARITY:
|
|
ptrTrmParams->parity = ITMEVENPARITY;
|
|
break;
|
|
case ODDPARITY:
|
|
ptrTrmParams->parity = ITMODDPARITY;
|
|
break;
|
|
case MARKPARITY:
|
|
ptrTrmParams->parity = ITMMARKPARITY;
|
|
break;
|
|
case SPACEPARITY:
|
|
ptrTrmParams->parity = ITMSPACEPARITY;
|
|
break;
|
|
default:
|
|
ptrTrmParams->parity = ITMNOPARITY;
|
|
break;
|
|
}
|
|
|
|
switch(lpMSSettings->iHandshake)
|
|
{
|
|
case MS_HSHARDWARE:
|
|
ptrTrmParams->flowControl = ITMHARDFLOW;
|
|
break;
|
|
case MS_HSNONE:
|
|
ptrTrmParams->flowControl = ITMNOFLOW;
|
|
break;
|
|
default:
|
|
ptrTrmParams->flowControl = ITMXONFLOW;
|
|
break;
|
|
}
|
|
|
|
ptrTrmParams->dlyRetry = (lpMSSettings->iAnswer + lpMSSettings->iToneWait);
|
|
lstrcpy(ptrTrmParams->phone, lpMSSettings->szPhNum);
|
|
|
|
switch(lpMSSettings->iCountry)
|
|
{
|
|
case MS_IDS_BRITISH:
|
|
ptrTrmParams->language = ICS_BRITISH;
|
|
break;
|
|
case MS_IDS_GERMAN:
|
|
ptrTrmParams->language = ICS_GERMAN;
|
|
break;
|
|
case MS_IDS_FRENCH:
|
|
ptrTrmParams->language = ICS_FRENCH;
|
|
break;
|
|
case MS_IDS_SWEDISH:
|
|
ptrTrmParams->language = ICS_SWEDISH;
|
|
break;
|
|
case MS_IDS_ITALIAN:
|
|
ptrTrmParams->language = ICS_ITALIAN;
|
|
break;
|
|
case MS_IDS_SPANISH:
|
|
ptrTrmParams->language = ICS_SPANISH;
|
|
break;
|
|
case MS_IDS_DANISH:
|
|
ptrTrmParams->language = ICS_DANISH;
|
|
break;
|
|
case MS_IDS_FINNISH:
|
|
ptrTrmParams->language = ICS_FINISH;
|
|
break;
|
|
case MS_IDS_CANADIAN:
|
|
ptrTrmParams->language = ICS_CANADIAN;
|
|
break;
|
|
case MS_IDS_SWISS:
|
|
ptrTrmParams->language = ICS_SWISS;
|
|
break;
|
|
default:
|
|
ptrTrmParams->language = ICS_NONE;
|
|
break;
|
|
}
|
|
}
|
|
|
|
|
|
/*---------------------------------------------------------------------------*/
|
|
/* writeTermSettings() - [scf] */
|
|
/*---------------------------------------------------------------------------*/
|
|
|
|
BOOL NEAR writeTermSettings(INT fileHandle)
|
|
{
|
|
BOOL writeTermSettings = FALSE;
|
|
HANDLE hSettings;
|
|
LPSETTINGS lpSettings;
|
|
|
|
if((hSettings = GlobalAlloc(GMEM_MOVEABLE, (DWORD) sizeof(recTrmParams))) != NULL)
|
|
{
|
|
if(lpSettings = (LPSETTINGS) GlobalLock(hSettings))
|
|
{
|
|
lmovmem((LPBYTE) &trmParams, (LPBYTE) lpSettings, sizeof(recTrmParams));
|
|
|
|
/* perform conversions here, if necessary... */
|
|
|
|
if(_write(fileHandle, (LPSTR) lpSettings, sizeof(recTrmParams)) == sizeof(recTrmParams)) /* jtf 3.15 */
|
|
writeTermSettings = TRUE;
|
|
|
|
GlobalUnlock(hSettings);
|
|
}
|
|
|
|
GlobalFree(hSettings);
|
|
}
|
|
|
|
return(writeTermSettings);
|
|
}
|