Recovering from error

  • Thread starter Thread starter John
  • Start date Start date
J

John

Hi

I have a button which calls a method which in turn calls another method,
which in turn calls another method. Let's say in the third method an error
occurs and it is no longer possible to continue, how can I dump everything
and come out of everything waiting for the user to press the button again to
do the process again?

Thanks

Regards
 
John said:
Hi

I have a button which calls a method which in turn calls another method,
which in turn calls another method. Let's say in the third method an error
occurs and it is no longer possible to continue, how can I dump everything
and come out of everything waiting for the user to press the button again
to do the process again?

The simple approach is you can do an Exit Sub at any point in a method to
return to the method that called it. You might want to set a global variable
like WasError to true and have each proceeding method check the flag to know
to just exit the previous method (not do anything) until the code returns
to the top call which should be the initial call from the button method. The
WasError is reset to false and the user can push the button again.
 
Hi

I have a button which calls a method which in turn calls another method,
which in turn calls another method. Let's say in the third method an error
occurs and it is no longer possible to continue, how can I dump everything
and come out of everything waiting for the user to press the button again to
do the process again?

Thanks

Regards

Put a Try/Catch around the top level call, and throw an error in the
third method. You can Catch all errors or only certain ones.
 
John said:
I have a button which calls a method which in turn calls another method,
which in turn calls another method. Let's say in the third method an error
occurs and it is no longer possible to continue, how can I dump everything
and come out of everything waiting for the user to press the button again to
do the process again?

Have a read about "Structured Exception Handling" and "Try .. Catch"

Sub Button1_Click( ... ) Handles Button1.Click
Try

Sub1()

Catch ex as Exception
' This catches [just about] ANY error
' You /can/ be more selective and pick a specific Exception
' if you can do something /useful/ with it

' Looking at the Exception class:
' ex.Message - /what/ went wrong,
' ex.StackTrace - /where/ it happened,
' ex.ToString() - gets the whole lot in one go.
' If you /log/ the error for later, log /this/.

MsgBox( "Oh Dear" & vbCrLf & ex.Message )

RecordToLogFile( ex.ToString() )

End Try
End Sub

Sub Sub1()
Sub2
End Sub

Sub Sub2()
Sub3
End Sub

Sub Sub3()
' Something that goes wrong
End Sub

HTH,
Phill W.
 
That is very close to the question I asked when someone started telling
me how wonderful all this structured stuff is vs. assembler where
everything is everything and you can do what you want. Data is data and
is only a character if you ask it to be and is a number if you ask it to
be without any change in the actual data or its location. If you
reference it with a math operator, it is a number, if you printing it on
paper, it is a character.

The actual answer is that you have to set all the traps and every
routine has to know what is going on with all that it has called and it
is a mess sometimes! Someone down deep gets an error and has to back
out all these levels and you have to code and be ready for it all the
way down so you can come all the way back and sit ready for the user
again.

People seem to think that all this plumbing is the greatest thing but I
will stop liking branch statements when the hardware stops using them!

And the folks who think that "On Error Resume Next" is useless needs to
read a few books by experts. The new Try/Catch business does NOT do
everything that needs be done. Resume Next is still necessary at times.
If I delete a file and it is not there, who cares? I just resume next
around it and I never know if it was there or not. I want it gone, when
I get through it is gone, mission accomplished. Yes, there can be some
other errors but those can be caught in one testing pass and then all is
done.

Mike
 
I vaguely recall C (or at least Turbo C) had a mechanism to jump right back
to a previous location. Not that it matters so much what was in C anyway.
 
VB has one too. It is named GoTo. It is a branch statement (one of the
VB curse words). It can go right back to the top of a nested bunch of
(almost) spaghetti code.

But is the ugly step-sister that is kept locked up in the basement that
no one ever talks about because it "can" enable "spaghetti code" to be
written.

And, OH MY, WE DON'T WANT SPAGHETTI CODE NOW, DO WE?????

Too bad some people never drove a manual shift and don't know to NOT use
their left foot on the brake pedal.

Too bad most programmers never wrote assembler - the code of champions -
and don't know how to avoid spaghetti code in the first place!

We have to save these poor souls from themselves!!!
BE SAVED!!!!!!!!!!!!

People can write spaghetti code in a structured environment, too.

It may be more difficult but still possible and still done, I expect.
Some of the stuff I have seen might as well be classified that way since
it is almost unreadable and unfollowable.

I only use "Goto" on an "On Error" statement but it can be used all by
itself. But don't do it or you will get a spanking and will be sent to
bed without any supper! Never mind it is completely legal to do...

Mike
 
Back
Top