Einzelnen Beitrag anzeigen

MathiasSimmack
(Gast)

n/a Beiträge
 
#5
  Alt 4. Jul 2002, 09:04
Guten Morgen.

1. Wenn du diese Funktion einbindest:
Code:
function fileexists(const szFilename: string): boolean;
var
  Handle  : THandle;
  FindData : TWin32FindData;
begin
  Handle := FindFirstFile(pchar(szFilename),FindData);
  Result := (Handle <> INVALID_HANDLE_VALUE);

  if(Result) then Windows.FindClose(Handle);
end;
kannst du auf die "SysUtils.pas" verzichten, und dein Programm reduziert sich von 43,5k auf 19k.

2. Anstelle von "GetSystemTime" würde ich "GetLocalTime" vorschlagen.

3. Die Anweisung "sleep(150)" dient wofür? Um die Bearbeitung zu verzögern, damit man die Protokollierung ausführen kann? Hm, bei mir hat´s auch ohne geklappt. Aber ich lasse mich da gern belehren.


<Edit>

Machen wir doch noch folgendes:
Code:
function inttostr(const i : integer): string;
begin
  Result := ''; str(i,Result);
end;

// zu finden im EDH -->
function GetWindowsUpTime: String;
const
  DAYS   : Integer = 1000 * 60 * 60 * 24;
  HOURS  : Integer = 1000 * 60 * 60;
  MINUTES : Integer = 1000 * 60;
  SECONDS : Integer = 1000;
var
  Ticks : Integer;
  day, hour, min, sec : Integer;
begin
 Ticks := GetTickCount;
   //GetTickCount gibt die Zeit nach einem Windowstart an

 day := Ticks div DAYS; //Tage
 dec(Ticks, day * DAYS);

 hour := Ticks div HOURS; //Stunden
 dec(Ticks, hour * HOURS);

 min := Ticks div MINUTES; //Minuten
 dec(Ticks, min * MINUTES);

 sec := Ticks div SECONDS; //Sekunden

 Result := IntToStr(day) + ' days, '+
           IntToStr(hour) + ' hours, '+
           IntToStr(min) + ' min, '+
           IntToStr(sec) + ' sec';
end;
Und dann erweitern wir WM_CREATE:
Code:
WM_CREATE:
  begin
    AssignFile(f, 'log.txt');
    if (FileExists('log.txt')) then
      Append(f)
    else
      Rewrite(f);

    GetLocalTime(SystemTime);
    WriteLn(f, 'ShutdownSpy launched at ',
               LeadingZero(SystemTime.wYear), '/',
               LeadingZero(SystemTime.wMonth), '/',
               LeadingZero(SystemTime.wDay), ' ',
               LeadingZero(SystemTime.wHour), ':',
               LeadingZero(SystemTime.wMinute), ':',
               LeadingZero(SystemTime.wSecond), '.');

    WriteLn(f, 'OS is running since ' + GetWindowsUpTime);
    CloseFile(f);

    ...
  end;
Fertig, bei 20k Größe.

</Edit>

Gruß,
Mathias,
  Mit Zitat antworten Zitat