mirror of
https://github.com/github/codeql.git
synced 2025-12-16 16:53:25 +01:00
Java: Improve the diagnostics consistency query
Diagnostics can be easier to read if you see them in the order in which
they were generated. By selecting the compilation and indexes, they get
sorted by the testsuite driver.
d.getCompilationInfo(c, f, i) would be a bit more natural as
d = c.getDiagnostic(f, i), but currently we don't import Diagnostic into
the default ('import java') namespace, and I don't think it's worth
changing that for this.
This commit is contained in:
@@ -28,7 +28,8 @@ string diagnosticMessage(Diagnostic d) {
|
||||
// something is fixed.
|
||||
query predicate unusedDiagnosticException(DiagnosticException de) { not exists(de.getException()) }
|
||||
|
||||
query predicate unexpectedDiagnostic(Diagnostic d, string s) {
|
||||
query predicate unexpectedDiagnostic(Compilation c, int f, int i, Diagnostic d, string s) {
|
||||
d.getCompilationInfo(c, f, i) and
|
||||
s = diagnosticMessage(d) and
|
||||
not d = any(DiagnosticException de).getException()
|
||||
}
|
||||
|
||||
@@ -0,0 +1,4 @@
|
||||
---
|
||||
category: feature
|
||||
---
|
||||
* A `Diagnostic.getCompilationInfo()` predicate has been added.
|
||||
@@ -9,6 +9,11 @@ class Diagnostic extends @diagnostic {
|
||||
/** Gets the compilation that generated this diagnostic. */
|
||||
Compilation getCompilation() { diagnostic_for(this, result, _, _) }
|
||||
|
||||
/** Gets the compilation information for this diagnostic. */
|
||||
predicate getCompilationInfo(Compilation c, int fileNumber, int diagnosticNumber) {
|
||||
diagnostic_for(this, c, fileNumber, diagnosticNumber)
|
||||
}
|
||||
|
||||
/**
|
||||
* Gets the program that generated this diagnostic.
|
||||
*/
|
||||
|
||||
Reference in New Issue
Block a user