X-Git-Url: http://deadsoftware.ru/gitweb?a=blobdiff_plain;f=src%2Fengine%2Fe_log.pas;h=937730d5d4fd822260f19fbbe9d42861c8ef4192;hb=5c0e145428d60023677261d107632740cec9342b;hp=aba6e0d99d3f794b3de7f85dbf69d99de4c32a57;hpb=7d5854863648d8064a3daa3fd64c8c9b2d1597a7;p=d2df-sdl.git diff --git a/src/engine/e_log.pas b/src/engine/e_log.pas index aba6e0d..937730d 100644 --- a/src/engine/e_log.pas +++ b/src/engine/e_log.pas @@ -41,6 +41,7 @@ function DecodeIPV4 (ip: LongWord): string; procedure e_InitWritelnDriver (); procedure e_LogWritefln (const fmt: AnsiString; args: array of const; category: TRecordCategory=MSG_NOTIFY; writeTime: Boolean=true); +procedure e_LogWriteln (const s: AnsiString; category: TRecordCategory=MSG_NOTIFY; writeTime: Boolean=true); var @@ -68,54 +69,12 @@ procedure e_WriteLog (TextLine: String; RecordCategory: TRecordCategory; WriteTi begin e_LogWritefln('%s', [TextLine], RecordCategory, WriteTime); end; -(* -var - LogFile: TextFile; - Prefix: ShortString = ''; - OutStr: String; -begin - if driverInited and (length(TextLine) > 0) then - begin - case RecordCategory of - MSG_FATALERROR: write('FATAL: '); - MSG_WARNING: write('WARNING: '); - end; - writeln(TextLine); - end; - if FileName = '' then Exit; - Assign(LogFile, FileName); - try - if FileExists(FileName) then - Append(LogFile) - else - Rewrite(LogFile); - try - if FirstRecord then - begin - Writeln(LogFile, '--- Log started at '+TimeToStr(Time)+' ---'); - FirstRecord := False; - end; - case RecordCategory of - MSG_FATALERROR: Prefix := '!!!'; - MSG_WARNING: Prefix := '! '; - MSG_NOTIFY: Prefix := '***'; - end; - if WriteTime then - OutStr := '['+TimeToStr(Time)+'] '+Prefix+' '+TextLine - else - OutStr := Prefix+' '+TextLine; - Writeln(LogFile, OutStr); - if e_WriteToStdOut then - Writeln(OutStr); - finally - Close(LogFile); - end; - except // sorry - end; +procedure e_LogWriteln (const s: AnsiString; category: TRecordCategory=MSG_NOTIFY; writeTime: Boolean=true); +begin + e_LogWritefln('%s', [s], category, writeTime); end; -*) // returns formatted string if `writerCB` is `nil`, empty string otherwise @@ -133,7 +92,7 @@ begin while (len > 0) do begin if (len > 255) then slen := 255 else slen := Integer(len); - Move(b^, ss[1], len); + Move(b^, ss[1], slen); ss[0] := AnsiChar(slen); write(ss); b += slen; @@ -179,12 +138,13 @@ begin while (len > 0) do begin slen := 0; - while (slen < len) and (slen < 255) and (b[slen] <> 13) and (b[slen] <> 10) do Inc(slen); + while (slen < len) and (b[slen] <> 13) and (b[slen] <> 10) do Inc(slen); + if (slen > 255) then slen := 255; // print string if (slen > 0) then begin if xlogWantSpace then begin write(xlogFile, ' '); xlogWantSpace := false; end; - Move(b^, ss[1], len); + Move(b^, ss[1], slen); ss[0] := AnsiChar(slen); write(xlogFile, ss); b += slen; @@ -194,16 +154,8 @@ begin // process newline if (len > 0) and ((b[0] = 13) or (b[0] = 10)) then begin - if (len > 1) and (b[0] = 13) and (b[1] = 10) then - begin - len -= 2; - b += 2; - end - else - begin - len -= 1; - b += 1; - end; + if (b[0] = 13) then begin len -= 1; b += 1; end; + if (len > 0) and (b[0] = 10) then begin len -= 1; b += 1; end; xlogLastWasEOL := false; writeln(xlogFile, ''); write(xlogFile, xlogPrefix);