add error handling

This commit is contained in:
Birk Skyum
2025-01-21 22:37:17 +01:00
parent 91dc221755
commit 822fc2bdc2

View File

@@ -16,12 +16,27 @@ CodeMirror.defineMode("mgl", (config, parserConfig) => {
CodeMirror.registerHelper("lint", "json", (text: string) => {
const found: MarkerRangeWithMessage[] = [];
try {
parse(text);
}
catch(_e) {
// Do nothing we catch the error above
catch(err: any) {
const errorMatch = err.toString().match(/line (\d+), column (\d+)/);
if (errorMatch) {
const loc = {
first_line: parseInt(errorMatch[1], 10),
first_column: parseInt(errorMatch[2], 10),
last_line: parseInt(errorMatch[1], 10),
last_column: parseInt(errorMatch[2], 10)
};
// const loc = hash.loc;
found.push({
from: CodeMirror.Pos(loc.first_line - 1, loc.first_column),
to: CodeMirror.Pos(loc.last_line - 1, loc.last_column),
message: err
});
}
}
return found;
});
@@ -33,8 +48,25 @@ CodeMirror.registerHelper("lint", "mgl", (text: string, opts: any, doc: any) =>
try {
parse(text);
}
catch (_e) {
// ignore errors
catch (err: any) {
const errorMatch = err.toString().match(/line (\d+), column (\d+)/);
if (errorMatch) {
const loc = {
first_line: parseInt(errorMatch[1], 10),
first_column: parseInt(errorMatch[2], 10),
last_line: parseInt(errorMatch[1], 10),
last_column: parseInt(errorMatch[2], 10)
};
// const loc = hash.loc;
found.push({
from: CodeMirror.Pos(loc.first_line - 1, loc.first_column),
to: CodeMirror.Pos(loc.last_line - 1, loc.last_column),
message: err
});
}
}
if (found.length > 0) {