123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434 |
- #define BUILDING_OPENDOORS
- #include <stdio.h>
- #include <stdlib.h>
- #include <stdarg.h>
- #include <string.h>
- #include <ctype.h>
- #include <time.h>
- #include "OpenDoor.h"
- #include "ODStr.h"
- #include "ODCore.h"
- #include "ODGen.h"
- #include "ODCom.h"
- #include "ODPlat.h"
- #include "ODTypes.h"
- #include "ODScrn.h"
- #include "ODInQue.h"
- #include "ODKrnl.h"
- #include "ODInEx.h"
- #include "ODUtil.h"
- #define DROPFILE_TIME_LEEWAY 10
- #define MAX_RESPONSE_LEN 40
- #define RESPONSE_TIMEOUT 2000
- static char *apszEnvVarNames[] =
- {
- "RA",
- "QUICK",
- "PCB",
- "BBS",
- "WCNODEID",
- "SBBSNODE",
- };
- #define NUM_DIR_ENV_VARS DIM(apszEnvVarNames)
- static INT ODSearchInDir(char **papszFileNames, INT nNumFileNames,
- char *pszFound, char *pszDirectory);
- #ifdef ODPLAT_WIN32
- static BOOL ODSendModemCommand(char *pszCommand, int nRetries);
- static BOOL ODSendModemCommandOnce(char *pszCommand);
- static BOOL ODWaitForString(char *pszResponse, tODMilliSec ResponseTimeout);
- #endif
- #ifdef OD_DIAGNOSTICS
- static char szDebugWorkString[500] = "";
- #endif
- ODAPIDEF void ODCALL od_exit(INT nErrorLevel, BOOL bTermCall)
- {
- BYTE btCount;
- FILE *pfDropFile;
- time_t nMaxTime;
- time_t nDoorEndTime;
- void *pWindow = NULL;
- DWORD dwActiveMinutes;
- static BOOL bExiting = FALSE;
-
- TRACE(TRACE_API, "od_exit()");
- #if defined(OD_DIAGNOSTICS) && defined(ODPLAT_WIN32)
- if(od_control.od_internal_debug)
- {
- MessageBox(NULL, "Starting up od_exit()", "OpenDoors Diagnostics",
- MB_OK);
- }
- #endif
-
- if(bExiting)
- {
- return;
- }
- bExiting = TRUE;
-
-
- if(!bODInitialized) od_init();
-
- od_control.user_timelimit += od_control.od_maxtime_deduction;
-
- time(&nDoorEndTime);
- ODDWordDivide(&dwActiveMinutes, NULL, nDoorEndTime - nStartupUnixTime, 60L);
- od_control.user_time_used += ((nInitialRemaining
- - od_control.user_timelimit) - (int)dwActiveMinutes);
-
- od_control.baud = dwFileBPS;
-
- if(od_control.od_before_exit != NULL)
- {
-
- (*od_control.od_before_exit)();
- }
- if(bTermCall && od_control.od_hanging_up != NULL)
- {
- pWindow = ODScrnShowMessage(od_control.od_hanging_up, 0);
- }
- else if(!bTermCall)
- {
- pWindow = ODScrnShowMessage(od_control.od_exiting, 0);
- }
- if(szOriginalDir != NULL)
- {
- ODDirChangeCurrent(szOriginalDir);
- free(szOriginalDir);
- szOriginalDir=NULL;
- }
- if(od_control.od_extended_info)
- {
- ODMakeFilename(szExitinfoBBSPath, szExitinfoBBSPath, "EXITINFO.BBS",
- sizeof(szExitinfoBBSPath));
- if((pfDropFile = fopen(szExitinfoBBSPath, "r+b")) != NULL)
- {
- switch(od_control.od_info_type)
- {
- case RA2EXITINFO:
- pRA2ExitInfoRecord->baud = (unsigned int)od_control.baud;
- pRA2ExitInfoRecord->num_calls = od_control.system_calls;
- ODStringCToPascal(pRA2ExitInfoRecord->last_caller,35,od_control.system_last_caller);
- ODStringCToPascal(pRA2ExitInfoRecord->sLastHandle,35,od_control.system_last_handle);
- ODStringCToPascal(pRA2ExitInfoRecord->start_date,8,od_control.timelog_start_date);
- memcpy(&pRA2ExitInfoRecord->busyperhour,&od_control.timelog_busyperhour,62);
- ODStringCToPascal(pRA2ExitInfoRecord->name,35,od_control.user_name);
- ODStringCToPascal(pRA2ExitInfoRecord->location,25,od_control.user_location);
- ODStringCToPascal(pRA2ExitInfoRecord->organisation,50,od_control.user_org);
- for(btCount=0;btCount<3;++btCount)
- ODStringCToPascal(pRA2ExitInfoRecord->address[btCount],50,od_control.user_address[btCount]);
- ODStringCToPascal(pRA2ExitInfoRecord->handle,35,od_control.user_handle);
- ODStringCToPascal(pRA2ExitInfoRecord->comment,80,od_control.user_comment);
- pRA2ExitInfoRecord->password_crc=od_control.user_pwd_crc;
- ODStringCToPascal(pRA2ExitInfoRecord->dataphone,15,od_control.user_dataphone);
- ODStringCToPascal(pRA2ExitInfoRecord->homephone,15,od_control.user_homephone);
- ODStringCToPascal(pRA2ExitInfoRecord->lasttime,5,od_control.user_lasttime);
- ODStringCToPascal(pRA2ExitInfoRecord->lastdate,8,od_control.user_lastdate);
- pRA2ExitInfoRecord->attrib=od_control.user_attribute;
- pRA2ExitInfoRecord->attrib2=od_control.user_attrib2;
- memcpy(&pRA2ExitInfoRecord->flags,&od_control.user_flags,14);
- pRA2ExitInfoRecord->sec=od_control.user_security;
- pRA2ExitInfoRecord->lastread=od_control.user_lastread;
- memcpy(&pRA2ExitInfoRecord->nocalls,&od_control.user_numcalls,29);
- pRA2ExitInfoRecord->group=od_control.user_group;
- memcpy(&pRA2ExitInfoRecord->combinedrecord,&od_control.user_combinedrecord,200);
- ODStringCToPascal(pRA2ExitInfoRecord->firstcall,8,od_control.user_firstcall);
- ODStringCToPascal(pRA2ExitInfoRecord->birthday,8,od_control.user_birthday);
- ODStringCToPascal(pRA2ExitInfoRecord->subdate,8,od_control.user_subdate);
- pRA2ExitInfoRecord->screenwidth=od_control.user_screenwidth;
- pRA2ExitInfoRecord->language=od_control.user_language;
- pRA2ExitInfoRecord->dateformat=od_control.user_date_format;
- ODStringCToPascal(pRA2ExitInfoRecord->forwardto,35,od_control.user_forward_to);
- memcpy(&pRA2ExitInfoRecord->msgarea,&od_control.user_msg_area,15);
- pRA2ExitInfoRecord->sex = (od_control.user_sex == 'M') ? 1 : 2;
- pRA2ExitInfoRecord->btAttribute3=od_control.user_attrib3;
- ODStringCToPascal(pRA2ExitInfoRecord->sPassword,15,od_control.user_password);
- pRA2ExitInfoRecord->status=od_control.event_status;
- ODStringCToPascal(pRA2ExitInfoRecord->starttime,5,od_control.event_starttime);
- memcpy(&pRA2ExitInfoRecord->errorlevel,&od_control.event_errorlevel,3);
- ODStringCToPascal(pRA2ExitInfoRecord->lasttimerun,8,od_control.event_last_run);
- memcpy(&pRA2ExitInfoRecord->netmailentered,&od_control.user_netmailentered,2);
- ODStringCToPascal(pRA2ExitInfoRecord->logintime,5,od_control.user_logintime);
- ODStringCToPascal(pRA2ExitInfoRecord->logindate,8,od_control.user_logindate);
- memcpy(&pRA2ExitInfoRecord->timelimit,&od_control.user_timelimit,6);
- memcpy(&pRA2ExitInfoRecord->userrecord,&od_control.user_num,8);
- ODStringCToPascal(pRA2ExitInfoRecord->timeofcreation,5,od_control.user_timeofcreation);
- pRA2ExitInfoRecord->logonpasswordcrc=od_control.user_logon_pwd_crc;
- pRA2ExitInfoRecord->wantchat=od_control.user_wantchat;
- pRA2ExitInfoRecord->deducted_time=od_control.user_deducted_time;
- for(btCount=0;btCount<50;++btCount)
- ODStringCToPascal(pRA2ExitInfoRecord->menustack[btCount],8,od_control.user_menustack[btCount]);
- pRA2ExitInfoRecord->menustackpointer=od_control.user_menustackpointer;
- memcpy(&pRA2ExitInfoRecord->error_free,&od_control.user_error_free,3);
- ODStringCToPascal(pRA2ExitInfoRecord->emsi_crtdef,40,od_control.user_emsi_crtdef);
- ODStringCToPascal(pRA2ExitInfoRecord->emsi_protocols,40,od_control.user_emsi_protocols);
- ODStringCToPascal(pRA2ExitInfoRecord->emsi_capabilities,40,od_control.user_emsi_capabilities);
- ODStringCToPascal(pRA2ExitInfoRecord->emsi_requests,40,od_control.user_emsi_requests);
- ODStringCToPascal(pRA2ExitInfoRecord->emsi_software,40,od_control.user_emsi_software);
- memcpy(&pRA2ExitInfoRecord->hold_attr1,&od_control.user_hold_attr1,3);
- ODStringCToPascal(pRA2ExitInfoRecord->page_reason,77,od_control.user_reasonforchat);
- if(bRAStatus)
- {
- pRA2ExitInfoRecord->status_line = btCurrentStatusLine + 1;
- }
- ODStringCToPascal(pRA2ExitInfoRecord->last_cost_menu,9,od_control.user_last_cost_menu);
- pRA2ExitInfoRecord->menu_cost_per_min=od_control.user_menu_cost;
- pRA2ExitInfoRecord->has_rip=od_control.user_rip;
- pRA2ExitInfoRecord->btRIPVersion=od_control.user_rip_ver;
- fwrite(pRA2ExitInfoRecord,1,sizeof(tRA2ExitInfoRecord),pfDropFile);
- free(pRA2ExitInfoRecord);
- break;
- case EXITINFO:
- ODStringCToPascal(pExitInfoRecord->bbs.ra.timeofcreation,5,od_control.user_timeofcreation);
- ODStringCToPascal(pExitInfoRecord->bbs.ra.logonpassword,15,od_control.user_logonpassword);
- pExitInfoRecord->bbs.ra.wantchat=od_control.user_wantchat;
- ODWriteExitInfoPrimitive(pfDropFile,476);
- break;
- case RA1EXITINFO:
- pExtendedExitInfo->deducted_time=od_control.user_deducted_time;
- for(btCount=0;btCount<50;++btCount)
- {
- ODStringCToPascal(pExtendedExitInfo->menustack[btCount],8,od_control.user_menustack[btCount]);
- }
- pExtendedExitInfo->menustackpointer=od_control.user_menustackpointer;
- ODStringCToPascal(pExtendedExitInfo->userhandle,35,od_control.user_handle);
- ODStringCToPascal(pExtendedExitInfo->comment,80,od_control.user_comment);
- ODStringCToPascal(pExtendedExitInfo->firstcall,8,od_control.user_firstcall);
- memcpy(pExtendedExitInfo->combinedrecord,od_control.user_combinedrecord,25);
- ODStringCToPascal(pExtendedExitInfo->birthday,8,od_control.user_birthday);
- ODStringCToPascal(pExtendedExitInfo->subdate,8,od_control.user_subdate);
- pExtendedExitInfo->screenwidth=od_control.user_screenwidth;
- pExtendedExitInfo->msgarea = (BYTE)od_control.user_msg_area;
- pExtendedExitInfo->filearea = (BYTE)od_control.user_file_area;
- pExtendedExitInfo->language=od_control.user_language;
- pExtendedExitInfo->dateformat=od_control.user_date_format;
- ODStringCToPascal(pExtendedExitInfo->forwardto,35,od_control.user_forward_to);
- memcpy(&pExtendedExitInfo->error_free,&od_control.user_error_free,3);
- ODStringCToPascal(pExtendedExitInfo->emsi_crtdef,40,od_control.user_emsi_crtdef);
- ODStringCToPascal(pExtendedExitInfo->emsi_protocols,40,od_control.user_emsi_protocols);
- ODStringCToPascal(pExtendedExitInfo->emsi_capabilities,40,od_control.user_emsi_capabilities);
- ODStringCToPascal(pExtendedExitInfo->emsi_requests,40,od_control.user_emsi_requests);
- ODStringCToPascal(pExtendedExitInfo->emsi_software,40,od_control.user_emsi_software);
- memcpy(&pExtendedExitInfo->hold_attr1,&od_control.user_hold_attr1,3);
- ODStringCToPascal(pExitInfoRecord->bbs.ra.timeofcreation,5,od_control.user_timeofcreation);
- ODStringCToPascal(pExitInfoRecord->bbs.ra.logonpassword,15,od_control.user_logonpassword);
- pExitInfoRecord->bbs.ra.wantchat=od_control.user_wantchat;
- ODWriteExitInfoPrimitive(pfDropFile,476);
- fwrite(pExtendedExitInfo,1,1017,pfDropFile);
- free(pExtendedExitInfo);
- break;
- case QBBS275EXITINFO:
- pExitInfoRecord->elapsed=nInitialElapsed;
- pExitInfoRecord->bbs.qbbs.qwantchat=od_control.user_wantchat;
- pExitInfoRecord->bbs.qbbs.gosublevel=od_control.user_menustackpointer;
- for(btCount=0;btCount<pExitInfoRecord->bbs.qbbs.gosublevel;++btCount)
- {
- ODStringCToPascal(pExitInfoRecord->bbs.qbbs.menustack[btCount],8,od_control.user_menustack[btCount]);
- }
- ODStringCToPascal(pExitInfoRecord->bbs.qbbs.menu,8,od_control.user_menustack[od_control.user_menustackpointer]);
- pExitInfoRecord->bbs.qbbs.externlogoff = bTermCall ? 1 : 0;
- pExitInfoRecord->bbs.qbbs.ripactive = od_control.user_rip ? 1 : 0;
- ODWriteExitInfoPrimitive(pfDropFile,644);
- }
- fclose(pfDropFile);
- }
- }
- switch(od_control.od_info_type)
- {
- case DOORSYS_GAP:
- case DOORSYS_WILDCAT:
- pfDropFile=fopen(szDropFilePath,"w");
- if(od_control.baud==0L)
- {
- fprintf(pfDropFile,"COM0:\n");
- }
- else
- {
- fprintf(pfDropFile,"COM%d:\n",od_control.port+1);
- }
- fprintf(pfDropFile,"%s",apszDropFileInfo[0]);
- fprintf(pfDropFile,"%s",apszDropFileInfo[1]);
- fprintf(pfDropFile,"%u\n",od_control.od_node);
- switch(btDoorSYSLock)
- {
- case 0:
- fprintf(pfDropFile,"%lu\n",od_control.baud);
- break;
- case 1:
- fprintf(pfDropFile,"N\n");
- break;
- case 2:
- fprintf(pfDropFile,"Y\n");
- }
- fprintf(pfDropFile,"%s",apszDropFileInfo[3]);
- fprintf(pfDropFile,"%s",apszDropFileInfo[4]);
- fprintf(pfDropFile,"%s",apszDropFileInfo[5]);
- fprintf(pfDropFile,"%s",apszDropFileInfo[22]);
- strupr(od_control.user_name);
- fprintf(pfDropFile,"%s\n",od_control.user_name);
- fprintf(pfDropFile,"%s\n",od_control.user_location);
- fprintf(pfDropFile,"%s\n",od_control.user_homephone);
- fprintf(pfDropFile,"%s\n",od_control.user_dataphone);
- fprintf(pfDropFile,"%s\n",od_control.user_password);
- fprintf(pfDropFile,"%u\n",od_control.user_security);
- fprintf(pfDropFile,"%d\n",od_control.user_numcalls);
- fprintf(pfDropFile,"%s\n",od_control.user_lastdate);
- fprintf(pfDropFile,"%u\n",(signed int)od_control.user_timelimit*60);
- fprintf(pfDropFile,"%d\n",od_control.user_timelimit);
- if(od_control.user_rip)
- {
- fprintf(pfDropFile,"RIP\n");
- }
- else if(od_control.user_ansi)
- {
- fprintf(pfDropFile,"GR\n");
- }
- else
- {
- fprintf(pfDropFile,"NG\n");
- }
- fprintf(pfDropFile,"%d\n",od_control.user_screen_length);
- fprintf(pfDropFile,"%s",apszDropFileInfo[8]);
- fprintf(pfDropFile,"%s",apszDropFileInfo[9]);
- fprintf(pfDropFile,"%s",apszDropFileInfo[10]);
- fprintf(pfDropFile,"%s\n",od_control.user_subdate);
- fprintf(pfDropFile,"%u\n",od_control.user_num);
- fprintf(pfDropFile,"%s",apszDropFileInfo[6]);
- fprintf(pfDropFile,"%u\n",od_control.user_uploads);
- fprintf(pfDropFile,"%u\n",od_control.user_downloads);
- fprintf(pfDropFile,"%u\n",od_control.user_todayk);
- fprintf(pfDropFile,"%s",apszDropFileInfo[21]);
- if(od_control.od_info_type==DOORSYS_WILDCAT)
- {
- fprintf(pfDropFile,"%s\n",od_control.user_birthday);
- fprintf(pfDropFile,"%s",apszDropFileInfo[11]);
- fprintf(pfDropFile,"%s",apszDropFileInfo[12]);
- fprintf(pfDropFile,"%s\n",od_control.sysop_name);
- strupr(od_control.user_handle);
- fprintf(pfDropFile,"%s\n",od_control.user_handle);
- fprintf(pfDropFile,"%s\n",od_control.event_starttime);
- if(od_control.user_error_free)
- fprintf(pfDropFile,"Y\n");
- else
- fprintf(pfDropFile,"N\n");
- fprintf(pfDropFile,"%s",apszDropFileInfo[7]);
- fprintf(pfDropFile,"%s",apszDropFileInfo[13]);
- fprintf(pfDropFile,"%s",apszDropFileInfo[14]);
- fprintf(pfDropFile,"%s",apszDropFileInfo[15]);
- fprintf(pfDropFile,"%s",apszDropFileInfo[16]);
- fprintf(pfDropFile,"%s\n",od_control.user_logintime);
- fprintf(pfDropFile,"%s\n",od_control.user_lasttime);
- fprintf(pfDropFile,"%s",apszDropFileInfo[18]);
- fprintf(pfDropFile,"%s",apszDropFileInfo[19]);
- fprintf(pfDropFile,"%u\n",od_control.user_upk);
- fprintf(pfDropFile,"%u\n",od_control.user_downk);
- fprintf(pfDropFile,"%s\n",od_control.user_comment);
- fprintf(pfDropFile,"%s",apszDropFileInfo[20]);
- fprintf(pfDropFile,"%u\n",od_control.user_messages);
- }
- fclose(pfDropFile);
- break;
- case DOORSYS_DRWY:
- pfDropFile=fopen(szDropFilePath,"w");
- fprintf(pfDropFile,"%s\n",od_control.user_name);
- if(od_control.baud==0L)
- {
- fprintf(pfDropFile,"-1\n");
- }
- else
- {
- fprintf(pfDropFile,"%d\n",od_control.port+1);
- }
- fprintf(pfDropFile,"%lu\n",od_control.baud);
- fprintf(pfDropFile,"%d\n",od_control.user_timelimit);
- if(od_control.user_ansi)
- {
- fprintf(pfDropFile,"G\n");
- }
- else
- {
- fprintf(pfDropFile,"M\n");
- }
- fclose(pfDropFile);
- break;
- case SFDOORSDAT:
- pfDropFile=fopen(szDropFilePath,"w");
- fprintf(pfDropFile,"%u\n",od_control.user_num);
- fprintf(pfDropFile,"%s\n",od_control.user_name);
- fprintf(pfDropFile,"%s\n",od_control.user_password);
- fprintf(pfDropFile,"%s",apszDropFileInfo[0]);
- fprintf(pfDropFile,"%lu\n",od_control.baud);
- fprintf(pfDropFile,"%d\n",od_control.port+1);
- fprintf(pfDropFile,"%d\n",od_control.user_timelimit);
- fprintf(pfDropFile,"%s",apszDropFileInfo[13]);
- fprintf(pfDropFile,"%s",apszDropFileInfo[14]);
- if(od_control.user_ansi)
- {
- fprintf(pfDropFile,"TRUE\n");
- }
- else
- {
- fprintf(pfDropFile,"FALSE\n");
- }
- fprintf(pfDropFile,"%u\n",od_control.user_security);
- fprintf(pfDropFile,"%u\n",od_control.user_uploads);
- fprintf(pfDropFile,"%u\n",od_control.user_downloads);
- fprintf(pfDropFile,"%s",apszDropFileInfo[1]);
- fprintf(pfDropFile,"%s",apszDropFileInfo[2]);
- fprintf(pfDropFile,"%s",apszDropFileInfo[3]);
- if(od_control.sysop_next)
- {
- fprintf(pfDropFile,"TRUE\n");
- }
- else
- {
- fprintf(pfDropFile,"FALSE\n");
- }
- fprintf(pfDropFile,"%s",apszDropFileInfo[4]);
- fprintf(pfDropFile,"%s",apszDropFileInfo[5]);
- fprintf(pfDropFile,"%s",apszDropFileInfo[6]);
- if(od_control.user_error_free)
- {
- fprintf(pfDropFile,"TRUE\n");
- }
- else
- {
- fprintf(pfDropFile,"FALSE\n");
- }
- fprintf(pfDropFile,"%u\n",od_control.user_msg_area);
- fprintf(pfDropFile,"%u\n",od_control.user_file_area);
- fprintf(pfDropFile,"%u\n",od_control.od_node);
- fprintf(pfDropFile,"%s",apszDropFileInfo[10]);
- fprintf(pfDropFile,"%s",apszDropFileInfo[11]);
- fprintf(pfDropFile,"%s",apszDropFileInfo[12]);
- fprintf(pfDropFile,"%u\n",od_control.user_todayk);
- fprintf(pfDropFile,"%u\n",od_control.user_upk);
- fprintf(pfDropFile,"%u\n",od_control.user_downk);
- fprintf(pfDropFile,"%s\n",od_control.user_homephone);
- fprintf(pfDropFile,"%s\n",od_control.user_location);
- if(apszDropFileInfo[15][0]!='\0')
- {
- fprintf(pfDropFile, "%s", apszDropFileInfo[15]);
- fprintf(pfDropFile, od_control.user_rip ? "TRUE\n" : "FALSE\n");
- fprintf(pfDropFile, od_control.user_wantchat ? "TRUE\n"
- : "FALSE\n");
- fprintf(pfDropFile, "%s", apszDropFileInfo[17]);
- fprintf(pfDropFile, "%d\n", od_control.od_com_irq);
- fprintf(pfDropFile, "%d\n", od_control.od_com_address);
- fprintf(pfDropFile, "%s", apszDropFileInfo[18]);
- }
- fclose(pfDropFile);
- break;
- case CHAINTXT:
- pfDropFile=fopen(szDropFilePath,"w");
- fprintf(pfDropFile,"%d\n",od_control.user_num);
- fprintf(pfDropFile,"%s\n",od_control.user_handle);
- fprintf(pfDropFile,"%s\n",od_control.user_name);
- fprintf(pfDropFile,"%s\n",od_control.user_callsign);
- fprintf(pfDropFile,"%s",apszDropFileInfo[0]);
- fprintf(pfDropFile,"%c\n",od_control.user_sex);
- fprintf(pfDropFile,"%s",apszDropFileInfo[1]);
- fprintf(pfDropFile,"%s\n",od_control.user_lastdate);
- fprintf(pfDropFile,"%d\n",od_control.user_screenwidth);
- fprintf(pfDropFile,"%d\n",od_control.user_screen_length);
- fprintf(pfDropFile,"%d\n",od_control.user_security);
- fprintf(pfDropFile,"%d\n",bIsSysop);
- fprintf(pfDropFile,"%d\n",bIsCoSysop);
- fprintf(pfDropFile,"%d\n",od_control.user_ansi);
- if(od_control.baud==0L)
- {
- fprintf(pfDropFile,"0\n");
- }
- else
- {
- fprintf(pfDropFile,"1\n");
- }
- fprintf(pfDropFile," %d.00\n",od_control.user_timelimit*60);
- fprintf(pfDropFile,"%s",apszDropFileInfo[3]);
- fprintf(pfDropFile,"%s",apszDropFileInfo[4]);
- fprintf(pfDropFile,"%s",apszDropFileInfo[5]);
- if(od_control.baud==0L)
- {
- fprintf(pfDropFile,"KB\n");
- }
- else
- {
- fprintf(pfDropFile,"%lu\n",od_control.baud);
- }
- fprintf(pfDropFile,"%d\n",od_control.port+1);
- fprintf(pfDropFile,"%s",apszDropFileInfo[6]);
- fprintf(pfDropFile,"%s\n",od_control.user_password);
- fprintf(pfDropFile,"%s",apszDropFileInfo[2]);
- fprintf(pfDropFile,"%s",apszDropFileInfo[7]);
- fprintf(pfDropFile,"%s",apszDropFileInfo[8]);
- fprintf(pfDropFile,"%s",apszDropFileInfo[9]);
- fprintf(pfDropFile,"%s",apszDropFileInfo[10]);
- fprintf(pfDropFile,"%s",apszDropFileInfo[11]);
- fprintf(pfDropFile,"%s",apszDropFileInfo[12]);
- fclose(pfDropFile);
- break;
- case TRIBBSSYS:
- pfDropFile = fopen(szDropFilePath, "w");
- fprintf(pfDropFile, "%u\n", od_control.user_num);
- fprintf(pfDropFile, "%s\n", od_control.user_name);
- fprintf(pfDropFile, "%s\n", od_control.user_password);
- fprintf(pfDropFile, "%u\n", od_control.user_security);
- fprintf(pfDropFile, "%c\n", od_control.user_expert ? 'Y' : 'N');
- fprintf(pfDropFile, "%c\n", od_control.user_ansi ? 'Y' : 'N');
- fprintf(pfDropFile, "%d\n", od_control.user_timelimit);
- fprintf(pfDropFile, "%s\n", od_control.user_homephone);
- fprintf(pfDropFile, "%s\n", od_control.user_location);
- od_control.user_birthday[2] = '/';
- od_control.user_birthday[5] = '/';
- fprintf(pfDropFile, "%s\n", od_control.user_birthday);
- fprintf(pfDropFile, "%d\n", od_control.od_node);
- fprintf(pfDropFile, "%d\n", od_control.port + 1);
- fprintf(pfDropFile, "%lu\n", od_control.od_connect_speed);
- fprintf(pfDropFile, "%lu\n", od_control.baud);
- fprintf(pfDropFile, "%c\n", (od_control.od_com_flow_control
- == COM_RTSCTS_FLOW) ? 'Y' : 'N');
- fprintf(pfDropFile, "%c\n", od_control.user_error_free ? 'Y' : 'N');
- fprintf(pfDropFile, "%s\n", od_control.system_name);
- fprintf(pfDropFile, "%s\n", od_control.sysop_name);
- fprintf(pfDropFile, "%s\n", od_control.user_handle);
- fprintf(pfDropFile, "%c\n", od_control.user_rip ? 'Y' : 'N');
- fclose(pfDropFile);
- break;
- }
-
- for(btCount=0;btCount<25;++btCount)
- {
- free(apszDropFileInfo[btCount]);
- }
-
- if(pfLogClose != NULL)
- {
-
- (*pfLogClose)(nErrorLevel);
- }
-
- if(od_control.baud && bTermCall)
- {
- BOOL bCarrier;
-
- ODWaitDrain(10000);
-
- ODComSetDTR(hSerialPort, FALSE);
- nMaxTime = time(NULL) + 5L;
- do
- {
- ODComCarrier(hSerialPort, &bCarrier);
- } while(bCarrier && time(NULL) <= nMaxTime);
-
- ODComSetDTR(hSerialPort, TRUE);
- }
-
-
- #ifdef ODPLAT_WIN32
-
-
- if(!bTermCall && od_control.baud)
- {
- ODInExDisableDTR();
- }
- #endif
-
-
- ODScrnRemoveMessage(pWindow);
- #ifndef ODPLAT_WIN32
-
- ODScrnSetBoundary(1,1,80,25);
-
- ODScrnSetAttribute(0x07);
-
- if(od_control.od_clear_on_exit)
- {
- ODScrnClear();
- }
- else
- {
- ODScrnSetCursorPos(1, 1);
- }
- #endif
- #if defined(OD_DIAGNOSTICS) && defined(ODPLAT_WIN32)
- if(od_control.od_internal_debug)
- {
- MessageBox(NULL, "Terminating kernel threads", "OpenDoors Diagnostics",
- MB_OK);
- }
- #endif
-
- ODKrnlShutdown();
- #if defined(OD_DIAGNOSTICS) && defined(ODPLAT_WIN32)
- if(od_control.od_internal_debug)
- {
- MessageBox(NULL, "Shutting down local screen", "OpenDoors Diagnostics",
- MB_OK);
- }
- #endif
-
- ODScrnShutdown();
- #if defined(OD_DIAGNOSTICS) && defined(ODPLAT_WIN32)
- if(od_control.od_internal_debug)
- {
- MessageBox(NULL, "Performing any final serial port deallocation",
- "OpenDoors Diagnostics", MB_OK);
- }
- #endif
-
- if(od_control.baud != 0)
- {
-
- ODComClose(hSerialPort);
-
- ODComFree(hSerialPort);
- }
- #if defined(OD_DIAGNOSTICS) && defined(ODPLAT_WIN32)
- if(od_control.od_internal_debug)
- {
- MessageBox(NULL, "Deallocating common queue", "OpenDoors Diagnostics",
- MB_OK);
- }
- #endif
-
- ODInQueueFree(hODInputQueue);
- #if defined(OD_DIAGNOSTICS) && defined(ODPLAT_WIN32)
- if(od_control.od_internal_debug)
- {
- MessageBox(NULL, "Going to inactive mode", "OpenDoors Diagnostics",
- MB_OK);
- }
- #endif
-
- bODInitialized = FALSE;
-
- bExiting = FALSE;
-
-
- if(od_control.od_noexit) return;
-
- if(bPreOrExit) return;
- #if defined(OD_DIAGNOSTICS) && defined(ODPLAT_WIN32)
- if(od_control.od_internal_debug)
- {
- MessageBox(NULL, "Terminating process", "OpenDoors Diagnostics", MB_OK);
- }
- #endif
-
- ODProcessExit(nErrorLevel);
- }
- INT ODSearchForDropFile(char **papszFileNames, INT nNumFileNames,
- char *pszFound, char *pszDirectory)
- {
- BYTE btCount;
- char *pszEnvVarSetting;
- INT nResult;
- ASSERT(papszFileNames != NULL);
- ASSERT(nNumFileNames > 0);
- ASSERT(pszFound != NULL);
-
-
- if(strlen(od_control.info_path) != 0)
- {
- if((nResult = ODSearchInDir(papszFileNames, nNumFileNames, pszFound,
- od_control.info_path)) != -1)
- {
- if(pszDirectory != NULL) strcpy(pszDirectory, od_control.info_path);
- return(nResult);
- }
- }
-
- if((nResult = ODSearchInDir(papszFileNames, nNumFileNames, pszFound,
- "."DIRSEP_STR)) != -1)
- {
- if(pszDirectory != NULL) strcpy(pszDirectory, "."DIRSEP_STR);
- return(nResult);
- }
-
-
-
- ASSERT(DIM(apszEnvVarNames) == NUM_DIR_ENV_VARS);
- for(btCount = 0; btCount < NUM_DIR_ENV_VARS; ++btCount)
- {
- if((pszEnvVarSetting = (char *)getenv(apszEnvVarNames[btCount])) != NULL)
- {
- if((nResult = ODSearchInDir(papszFileNames, nNumFileNames, pszFound,
- pszEnvVarSetting)) != -1)
- {
- if(pszDirectory != NULL) strcpy(pszDirectory,pszEnvVarSetting);
- return(nResult);
- }
- }
- }
- return(-1);
- }
- static INT ODSearchInDir(char **papszFileNames, INT nNumFileNames,
- char *pszFound, char *pszDirectory)
- {
- BYTE btCount;
- char szFullName[80];
- INT nFound = -1;
- tODDirHandle hDir;
- tODDirEntry DirEntry;
- time_t LatestTime = 0;
- ASSERT(papszFileNames != NULL);
- ASSERT(nNumFileNames > 0);
- ASSERT(pszFound != NULL);
- ASSERT(pszDirectory != NULL);
- for(btCount=0; btCount < nNumFileNames; ++btCount)
- {
-
-
- if(btCount == 2 && nFound == 1)
- {
- continue;
- }
- ASSERT(papszFileNames[btCount] != NULL);
- ODMakeFilename(szFullName, pszDirectory, (char *)papszFileNames[btCount],
- sizeof(szFullName));
-
- if(ODDirOpen(szFullName, DIR_ATTRIB_NORMAL | DIR_ATTRIB_ARCH, &hDir)
- == kODRCSuccess)
- {
-
- ODDirRead(hDir, &DirEntry);
- if(nFound == -1
- || DirEntry.LastWriteTime > LatestTime + DROPFILE_TIME_LEEWAY)
- {
- if(!ODFileAccessMode(szFullName, 4))
- {
- nFound=btCount;
- LatestTime = DirEntry.LastWriteTime;
- }
- }
-
- ODDirClose(hDir);
- }
- }
- if(nFound != -1)
- {
- ODMakeFilename(pszFound, pszDirectory, (char *)papszFileNames[nFound],
- 160);
- }
- return(nFound);
- }
- BOOL ODReadExitInfoPrimitive(FILE *pfDropFile, INT nCount)
- {
- if((pExitInfoRecord=malloc(sizeof(tExitInfoRecord)))==NULL) return(FALSE);
- if(fread(pExitInfoRecord,1,nCount,pfDropFile)!=(size_t)nCount)
- {
- return(FALSE);
- }
-
-
-
-
-
-
-
- od_control.baud=pExitInfoRecord->baud;
- od_control.system_calls=pExitInfoRecord->num_calls;
- ODStringPascalToC(od_control.system_last_caller,pExitInfoRecord->last_caller,35);
- ODStringPascalToC(od_control.timelog_start_date,pExitInfoRecord->start_date,8);
- memcpy(&od_control.timelog_busyperhour,&pExitInfoRecord->busyperhour,62);
- ODStringPascalToC(od_control.user_name,pExitInfoRecord->uname,35);
- ODStringPascalToC(od_control.user_location,pExitInfoRecord->uloc,25);
- ODStringPascalToC(od_control.user_password,pExitInfoRecord->password,15);
- ODStringPascalToC(od_control.user_dataphone,pExitInfoRecord->dataphone,12);
- ODStringPascalToC(od_control.user_homephone,pExitInfoRecord->homephone,12);
- ODStringPascalToC(od_control.user_lasttime,pExitInfoRecord->lasttime,5);
- ODStringPascalToC(od_control.user_lastdate,pExitInfoRecord->lastdate,8);
- memcpy(&od_control.user_attribute,&pExitInfoRecord->attrib,5);
- od_control.user_net_credit=pExitInfoRecord->credit;
- od_control.user_pending=pExitInfoRecord->pending;
- od_control.user_messages=pExitInfoRecord->posted;
- od_control.user_lastread=pExitInfoRecord->lastread;
- od_control.user_security=pExitInfoRecord->sec;
- od_control.user_numcalls=pExitInfoRecord->nocalls;
- od_control.user_uploads=pExitInfoRecord->ups;
- od_control.user_downloads=pExitInfoRecord->downs;
- od_control.user_upk=pExitInfoRecord->upk;
- od_control.user_downk=pExitInfoRecord->downk;
- od_control.user_todayk=pExitInfoRecord->todayk;
- memcpy(&od_control.user_time_used,&pExitInfoRecord->elapsed,6);
- od_control.user_group=pExitInfoRecord->group;
- od_control.user_xi_record=pExitInfoRecord->xirecord;
- od_control.event_status=pExitInfoRecord->status;
- ODStringPascalToC(od_control.event_starttime,pExitInfoRecord->starttime,5);
- memcpy(&od_control.event_errorlevel,&pExitInfoRecord->errorlevel,3);
- ODStringPascalToC(od_control.event_last_run,pExitInfoRecord->lasttimerun,8);
- memcpy(&od_control.user_netmailentered,&pExitInfoRecord->netmailentered,2);
- ODStringPascalToC(od_control.user_logintime,pExitInfoRecord->logintime,5);
- ODStringPascalToC(od_control.user_logindate,pExitInfoRecord->logindate,8);
-
-
-
- memcpy(&od_control.user_loginsec,&pExitInfoRecord->loginsec,16);
- od_control.user_ansi=od_control.user_attribute&8;
- od_control.user_avatar=od_control.user_attrib2&2;
- return(TRUE);
- }
- INT ODWriteExitInfoPrimitive(FILE *pfDropFile, INT nCount)
- {
- INT nToReturn;
- DWORD dwActiveMinutes;
- INT nUserTimeLost;
- INT nTimeSubtractedBySysop;
- time_t nCurrentUnixTime;
- pExitInfoRecord->num_calls=od_control.system_calls;
- ODStringCToPascal(pExitInfoRecord->last_caller,35,od_control.system_last_caller);
- ODStringCToPascal(pExitInfoRecord->start_date,8,od_control.timelog_start_date);
- memcpy(&pExitInfoRecord->busyperhour,&od_control.timelog_busyperhour,31);
- ODStringCToPascal(pExitInfoRecord->uname,35,od_control.user_name);
- ODStringCToPascal(pExitInfoRecord->uloc,25,od_control.user_location);
- ODStringCToPascal(pExitInfoRecord->password,15,od_control.user_password);
- ODStringCToPascal(pExitInfoRecord->dataphone,12,od_control.user_dataphone);
- ODStringCToPascal(pExitInfoRecord->homephone,12,od_control.user_homephone);
- ODStringCToPascal(pExitInfoRecord->lasttime,5,od_control.user_lasttime);
- ODStringCToPascal(pExitInfoRecord->lastdate,8,od_control.user_lastdate);
- memcpy(&pExitInfoRecord->attrib,&od_control.user_attribute,5);
- pExitInfoRecord->credit=(WORD)od_control.user_net_credit;
- pExitInfoRecord->pending=(WORD)od_control.user_pending;
- pExitInfoRecord->posted=(WORD)od_control.user_messages;
- pExitInfoRecord->lastread=(WORD)od_control.user_lastread;
- pExitInfoRecord->sec=(WORD)od_control.user_security;
- pExitInfoRecord->nocalls=(WORD)od_control.user_numcalls;
- pExitInfoRecord->ups=(WORD)od_control.user_uploads;
- pExitInfoRecord->downs=(WORD)od_control.user_downloads;
- pExitInfoRecord->upk=(WORD)od_control.user_upk;
- pExitInfoRecord->downk=(WORD)od_control.user_downk;
- pExitInfoRecord->todayk=(WORD)od_control.user_todayk;
- memcpy(&pExitInfoRecord->elapsed,&od_control.user_time_used,6);
- pExitInfoRecord->group = (BYTE)od_control.user_group;
- pExitInfoRecord->xirecord=(WORD)od_control.user_xi_record;
- pExitInfoRecord->status=od_control.event_status;
- pExitInfoRecord->status=od_control.event_status;
- ODStringCToPascal(pExitInfoRecord->starttime,5,od_control.event_starttime);
- memcpy(&pExitInfoRecord->errorlevel,&od_control.event_errorlevel,3);
- ODStringCToPascal(pExitInfoRecord->lasttimerun,8,od_control.event_last_run);
- memcpy(&pExitInfoRecord->netmailentered,&od_control.user_netmailentered,2);
- ODStringCToPascal(pExitInfoRecord->logintime,5,od_control.user_logintime);
- ODStringCToPascal(pExitInfoRecord->logindate,8,od_control.user_logindate);
-
-
- time(&nCurrentUnixTime);
- ODDWordDivide(&dwActiveMinutes, NULL, nCurrentUnixTime-nStartupUnixTime, 60L);
- nUserTimeLost = (nInitialRemaining - od_control.user_timelimit);
- nTimeSubtractedBySysop = nUserTimeLost - (int)dwActiveMinutes;
- pExitInfoRecord->timelimit -= nTimeSubtractedBySysop;
- memcpy(&pExitInfoRecord->loginsec,&od_control.user_loginsec,16);
- nToReturn=(fwrite(pExitInfoRecord,1,nCount,pfDropFile) == (size_t)nCount);
- free(pExitInfoRecord);
- return(nToReturn);
- }
- #ifndef ODPLAT_WIN32
- void ODAtExitCallback(void)
- {
- if(bODInitialized)
- {
- bPreOrExit = TRUE;
- if(od_control.od_errorlevel[0])
- {
- od_exit(od_control.od_errorlevel[7],FALSE);
- }
- else
- {
- od_exit(6,FALSE);
- }
- }
- }
- #endif
- #ifdef ODPLAT_WIN32
- static BOOL ODSendModemCommand(char *pszCommand, int nRetries)
- {
- ASSERT(pszCommand != NULL);
- ASSERT(nRetries >= 1);
- while(nRetries--)
- {
- if(ODSendModemCommandOnce(pszCommand))
- {
- return(TRUE);
- }
- }
- return(FALSE);
- }
- static BOOL ODSendModemCommandOnce(char *pszCommand)
- {
- char *pchCurrent;
- char szResponse[MAX_RESPONSE_LEN + 1];
- int nResponsePos;
- BOOL bSendingCommand = TRUE;
- ASSERT(pszCommand != NULL);
-
- ASSERT(od_control.baud != 0);
-
- for(pchCurrent = pszCommand; *pchCurrent != '\0'; ++pchCurrent)
- {
-
-
- if(bSendingCommand)
- {
- switch(*pchCurrent)
- {
- case ' ':
-
-
- bSendingCommand = FALSE;
-
- nResponsePos = 0;
- szResponse[0] = '\0';
- break;
- case '|':
-
-
- ODComSendByte(hSerialPort, '\r');
- #ifdef OD_DIAGNOSTICS
- strcat(szDebugWorkString, "\n");
- #endif
- break;
- case '~':
-
- od_sleep(1000);
- break;
- default:
-
- ODComSendByte(hSerialPort, *pchCurrent);
- #ifdef OD_DIAGNOSTICS
- {
- char szAppend[2];
- szAppend[0] = *pchCurrent;
- szAppend[1] = 0;
- strcat(szDebugWorkString, szAppend);
- }
- #endif
- }
- od_sleep(200);
- }
- else
- {
-
- switch(*pchCurrent)
- {
- case ' ':
-
-
-
- if(!ODWaitForString(szResponse, RESPONSE_TIMEOUT))
- {
-
- return(FALSE);
- }
-
- bSendingCommand = TRUE;
- break;
- case '~':
-
- break;
- default:
-
- if(nResponsePos < MAX_RESPONSE_LEN)
- {
- szResponse[nResponsePos] = *pchCurrent;
- ++nResponsePos;
- szResponse[nResponsePos] = '\0';
- }
- }
- }
- }
-
- return(TRUE);
- }
- static BOOL ODWaitForString(char *pszResponse, tODMilliSec ResponseTimeout)
- {
- tODTimer Timer;
- char szReceived[MAX_RESPONSE_LEN + 1] = "\0";
- tODInputEvent InputEvent;
- ASSERT(pszResponse != NULL);
- ASSERT(ResponseTimeout > 0);
-
- ASSERT(od_control.baud != 0);
-
- if(strlen(pszResponse) == 0) return(TRUE);
- #ifdef OD_DIAGNOSTICS
- strcat(szDebugWorkString, "[");
- #endif
- ODTimerStart(&Timer, ResponseTimeout);
- while(!ODTimerElapsed(&Timer))
- {
- if(ODInQueueGetNextEvent(hODInputQueue, &InputEvent,
- ODTimerLeft(&Timer)) == kODRCSuccess)
- {
- if(InputEvent.bFromRemote && InputEvent.EventType == EVENT_CHARACTER)
- {
- #ifdef OD_DIAGNOSTICS
- {
- char szAppend[2];
- szAppend[0] = InputEvent.chKeyPress;
- szAppend[1] = 0;
- strcat(szDebugWorkString, szAppend);
- }
- #endif
-
- if(strlen(szReceived) == MAX_RESPONSE_LEN)
- {
- memmove(szReceived, szReceived + 1, MAX_RESPONSE_LEN);
- }
- szReceived[strlen(szReceived) + 1] = '\0';
- szReceived[strlen(szReceived)] = InputEvent.chKeyPress;
-
- if(strstr(szReceived, pszResponse) != NULL)
- {
- #ifdef OD_DIAGNOSTICS
- strcat(szDebugWorkString, "]");
- #endif
- return(TRUE);
- }
- }
- }
- else
- {
-
- od_sleep(0);
- }
- }
- #ifdef OD_DIAGNOSTICS
- strcat(szDebugWorkString, "]");
- #endif OD_DIAGNOSTICS
-
- return(FALSE);
- }
- void ODInExDisableDTR(void)
- {
- BOOL bCarrier;
-
- if(od_control.od_com_method == COM_DOOR32 || od_control.od_com_method == COM_SOCKET)
- {
- return;
- }
-
- ODComCarrier(hSerialPort, &bCarrier);
- if(bCarrier)
- {
-
-
- if(od_control.od_open_handle == 0
- && !(od_control.od_disable & DIS_DTR_DISABLE))
- {
- if(!ODSendModemCommand(od_control.od_disable_dtr, 2))
- {
- #ifdef OD_DIAGNOSTICS
- if(od_control.od_internal_debug)
- {
- MessageBox(NULL, szDebugWorkString, "DTR Disable FAILED!",
- MB_OK);
- szDebugWorkString[0] = '\0';
- }
- #endif
- }
- else
- {
- #ifdef OD_DIAGNOSTICS
- if(od_control.od_internal_debug)
- {
- MessageBox(NULL, szDebugWorkString, "DTR Disable Succeeded!",
- MB_OK);
- szDebugWorkString[0] = '\0';
- }
- #endif
- }
- }
- }
- }
- #endif
|