зеркало из https://github.com/github/codeql.git
Merge pull request #547 from pavgust/fix/cwe-497-performance
C++: Refactor CWE-497 for clarity and performance
This commit is contained in:
Коммит
7aef8fa945
|
@ -33,14 +33,7 @@ abstract class SystemData extends Element {
|
|||
result = getAnExpr() or
|
||||
|
||||
// flow via global or member variable (conservative approximation)
|
||||
exists(Variable var |
|
||||
(
|
||||
var.getAnAssignedValue() = getAnExprIndirect() or
|
||||
var.getAnAccess() = getAnExprIndirect()
|
||||
) and
|
||||
result = var.getAnAccess() and
|
||||
not var instanceof LocalScopeVariable
|
||||
) or
|
||||
result = getAnAffectedVar().getAnAccess() or
|
||||
|
||||
// flow via stack variable
|
||||
definitionUsePair(_, getAnExprIndirect(), result) or
|
||||
|
@ -50,6 +43,17 @@ abstract class SystemData extends Element {
|
|||
// flow from assigned value to assignment expression
|
||||
result.(AssignExpr).getRValue() = getAnExprIndirect()
|
||||
}
|
||||
|
||||
/** Gets a global or member variable that may be affected by this system
|
||||
* data (conservative approximation).
|
||||
*/
|
||||
private Variable getAnAffectedVar() {
|
||||
(
|
||||
result.getAnAssignedValue() = this.getAnExprIndirect() or
|
||||
result.getAnAccess() = this.getAnExprIndirect()
|
||||
) and
|
||||
not result instanceof LocalScopeVariable
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
|
|
Загрузка…
Ссылка в новой задаче