From cf8375d61273f69839ec3dbaad3b28e65be812f4 Mon Sep 17 00:00:00 2001 From: KuechA <31155350+KuechA@users.noreply.github.com> Date: Sun, 11 Jun 2023 17:01:18 +0200 Subject: [PATCH] Infer DFG for calls to implicit functions (#1197) --- .../de/fraunhofer/aisec/cpg/passes/DFGPass.kt | 16 ++++++++++------ .../aisec/cpg/passes/UnresolvedDFGPassTest.kt | 8 +++----- 2 files changed, 13 insertions(+), 11 deletions(-) diff --git a/cpg-core/src/main/kotlin/de/fraunhofer/aisec/cpg/passes/DFGPass.kt b/cpg-core/src/main/kotlin/de/fraunhofer/aisec/cpg/passes/DFGPass.kt index d1d3ec7202..6e9ab553d9 100644 --- a/cpg-core/src/main/kotlin/de/fraunhofer/aisec/cpg/passes/DFGPass.kt +++ b/cpg-core/src/main/kotlin/de/fraunhofer/aisec/cpg/passes/DFGPass.kt @@ -388,11 +388,15 @@ class DFGPass(ctx: TranslationContext) : ComponentPass(ctx) { if (call.invokes.isEmpty() && inferDfgForUnresolvedSymbols) { // Unresolved call expression - handleUnresolvedCalls(call) + handleUnresolvedCalls(call, call) } else if (call.invokes.isNotEmpty()) { call.invokes.forEach { - Util.attachCallParameters(it, call.arguments) - call.addPrevDFG(it) + if (it.isInferred && inferDfgForUnresolvedSymbols) { + handleUnresolvedCalls(call, it) + } else { + Util.attachCallParameters(it, call.arguments) + call.addPrevDFG(it) + } } } } @@ -402,11 +406,11 @@ class DFGPass(ctx: TranslationContext) : ComponentPass(ctx) { * - from base (if available) to the CallExpression * - from all arguments to the CallExpression */ - private fun handleUnresolvedCalls(call: CallExpression) { + private fun handleUnresolvedCalls(call: CallExpression, dfgTarget: Node) { if (call is MemberCallExpression && !call.isStatic) { - call.base?.let { call.addPrevDFG(it) } + call.base?.let { dfgTarget.addPrevDFG(it) } } - call.arguments.forEach { call.addPrevDFG(it) } + call.arguments.forEach { dfgTarget.addPrevDFG(it) } } } diff --git a/cpg-core/src/test/kotlin/de/fraunhofer/aisec/cpg/passes/UnresolvedDFGPassTest.kt b/cpg-core/src/test/kotlin/de/fraunhofer/aisec/cpg/passes/UnresolvedDFGPassTest.kt index 72eb1dfee4..f5ecc5d7e7 100644 --- a/cpg-core/src/test/kotlin/de/fraunhofer/aisec/cpg/passes/UnresolvedDFGPassTest.kt +++ b/cpg-core/src/test/kotlin/de/fraunhofer/aisec/cpg/passes/UnresolvedDFGPassTest.kt @@ -149,16 +149,14 @@ class UnresolvedDFGPassTest { } declare { variable("s2", t("String")) { - memberCall("get", ref("os")) { - addArgument(literal(4, t("int"))) - } + memberCall("get", ref("os")) { literal(4, t("int")) } } } declare { variable("duc", t("DfgUnresolvedCalls")) { new { construct("DfgUnresolvedCalls") { - addArgument(literal(3, t("int"))) + literal(3, t("int")) } } } @@ -166,7 +164,7 @@ class UnresolvedDFGPassTest { declare { variable("i", t("int")) { memberCall("knownFunction", ref("duc")) { - addArgument(literal(2, t("int"))) + literal(2, t("int")) } } }