Skip to content

Commit fc2429b

Browse files
authored
WI #1846 Multi line diagnostics (#2036)
Diagnostics can now be positionned on a range of consecutive lines. Does not take in account Tokens spread on multiple lines.
1 parent 1e49d0c commit fc2429b

File tree

48 files changed

+279
-217
lines changed

Some content is hidden

Large Commits have some content hidden by default. Use the searchbox below for content that may be hidden.

48 files changed

+279
-217
lines changed

CLI/src/CLI.cs

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -561,7 +561,7 @@ private ReturnCode AddErrorsAndComputeReturnCode()
561561
if (generationException.Logged)
562562
{
563563
string message = generationException.Message + Environment.NewLine + generationException.StackTrace;
564-
var position = new Diagnostic.Position(generationException.LineNumber, generationException.ColumnStartIndex, generationException.ColumnEndIndex, null);
564+
var position = new Diagnostic.Position(generationException.LineNumber, generationException.ColumnStartIndex, generationException.LineNumber, generationException.ColumnEndIndex, null);
565565
Server.AddError(_errorWriter, generationException.Path, new Diagnostic(generationException.MessageCode, position, message));
566566
}
567567
}

CLI/src/Writer.cs

Lines changed: 3 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -141,7 +141,7 @@ private void writeMessage(string id, Diagnostic error) {
141141
writer.WriteStartElement("MESSAGE");
142142
writer.WriteElementString("MSGNUMBER",
143143
"TC-" + error.Info.Code.ToString().PadLeft(5, '0') + AsIBMSuffix((int) error.Info.Severity));
144-
writer.WriteElementString("MSGLINE", error.Line.ToString());
144+
writer.WriteElementString("MSGLINE", error.LineStart.ToString());
145145
writer.WriteElementString("MSGFILE", id);
146146
writer.WriteElementString("MSGTEXT", error.Message);
147147
writer.WriteEndElement(); // MESSAGE
@@ -246,9 +246,9 @@ private void WriteDiagnostics()
246246

247247
//range
248248
_xmlWriter.WriteStartElement("range");
249-
_xmlWriter.WriteAttributeString("line-start", diagnostic.Line.ToString());
249+
_xmlWriter.WriteAttributeString("line-start", diagnostic.LineStart.ToString());
250250
_xmlWriter.WriteAttributeString("column-start", diagnostic.ColumnStart.ToString());
251-
_xmlWriter.WriteAttributeString("line-end", diagnostic.Line.ToString());
251+
_xmlWriter.WriteAttributeString("line-end", diagnostic.LineEnd.ToString());
252252
_xmlWriter.WriteAttributeString("column-end", diagnostic.ColumnEnd.ToString());
253253
_xmlWriter.WriteEndElement();
254254

Lines changed: 3 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -1,4 +1,4 @@
1-
ReturnCode=ParsingDiagnostics_
1+
ReturnCode=ParsingDiagnostics_
22
2 errors in "input\MainPgm.rdz.tcbl":
3-
Line 15[12,20] <27, Error, Syntax> - Syntax error : Function 'DVZTEST1.GetTecMsg' expected parameter 'capt' of type DVZTEST2.Span and received 't1' of type TCOSMPL2.type1
4-
Line 18[12,20] <27, Error, Syntax> - Syntax error : Function 'GetTecMsg' expected parameter 'capt' of type DVZTEST2.Span and received 't1' of type TCOSMPL2.type1
3+
Range (15, 12) -> (16, 20) <27, Error, Syntax> - Syntax error : Function 'DVZTEST1.GetTecMsg' expected parameter 'capt' of type DVZTEST2.Span and received 't1' of type TCOSMPL2.type1
4+
Range (18, 12) -> (19, 20) <27, Error, Syntax> - Syntax error : Function 'GetTecMsg' expected parameter 'capt' of type DVZTEST2.Span and received 't1' of type TCOSMPL2.type1
Lines changed: 2 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -1,3 +1,3 @@
1-
ReturnCode=ParsingDiagnostics_
1+
ReturnCode=ParsingDiagnostics_
22
1 error in "input\PGM3.rdz.tcbl":
3-
Line 26[12,39] <30, Error, Semantics> - Semantic error: Function not found 'MyPublicProcedure' input(DATE)
3+
Range (26, 12) -> (27, 39) <30, Error, Semantics> - Semantic error: Function not found 'MyPublicProcedure' input(DATE)
Lines changed: 2 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -1,3 +1,3 @@
1-
ReturnCode=ParsingDiagnostics_
1+
ReturnCode=ParsingDiagnostics_
22
1 error in "input\PGM3.rdz.tcbl":
3-
Line 28[12,39] <30, Error, Semantics> - Semantic error: Function not found 'MyPublicProcedure' input(DATE)
3+
Range (28, 12) -> (29, 39) <30, Error, Semantics> - Semantic error: Function not found 'MyPublicProcedure' input(DATE)

Codegen/src/Generators/DefaultGenerator.cs

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -1223,7 +1223,7 @@ private void GenerateExceedLineDiagnostics()
12231223
{
12241224
foreach (int lineNumber in ExceedLines.Keys)
12251225
{
1226-
Diagnostic diag = new Diagnostic(MessageCode.GenerationErrorLineExceed, new Diagnostic.Position(lineNumber, 0, 0, null));
1226+
Diagnostic diag = new Diagnostic(MessageCode.GenerationErrorLineExceed, new Diagnostic.Position(lineNumber, 0, lineNumber, 0, null));
12271227
AddDiagnostic(diag);
12281228
}
12291229
}

TypeCobol.Analysis.Test/BasicCfgInstrs/CGM110.diag

Lines changed: 25 additions & 25 deletions
Original file line numberDiff line numberDiff line change
@@ -65,10 +65,10 @@ Line 27813[21,24] <37, Warning, General> - Warning: Unreachable code detected
6565
Line 27817[15,18] <37, Warning, General> - Warning: Unreachable code detected
6666
Line 27819[21,34] <37, Warning, General> - Warning: Unreachable code detected
6767
Line 27820[24,43] <37, Warning, General> - Warning: Unreachable code detected
68-
Line 27846[12,34] <37, Warning, General> - Warning: Unreachable code detected
68+
Range (27846, 12) -> (27849, 34) <37, Warning, General> - Warning: Unreachable code detected
6969
Line 27852[13,46] <37, Warning, General> - Warning: Unreachable code detected
7070
Line 27854[13,38] <37, Warning, General> - Warning: Unreachable code detected
71-
Line 27856[12,37] <37, Warning, General> - Warning: Unreachable code detected
71+
Range (27856, 12) -> (27857, 37) <37, Warning, General> - Warning: Unreachable code detected
7272
Line 27860[13,46] <37, Warning, General> - Warning: Unreachable code detected
7373
Line 27862[13,38] <37, Warning, General> - Warning: Unreachable code detected
7474
Line 27864[12,35] <37, Warning, General> - Warning: Unreachable code detected
@@ -79,18 +79,18 @@ Line 27872[13,47] <37, Warning, General> - Warning: Unreachable code detected
7979
Line 27876[12,67] <37, Warning, General> - Warning: Unreachable code detected
8080
Line 27878[12,57] <37, Warning, General> - Warning: Unreachable code detected
8181
Line 27879[13,47] <37, Warning, General> - Warning: Unreachable code detected
82-
Line 27882[12,37] <37, Warning, General> - Warning: Unreachable code detected
82+
Range (27882, 12) -> (27883, 37) <37, Warning, General> - Warning: Unreachable code detected
8383
Line 27884[18,39] <37, Warning, General> - Warning: Unreachable code detected
8484
Line 27885[14,17] <37, Warning, General> - Warning: Unreachable code detected
8585
Line 27888[18,39] <37, Warning, General> - Warning: Unreachable code detected
8686
Line 27889[21,40] <37, Warning, General> - Warning: Unreachable code detected
8787
Line 27890[24,45] <37, Warning, General> - Warning: Unreachable code detected
8888
Line 27891[22,25] <37, Warning, General> - Warning: Unreachable code detected
8989
Line 27896[13,18] <37, Warning, General> - Warning: a End statement is not aligned with the matching opening statement
90-
Line 27919[12,34] <37, Warning, General> - Warning: Unreachable code detected
90+
Range (27919, 12) -> (27922, 34) <37, Warning, General> - Warning: Unreachable code detected
9191
Line 27925[13,46] <37, Warning, General> - Warning: Unreachable code detected
9292
Line 27927[13,38] <37, Warning, General> - Warning: Unreachable code detected
93-
Line 27929[12,37] <37, Warning, General> - Warning: Unreachable code detected
93+
Range (27929, 12) -> (27930, 37) <37, Warning, General> - Warning: Unreachable code detected
9494
Line 27933[13,46] <37, Warning, General> - Warning: Unreachable code detected
9595
Line 27935[13,38] <37, Warning, General> - Warning: Unreachable code detected
9696
Line 27937[12,35] <37, Warning, General> - Warning: Unreachable code detected
@@ -106,38 +106,38 @@ Line 27959[13,38] <37, Warning, General> - Warning: Unreachable code detected
106106
Line 27962[12,67] <37, Warning, General> - Warning: Unreachable code detected
107107
Line 27964[12,57] <37, Warning, General> - Warning: Unreachable code detected
108108
Line 27965[13,47] <37, Warning, General> - Warning: Unreachable code detected
109-
Line 27968[12,37] <37, Warning, General> - Warning: Unreachable code detected
109+
Range (27968, 12) -> (27969, 37) <37, Warning, General> - Warning: Unreachable code detected
110110
Line 27970[18,39] <37, Warning, General> - Warning: Unreachable code detected
111111
Line 27971[14,17] <37, Warning, General> - Warning: Unreachable code detected
112112
Line 27974[20,41] <37, Warning, General> - Warning: Unreachable code detected
113113
Line 27975[23,42] <37, Warning, General> - Warning: Unreachable code detected
114114
Line 27976[26,47] <37, Warning, General> - Warning: Unreachable code detected
115115
Line 27977[24,27] <37, Warning, General> - Warning: Unreachable code detected
116-
Line 27999[12,42] <37, Warning, General> - Warning: Unreachable code detected
116+
Range (27999, 12) -> (28000, 42) <37, Warning, General> - Warning: Unreachable code detected
117117
Line 28005[12,53] <37, Warning, General> - Warning: Unreachable code detected
118118
Line 28006[15,33] <37, Warning, General> - Warning: Unreachable code detected
119119
Line 28009[12,61] <37, Warning, General> - Warning: Unreachable code detected
120120
Line 28010[12,66] <37, Warning, General> - Warning: Unreachable code detected
121121
Line 28024[12,32] <37, Warning, General> - Warning: Unreachable code detected
122-
Line 28029[12,45] <37, Warning, General> - Warning: Unreachable code detected
122+
Range (28029, 12) -> (28031, 45) <37, Warning, General> - Warning: Unreachable code detected
123123
Line 28032[14,21] <37, Warning, General> - Warning: Unreachable code detected
124124
Line 28035[12,31] <37, Warning, General> - Warning: Unreachable code detected
125125
Line 28036[15,34] <37, Warning, General> - Warning: Unreachable code detected
126126
Line 28039[19,55] <37, Warning, General> - Warning: Unreachable code detected
127-
Line 28042[15,48] <37, Warning, General> - Warning: Unreachable code detected
127+
Range (28042, 15) -> (28044, 48) <37, Warning, General> - Warning: Unreachable code detected
128128
Line 28045[18,25] <37, Warning, General> - Warning: Unreachable code detected
129129
Line 28047[15,46] <37, Warning, General> - Warning: Unreachable code detected
130130
Line 28049[18,37] <37, Warning, General> - Warning: Unreachable code detected
131131
Line 28050[15,18] <37, Warning, General> - Warning: Unreachable code detected
132132
Line 28055[12,15] <37, Warning, General> - Warning: Unreachable code detected
133-
Line 28068[12,44] <37, Warning, General> - Warning: Unreachable code detected
133+
Range (28068, 12) -> (28070, 44) <37, Warning, General> - Warning: Unreachable code detected
134134
Line 28071[14,21] <37, Warning, General> - Warning: Unreachable code detected
135135
Line 28074[12,31] <37, Warning, General> - Warning: Unreachable code detected
136136
Line 28075[14,33] <37, Warning, General> - Warning: Unreachable code detected
137137
Line 28078[12,15] <37, Warning, General> - Warning: Unreachable code detected
138138
Line 28083[12,29] <37, Warning, General> - Warning: Unreachable code detected
139139
Line 28086[14,37] <37, Warning, General> - Warning: Unreachable code detected
140-
Line 28090[14,54] <37, Warning, General> - Warning: Unreachable code detected
140+
Range (28090, 14) -> (28092, 54) <37, Warning, General> - Warning: Unreachable code detected
141141
Line 28093[16,40] <37, Warning, General> - Warning: Unreachable code detected
142142
Line 28095[14,45] <37, Warning, General> - Warning: Unreachable code detected
143143
Line 28096[16,62] <37, Warning, General> - Warning: Unreachable code detected
@@ -149,11 +149,11 @@ Line 28112[22,54] <37, Warning, General> - Warning: Unreachable code detected
149149
Line 28113[20,23] <37, Warning, General> - Warning: Unreachable code detected
150150
Line 28121[12,29] <37, Warning, General> - Warning: Unreachable code detected
151151
Line 28123[14,37] <37, Warning, General> - Warning: Unreachable code detected
152-
Line 28142[12,47] <37, Warning, General> - Warning: Unreachable code detected
152+
Range (28142, 12) -> (28145, 47) <37, Warning, General> - Warning: Unreachable code detected
153153
Line 28146[15,22] <37, Warning, General> - Warning: Unreachable code detected
154-
Line 28159[12,36] <37, Warning, General> - Warning: Unreachable code detected
155-
Line 28168[12,35] <37, Warning, General> - Warning: Unreachable code detected
156-
Line 28173[14,44] <37, Warning, General> - Warning: Unreachable code detected
154+
Range (28159, 12) -> (28160, 36) <37, Warning, General> - Warning: Unreachable code detected
155+
Range (28168, 12) -> (28172, 35) <37, Warning, General> - Warning: Unreachable code detected
156+
Range (28173, 14) -> (28174, 44) <37, Warning, General> - Warning: Unreachable code detected
157157
Line 28175[14,37] <37, Warning, General> - Warning: Unreachable code detected
158158
Line 28176[12,15] <37, Warning, General> - Warning: Unreachable code detected
159159
Line 28181[16,46] <37, Warning, General> - Warning: Unreachable code detected
@@ -166,7 +166,7 @@ Line 28187[20,47] <37, Warning, General> - Warning: Unreachable code detected
166166
Line 28189[22,42] <37, Warning, General> - Warning: Unreachable code detected
167167
Line 28193[14,17] <37, Warning, General> - Warning: Unreachable code detected
168168
Line 28208[12,42] <37, Warning, General> - Warning: Unreachable code detected
169-
Line 28209[15,39] <37, Warning, General> - Warning: Unreachable code detected
169+
Range (28209, 15) -> (28210, 39) <37, Warning, General> - Warning: Unreachable code detected
170170
Line 28213[17,37] <37, Warning, General> - Warning: Unreachable code detected
171171
Line 28214[15,18] <37, Warning, General> - Warning: Unreachable code detected
172172
Line 28219[18,38] <37, Warning, General> - Warning: Unreachable code detected
@@ -186,7 +186,7 @@ Line 28313[12,19] <37, Warning, General> - Warning: Unreachable code detected
186186
Line 28327[8,32] <37, Warning, General> - Warning: Paragraph 'CGBCALAK-SYSPUNCH-SUITE' is empty
187187
Line 28644[12,33] <37, Warning, General> - Warning: Unreachable code detected
188188
Line 28687[12,36] <37, Warning, General> - Warning: Unreachable code detected
189-
Line 28688[13,32] <37, Warning, General> - Warning: Unreachable code detected
189+
Range (28688, 13) -> (28689, 32) <37, Warning, General> - Warning: Unreachable code detected
190190
Line 28690[14,33] <37, Warning, General> - Warning: Unreachable code detected
191191
Line 28691[15,38] <37, Warning, General> - Warning: Unreachable code detected
192192
Line 28692[16,37] <37, Warning, General> - Warning: Unreachable code detected
@@ -196,7 +196,7 @@ Line 28702[12,48] <37, Warning, General> - Warning: Unreachable code detected
196196
Line 28703[13,32] <37, Warning, General> - Warning: Unreachable code detected
197197
Line 28704[14,33] <37, Warning, General> - Warning: Unreachable code detected
198198
Line 28705[15,46] <37, Warning, General> - Warning: Unreachable code detected
199-
Line 28714[12,44] <37, Warning, General> - Warning: Unreachable code detected
199+
Range (28714, 12) -> (28715, 44) <37, Warning, General> - Warning: Unreachable code detected
200200
Line 28717[15,34] <37, Warning, General> - Warning: Unreachable code detected
201201
Line 28719[18,36] <37, Warning, General> - Warning: Unreachable code detected
202202
Line 28777[12,34] <37, Warning, General> - Warning: Unreachable code detected
@@ -208,9 +208,9 @@ Line 28809[13,37] <37, Warning, General> - Warning: Unreachable code detected
208208
Line 28813[14,58] <37, Warning, General> - Warning: Unreachable code detected
209209
Line 28814[13,16] <37, Warning, General> - Warning: Unreachable code detected
210210
Line 28817[13,58] <37, Warning, General> - Warning: Unreachable code detected
211-
Line 28842[12,36] <37, Warning, General> - Warning: Unreachable code detected
212-
Line 28851[12,35] <37, Warning, General> - Warning: Unreachable code detected
213-
Line 28856[14,44] <37, Warning, General> - Warning: Unreachable code detected
211+
Range (28842, 12) -> (28843, 36) <37, Warning, General> - Warning: Unreachable code detected
212+
Range (28851, 12) -> (28855, 35) <37, Warning, General> - Warning: Unreachable code detected
213+
Range (28856, 14) -> (28857, 44) <37, Warning, General> - Warning: Unreachable code detected
214214
Line 28858[14,37] <37, Warning, General> - Warning: Unreachable code detected
215215
Line 28859[12,15] <37, Warning, General> - Warning: Unreachable code detected
216216
Line 28863[16,46] <37, Warning, General> - Warning: Unreachable code detected
@@ -223,7 +223,7 @@ Line 28869[20,47] <37, Warning, General> - Warning: Unreachable code detected
223223
Line 28871[22,42] <37, Warning, General> - Warning: Unreachable code detected
224224
Line 28875[14,17] <37, Warning, General> - Warning: Unreachable code detected
225225
Line 28913[12,30] <37, Warning, General> - Warning: Unreachable code detected
226-
Line 28914[12,31] <37, Warning, General> - Warning: Unreachable code detected
226+
Range (28914, 12) -> (28915, 31) <37, Warning, General> - Warning: Unreachable code detected
227227
Line 28916[13,31] <37, Warning, General> - Warning: Unreachable code detected
228228
Line 28920[14,48] <37, Warning, General> - Warning: Unreachable code detected
229229
Line 28921[15,33] <37, Warning, General> - Warning: Unreachable code detected
@@ -236,7 +236,7 @@ Line 29421[13,18] <37, Warning, General> - Warning: a End statement is not align
236236
Line 29550[20,71] <37, Warning, General> - Warning: Moving alphanumeric 'WS-CMM010-CODE-CADRAGE-JJ' to numeric 'WS-CMM010-CADR-BIN' declared with an USAGE may lead to unexpected results.
237237
Line 29627[16,21] <37, Warning, General> - Warning: a End statement is not aligned with the matching opening statement
238238
Line 29628[16,21] <37, Warning, General> - Warning: a End statement is not aligned with the matching opening statement
239-
Line 29685[24,46] <37, Warning, General> - Warning: Moving alphanumeric 'WS-CMM010-CODE-CADRAGE-JJ' to numeric 'WS-CMM010-CADR-BIN' declared with an USAGE may lead to unexpected results.
240-
Line 29772[12,17] <37, Warning, General> - Warning: "end-if" is missing
241-
Line 29776[16,21] <37, Warning, General> - Warning: "end-if" is missing
239+
Range (29685, 24) -> (29686, 46) <37, Warning, General> - Warning: Moving alphanumeric 'WS-CMM010-CODE-CADRAGE-JJ' to numeric 'WS-CMM010-CADR-BIN' declared with an USAGE may lead to unexpected results.
240+
Range (29772, 12) -> (29773, 17) <37, Warning, General> - Warning: "end-if" is missing
241+
Range (29776, 16) -> (29777, 21) <37, Warning, General> - Warning: "end-if" is missing
242242
Line 31035[21,26] <37, Warning, General> - Warning: a End statement is not aligned with the matching opening statement

0 commit comments

Comments
 (0)