How to stop a macro

D

DA

I'd like a macro to stop after 20 seconds, if it has not finished.
What is the easiest way to do this?

Thanks
Dean
 
J

joeu2004

I'd like a macro to stop after 20 seconds, if it has
not finished. What is the easiest way to do this?

Press ctrl+Break. (On my laptop, it is ctrl+alt+Pause.) That usually
interrupts the procedure and allows you debug or end.

Oh, did you mean programmatically? ;-)

See the following example. Essentially, OnTime is used to call a
procedure after a prescribed amount of time (5 sec, in the example).
When the timeOut function is called, it sets a global variable stopIt
to True. When the main procedure (doit) sees that stopIt is True, the
main procedure exits the loop.

However, this works on if the main procedure yields the CPU
periodically. See the use of DoEvents() in the main procedure. I
imagine that can be costly in execution time.

Also, there are many other conditions that will prevent the timeOut
procedure from running when the timer pops.

See http://www.cpearson.com/excel/OnTime.aspx for another method. I
don't know if avoids any or all of the above pitfalls.

Example....

Private stopIt As Boolean
Private st As Double

Sub doit()
'* see also http://www.cpearson.com/excel/OnTime.aspx
stopIt = False
st = Now
Application.OnTime st + TimeSerial(0, 0, 5), "timeOut"
myst = Timer
Do
'* abort if no timeout after 10 sec
If Timer - myst > 10 Then MsgBox "no timeout": Exit Sub

'* must use DoEvents to allow timeOut to run.
'* comment out following line to see what happens
x = DoEvents()
Loop Until stopIt
MsgBox "stopit"
End Sub

Private Sub timeOut()
stopIt = True
et = Now
MsgBox "timeOut" & Format(st, " hh:mm:ss") & _
Format(et, " hh:mm:ss")
End Sub
 

Ask a Question

Want to reply to this thread or ask your own question?

You'll need to choose a username for the site, which only take a couple of moments. After that, you can post your question and our members will help you out.

Ask a Question

Top