Catch terminal's error message

23 vues (au cours des 30 derniers jours)
Juan Ramirez
Juan Ramirez le 15 Mai 2018
Commenté : Juan Ramirez le 15 Mai 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?

Réponse acceptée

Guillaume
Guillaume le 15 Mai 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 commentaire
Juan Ramirez
Juan Ramirez le 15 Mai 2018
Thank you both! Using a try...catch as in above is exactly what I wanted.

Connectez-vous pour commenter.

Plus de réponses (1)

Walter Roberson
Walter Roberson le 15 Mai 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.

Catégories

En savoir plus sur MATLAB Compiler dans Help Center et File Exchange

Produits


Version

R2018a

Community Treasure Hunt

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

Start Hunting!

Translated by