mirror of
https://github.com/github/codeql.git
synced 2026-04-28 10:15:14 +02:00
Python: Autoformat everything using qlformat.
Will need subsequent PRs fixing up test failures (due to deprecated methods moving around), but other than that everything should be straight-forward.
This commit is contained in:
@@ -9,15 +9,15 @@ import python
|
||||
import external.CodeDuplication
|
||||
|
||||
predicate lexically_sorted(DuplicateBlock dup1, DuplicateBlock dup2) {
|
||||
dup1.sourceFile().getAbsolutePath() < dup2.sourceFile().getAbsolutePath()
|
||||
or
|
||||
dup1.sourceFile().getAbsolutePath() = dup2.sourceFile().getAbsolutePath() and
|
||||
dup1.sourceStartLine() < dup2.sourceStartLine()
|
||||
dup1.sourceFile().getAbsolutePath() < dup2.sourceFile().getAbsolutePath()
|
||||
or
|
||||
dup1.sourceFile().getAbsolutePath() = dup2.sourceFile().getAbsolutePath() and
|
||||
dup1.sourceStartLine() < dup2.sourceStartLine()
|
||||
}
|
||||
|
||||
from DuplicateBlock dup1, DuplicateBlock dup2
|
||||
where
|
||||
dup1.getEquivalenceClass() = dup2.getEquivalenceClass() and
|
||||
lexically_sorted(dup1, dup2)
|
||||
dup1.getEquivalenceClass() = dup2.getEquivalenceClass() and
|
||||
lexically_sorted(dup1, dup2)
|
||||
select dup1.toString(), dup2.toString(), dup1.sourceFile().getShortName(), dup1.sourceStartLine(),
|
||||
dup1.sourceEndLine()
|
||||
dup1.sourceEndLine()
|
||||
|
||||
@@ -9,18 +9,18 @@ import python
|
||||
import external.CodeDuplication
|
||||
|
||||
predicate mostlyDuplicateFunction(Function f) {
|
||||
exists(int covered, int total, Function other, int percent |
|
||||
duplicateStatements(f, other, covered, total) and
|
||||
covered != total and
|
||||
total > 5 and
|
||||
covered * 100 / total = percent and
|
||||
percent > 80 and
|
||||
not exists(Scope s | s = f.getScope*() | duplicateScopes(s, _, _, _))
|
||||
)
|
||||
exists(int covered, int total, Function other, int percent |
|
||||
duplicateStatements(f, other, covered, total) and
|
||||
covered != total and
|
||||
total > 5 and
|
||||
covered * 100 / total = percent and
|
||||
percent > 80 and
|
||||
not exists(Scope s | s = f.getScope*() | duplicateScopes(s, _, _, _))
|
||||
)
|
||||
}
|
||||
|
||||
from Stmt s
|
||||
where
|
||||
mostlyDuplicateFunction(s.getScope()) and
|
||||
not duplicateStatement(s.getScope(), _, s, _)
|
||||
mostlyDuplicateFunction(s.getScope()) and
|
||||
not duplicateStatement(s.getScope(), _, s, _)
|
||||
select s.toString(), s.getLocation().toString()
|
||||
|
||||
@@ -9,14 +9,14 @@ import python
|
||||
import external.CodeDuplication
|
||||
|
||||
predicate lexically_sorted(SimilarBlock dup1, SimilarBlock dup2) {
|
||||
dup1.sourceFile().getAbsolutePath() < dup2.sourceFile().getAbsolutePath()
|
||||
or
|
||||
dup1.sourceFile().getAbsolutePath() = dup2.sourceFile().getAbsolutePath() and
|
||||
dup1.sourceStartLine() < dup2.sourceStartLine()
|
||||
dup1.sourceFile().getAbsolutePath() < dup2.sourceFile().getAbsolutePath()
|
||||
or
|
||||
dup1.sourceFile().getAbsolutePath() = dup2.sourceFile().getAbsolutePath() and
|
||||
dup1.sourceStartLine() < dup2.sourceStartLine()
|
||||
}
|
||||
|
||||
from SimilarBlock dup1, SimilarBlock dup2
|
||||
where
|
||||
dup1.getEquivalenceClass() = dup2.getEquivalenceClass() and
|
||||
lexically_sorted(dup1, dup2)
|
||||
dup1.getEquivalenceClass() = dup2.getEquivalenceClass() and
|
||||
lexically_sorted(dup1, dup2)
|
||||
select dup1, dup2, dup1.sourceFile().getShortName(), dup1.sourceStartLine(), dup1.sourceEndLine()
|
||||
|
||||
Reference in New Issue
Block a user