X-Git-Url: http://www.lcore.org/git/lcore.git/blobdiff_plain/3745aa61ef489e4b143b5c753a006d0613a0297f..2c3a30778bb5a281c10736470058b5a63575a516:/wcore.pas diff --git a/wcore.pas b/wcore.pas old mode 100755 new mode 100644 index 8b402b5..2c07d50 --- a/wcore.pas +++ b/wcore.pas @@ -34,7 +34,7 @@ interface initialdone:boolean; prevtimer:tltimer; nexttimer:tltimer; - interval:integer; {miliseconds, default 1000} + interval:integer; {milliseconds, default 1000} nextts:integer; property enabled:boolean read fenabled write setenabled; constructor create(aowner:tcomponent);override; @@ -58,6 +58,7 @@ procedure addtask(ahandler:ttaskevent;aobj:tobject;awparam,alparam:longint); procedure disconnecttasks(aobj:tobject); procedure exitmessageloop; procedure processmessages; +procedure wcoreinit; var onshutdown:procedure(s:ansistring); @@ -78,7 +79,7 @@ const var hwndwcore:hwnd; firsttimer:tltimer; - timesubstract:integer; + timesubtract:integer; firsttask,lasttask,currenttask:tltask; procedure tlcomponent.release; @@ -143,13 +144,13 @@ begin end; tvnow := timegettime; - if (tvnow and ((-1) shl rollover_bits)) <> timesubstract then begin + if (tvnow and ((-1) shl rollover_bits)) <> timesubtract then begin currenttimer := firsttimer; while assigned(currenttimer) do begin dec(currenttimer.nextts,(1 shl rollover_bits)); currenttimer := currenttimer.nexttimer; end; - timesubstract := tvnow and ((-1) shl rollover_bits); + timesubtract := tvnow and ((-1) shl rollover_bits); end; tvnow := tvnow and ((1 shl rollover_bits)-1); @@ -216,7 +217,7 @@ begin end else begin currenttasklocal := currenttask; //needed in case called from a task end; - // note i don't bother to sestroy the links here as that will happen when + // note i don't bother to destroy the links here as that will happen when // the list of tasks is processed anyway while assigned(currenttasklocal) do begin if currenttasklocal.obj = aobj then begin @@ -312,11 +313,8 @@ var lpszMenuName : nil; lpszClassName : 'wcoreClass'); -procedure messageloop; -var - MsgRec : TMsg; +procedure wcoreinit; begin - if Windows.RegisterClass(MyWindowClass) = 0 then halt; //writeln('about to create wcore handle, hinstance=',hinstance); hwndwcore := CreateWindowEx(WS_EX_TOOLWINDOW, @@ -339,6 +337,14 @@ begin {$endif} +end; + +procedure messageloop; +var + MsgRec : TMsg; + +begin + while GetMessage(MsgRec, 0, 0, 0) do begin TranslateMessage(MsgRec); DispatchMessage(MsgRec); @@ -359,13 +365,13 @@ end; function ProcessMessage : Boolean; var - Msg : TMsg; + MsgRec : TMsg; begin Result := FALSE; - if PeekMessage(Msg, 0, 0, 0, PM_REMOVE) then begin + if PeekMessage(MsgRec, 0, 0, 0, PM_REMOVE) then begin Result := TRUE; TranslateMessage(MsgRec); - DispatchMessage(Msg); + DispatchMessage(MsgRec); end; end;