RENEMAIL is now REETODO free

This commit is contained in:
Rick Parrish 2013-02-08 12:52:49 -05:00
parent 44c2102774
commit e2b2ead554
1 changed files with 52 additions and 4 deletions

View File

@ -20,7 +20,12 @@ CONST
Activity_Log: Boolean = FALSE; Activity_Log: Boolean = FALSE;
NetMailOnly: Boolean = FALSE; NetMailOnly: Boolean = FALSE;
IsNetMail: Boolean = FALSE; IsNetMail: Boolean = FALSE;
{$IFDEF MSDOS}
FastPurge: Boolean = TRUE; FastPurge: Boolean = TRUE;
{$ENDIF}
{$IFDEF WIN32}
FastPurge: Boolean = FALSE;
{$ENDIF}
Process_NetMail: Boolean = TRUE; Process_NetMail: Boolean = TRUE;
Purge_NetMail: Boolean = TRUE; Purge_NetMail: Boolean = TRUE;
Absolute_Scan: Boolean = FALSE; Absolute_Scan: Boolean = FALSE;
@ -97,6 +102,51 @@ VAR
ParamFound: Boolean; ParamFound: Boolean;
{$IFDEF WIN32}
(* REENOTE
In BP/TP you can do this:
var
MySet: NetAttribs;
MyWord: Word;
begin
MySet := [Private, Crash];
MyWord := Word(MySet);
{ MyWord now contains the value 3 in BP/TP }
{ but VP refuses to compile the code due to Word(MySet) }
end;
In VP this typecast isn't allowed (maybe there's a compiler setting to allow it, didn't look actually)
so this function converts from a set to a word type.
While this function should work for both BP/TP and for VP, I'm only using it for VP and using the
original cast for BP/TP, since there's no need to change what isn't broken
*)
function NetAttribsToWord(inSet: NetAttribs): Word;
var
Result: Word;
begin
Result := 0;
if (Private in inSet) then result := result + 1;
if (Crash in inSet) then result := result + 2;
if (Recd in inSet) then result := result + 4;
if (NSent in inSet) then result := result + 8;
if (FileAttach in inSet) then result := result + 16;
if (Intransit in inSet) then result := result + 32;
if (Orphan in inSet) then result := result + 64;
if (KillSent in inSet) then result := result + 128;
if (Local in inSet) then result := result + 256;
if (Hold in inSet) then result := result + 512;
if (Unused in inSet) then result := result + 1024;
if (FileRequest in inSet) then result := result + 2048;
if (ReturnReceiptRequest in inSet) then result := result + 4096;
if (IsReturnReceipt in inSet) then result := result + 8192;
if (AuditRequest in inSet) then result := result + 16384;
if (FileUpdateRequest in inSet) then result := result + 32768;
NetAttribsToWord := Result;
end;
{$ENDIF}
FUNCTION CenterStr(S: STRING): STRING; FUNCTION CenterStr(S: STRING): STRING;
VAR VAR
Counter1: Byte; Counter1: Byte;
@ -865,7 +915,7 @@ BEGIN
Purged := (Lo(Regs.AX) = 0); Purged := (Lo(Regs.AX) = 0);
{$ENDIF} {$ENDIF}
{$IFDEF WIN32} {$IFDEF WIN32}
WriteLn('REETODO RENEMAIL PurgeDir'); Halt; // We ensure FastPurge is false in Win32, so this is never called
{$ENDIF} {$ENDIF}
END END
ELSE ELSE
@ -1703,9 +1753,7 @@ BEGIN
FidoMsgHdr.Attribute := Word(RGMsgHdr.NetAttribute) FidoMsgHdr.Attribute := Word(RGMsgHdr.NetAttribute)
{$ENDIF} {$ENDIF}
{$IFDEF WIN32} {$IFDEF WIN32}
BEGIN FidoMsgHdr.Attribute := NetAttribsToWord(RGMsgHdr.NetAttribute)
WriteLn('REETODO RENEMAIL Scan'); Halt;
END
{$ENDIF} {$ENDIF}
ELSE IF (Prvt IN RGMsgHdr.Status) THEN ELSE IF (Prvt IN RGMsgHdr.Status) THEN
FidoMsgHdr.Attribute := 257 FidoMsgHdr.Attribute := 257