Debug Error Handling

I have a small querry . It works of but if you press cancel small problem in debuger.
I need a way to handle it.

By the way it only does this in the debuger.
If i just run the exe it will do nothing. Is this someing to be worried about ?
var
  value : string;
 
begin
    value := InputBox('Invoice Number Lookup ', 'Please type your Number', '');
 if datamodule2.ADOQuery1.Locate('InvoiceNumber', Value, []) then
  ShowMessage('Record located')
  else
  ShowMessage('Record NOT LOCATED');
end;

Open in new window

large.jpg
Grant FullenAsked:
Who is Participating?

Improve company productivity with a Business Account.Sign Up

x
 
8080_DiverConnect With a Mentor Commented:
It works of but if you press cancel small problem in debuger.
I need a way to handle it.

Please explain what you mean by "if you press cancel".  If you are referring to the Cancel button on the Dialog box, then you need to look at the Default String parameter in your InputBox statement . . . it is a null string.  That could weel be the cause of your problems.  If you do not want toeven attempt to locate a record, then you need to code for that.
Also, you should get in the habit of using TRY . . . EXCEPT . . . END; to wrap code that has a potential for throwing exceptions.  That lets you, among other things, add a little more debugging or human consumable text to the error message (see below).  
Substituting the code snippet for your code should, among other things, make the exception message a little more meaningful if in no other way than that it will show you what was entered for the search parameter.  


var
  value : string;
 
begin
  value := InputBox('Invoice Number Lookup ', 
                    'Please type your Number', '');
  if  (Value = '')
  then begin
    ShowMessage('You clicked Cancel.');
  end
  else
    try
      if datamodule2.ADOQuery1.Locate('InvoiceNumber', Value, []) 
      then begin
        ShowMessage('Record located');
      end
      else begin
        ShowMessage('Record NOT LOCATED');
      end; {if}
    except E:Exception
      on exception
        begin
          Raise Exception.Create('ERROR: An error occured while ' +   
                                 'trying to locate the desired ' +   
                                 'record [' + Value + ']:' + #13#10 +
                                 E.Message);
        end;
    end; {try}
  end; {if}
end;

Open in new window

0
 
Grant FullenAuthor Commented:
Thanks for your reply.
except E:Exception  <========= Undeclaired Identifier......
0
 
Geert GOracle dbaCommented:
Add SysUtils to the uses clause
0
 
Grant FullenAuthor Commented:
wow thats   weard I allready have SysUtils in my uses clause...........
0
 
Geert GOracle dbaCommented:
uh no, it's a syntax error

 except
      on E:Exception do
        begin
          Raise Exception.Create('ERROR: An error occured while ' +  
                                 'trying to locate the desired ' +  
0
Question has a verified solution.

Are you are experiencing a similar issue? Get a personalized answer when you ask a related question.

Have a better answer? Share it in a comment.

All Courses

From novice to tech pro — start learning today.