Pause between two commands without using the SLEEP() command

Hi All,

I have a service running that monitors other services and restarts them when needed. After starting I check if the start is successful. Works fine.

But today I added a service that apparently takes a bit more time to start so my check if the start was successful comes to early. So I need a kind of delay between those two lines. I don’t want to use the SLEEP() command in the case. As far as I know that would delay the whole application which is not good it will also confuse the timer event which has to fire every three minutes.

Is there some other way I can get a delay between to commands instead of using SLEEP()? I guess a delay of 300ms will be sufficient.

AFAIK, it only affects the current thread.

OK that is good to know, thanks. Unfortunate that doesn’t help in this case because this application has just one thread. The checking and starting is done in a UserEvent on the main procedure.

On the newsgroup I got a pragmatic solution: Why not wait for the next timed event to check if the restart worked? For a non-essential service that might be ok.

use the Timer:event. Set Prop:timer to a shorter interval to start and then increase it after your services have started. You may want to save the FirstTime in the Event:OpenWindow. I believe the first timer event fires right after the open window and then goes the specified interval. Although I may be wrong about that…

In my experience not. It take three minutes to fire the first check which is the interval I set my timer to. Maybe it makes a difference that my application is running as a service, not sure didn’t test.

Setting the PROP:Timer to a shorter interval for that slow starting service is something I don’t prefer. A continuous checking of the more important services is more important to me. I choose a more pragmatic solution, just wait for the next cycle to see if the restart works because most of the time that will be the case.

0{PROP:Timer} = 42
Are you aware that you can change the timer value at runtime via property syntax ?

Yep, I use that quite often :slightly_smiling_face:

But in this case I am afraid that it will interfere my three minutes interval if I set to a short interval and then set it back to the three minutes.

Then either fire up another thread where you have the alternate timer
Or replace the window timers with API timers, and WaitMultipleObjects

1 Like

Instead of 3 minutes you could set your Timer to 30 to 60 seconds always.

Then you measure time elapsed as Clock() - Last Time Processed My 3m Thing. If it’s been 18,000 H Seconds you process your 3 minute thing. This allows multiple time intervals to be tracked.

There are a few details to deal with like at Midnight the Clock() resets back to zero. Simple code needs to check IF Clock() < Last Process to see if there was a Midnight.

I would use the API GetTickCount as a tiny bit more efficient than Clarion’s Clock.

Using API timers is something new for me. I put it on my list “Must learn that” and hope to find the time to actually find the time to dig out.

Well this is just an example that someone (me in this case :slightly_smiling_face:) can really get blindfolded when running into a problem. I never thought about changing the interval time.

Interesting, would the be noticeable when running a small task every one minute?

No.

I just like it as the right API for the job

The Old New Thing

The purpose of Get­Tick­Count is to let you measure intervals of time. It provides a common clock source so that multiple components can coordinate their actions. It also allows you to retrieve the tick count at one point, then retrieve the tick count at another point, subtract them, and conclude how much time has elapsed between those two points.

When the System Timer changes Windows stores the Tick Count so it is very fast and simple to get versus asking the Clock the current time.

Oke, makes sense :grinning:

This doesnt appear to be the case.

Sleeping MainFrame, whilst a thread spawned from the MainFrame completes, causes the App to hang.

Hi. I created this code to do this.

!!! <summary>
!!! Pause n Seconds
!!! Par:Seconds: Time, in seconds, to pause. You can use parts of a second (eg: 0.5)
!!! </summary>
Pause                FUNCTION(REAL Par:Seconds)
Rot:Miliseconds         LONG
Rot:Start               LONG
  CODE
      IF Par:Seconds
         Rot:Miliseconds = Par:Seconds * 100
         Rot:Start = CLOCK()
         LOOP WHILE ABS(CLOCK() - Rot:Start) < Rot:Miliseconds
            YIELD()
         END
      END
      RETURN

You probably should not label it “Milli” seconds which is a thousandth 1/1000 while Clarion Time and your code is in hundredths 1/100. Windows API time is usually in Milliseconds e.g. GetTickCount(l.

Maybe call it CentiSeconds or ClockTicks.


You should check IF > 0 because if Negative Seconds were accidentally passed you would spin forever.

1 Like

See the help on starting threads, and slso the RESUME command.

You cannot mix API calls into Clarion and have solid code without a complete understanding of the API.

Stop posting all these broken API seanarios and start reading the MSDN Windows API docs and maybe a few API books.

The docs on Sleep clearly say that your seanario will not work:

Be careful when using Sleep in the following scenarios:

  • Code that directly or indirectly creates windows. If a thread creates any windows, it must process messages. Message broadcasts are sent to all windows in the system.
2 Likes

I know what the docs say, but its not happening on this machine as described by the API. Maybe its because the API docs are written in American English?