Catch terminal's error message

6 views (last 30 days)
Juan Ramirez
Juan Ramirez on 15 May 2018
Commented: Juan Ramirez on 15 May 2018
I have a long script executed remotely and would like to capture any error in a log file. I would prefer not to write several try/catch statements, and would rather write a single try/catch around the entire function, and record the exact error, with a line number. But I can't find a tool to capture this.
Even in this simple example, I cannot capture the error message, and the program does not fail gracefully:
try
1=0;
catch ME
disp(ME.identifier)
end
The terminal says
Error: File: test.m Line: 2 Column 6
Incorrect use of '=' operator. To assign a value...
It is this message that I want saved and directed to a file. Can it be done?

Accepted Answer

Guillaume
Guillaume on 15 May 2018
As Walter says, your example script will never execute because of the syntax error so try catch inside the file is no good.
However, a try... catch statement in the caller of the file would trap the error. So:
try
nameoflongscript %invoke long script
catch ME
disp(ME)
end
would work.
Alternatively, to detect such parse errors before actually running the script, you could use mlint to analyse the file, or the undocumented mtree to get the parse tree of the file. Either of these will tell you if there are any parse error.
  1 Comment
Juan Ramirez
Juan Ramirez on 15 May 2018
Thank you both! Using a try...catch as in above is exactly what I wanted.

Sign in to comment.

More Answers (1)

Walter Roberson
Walter Roberson on 15 May 2018
No, in all modern MATLAB versions, the file is completely parsed before any of it is executed. You would need to have the try/catch in the calling code.

Categories

Find more on Entering Commands in Help Center and File Exchange

Products


Release

R2018a

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!