From 3e4029fca16b320869e45b401980a6aed5d48d44 Mon Sep 17 00:00:00 2001 From: Alexander Kuechler Date: Fri, 9 Feb 2024 15:25:41 +0100 Subject: [PATCH] Handle non-existing list --- .../aisec/cpg/passes/inference/DFGFunctionSummaries.kt | 6 +++++- 1 file changed, 5 insertions(+), 1 deletion(-) diff --git a/cpg-core/src/main/kotlin/de/fraunhofer/aisec/cpg/passes/inference/DFGFunctionSummaries.kt b/cpg-core/src/main/kotlin/de/fraunhofer/aisec/cpg/passes/inference/DFGFunctionSummaries.kt index 789a63d67f5..8239733f6c1 100644 --- a/cpg-core/src/main/kotlin/de/fraunhofer/aisec/cpg/passes/inference/DFGFunctionSummaries.kt +++ b/cpg-core/src/main/kotlin/de/fraunhofer/aisec/cpg/passes/inference/DFGFunctionSummaries.kt @@ -62,6 +62,8 @@ class DFGFunctionSummaries { } private fun findFunctionDeclarationEntry(functionDecl: FunctionDeclaration): List? { + if (functionToDFGEntryMap.isEmpty()) return null + val language = functionDecl.language val languageName = language?.javaClass?.name val methodName = functionDecl.name @@ -82,7 +84,7 @@ class DFGFunctionSummaries { } else if (matchingEntries.filter { it.signature != null }.size == 1) { // Only one entry with a matching signature => We take this one. functionToDFGEntryMap[matchingEntries.single { it.signature != null }] - } else { + } else if (matchingEntries.isNotEmpty()) { /* There are multiple matching entries. We use the following routine: * First, we filter for existing signatures. * Second, we filter for the most precise class. @@ -116,6 +118,8 @@ class DFGFunctionSummaries { mostPreciseClassEntries.sortByDescending { it.signature?.size ?: 0 } } functionToDFGEntryMap[matchingEntries.first()] + } else { + null } }