From 8bd6779e7c1af8048db8cf20adb0e132be349890 Mon Sep 17 00:00:00 2001 From: Raffi Khatchadourian Date: Tue, 19 Dec 2023 23:41:27 -0500 Subject: [PATCH] It should be a for each element get instruction. --- .../PythonSSAPropagationCallGraphBuilder.java | 53 +++++++++---------- 1 file changed, 24 insertions(+), 29 deletions(-) diff --git a/com.ibm.wala.cast.python/source/com/ibm/wala/cast/python/ipa/callgraph/PythonSSAPropagationCallGraphBuilder.java b/com.ibm.wala.cast.python/source/com/ibm/wala/cast/python/ipa/callgraph/PythonSSAPropagationCallGraphBuilder.java index 83ea58b8f..5c0bf6308 100644 --- a/com.ibm.wala.cast.python/source/com/ibm/wala/cast/python/ipa/callgraph/PythonSSAPropagationCallGraphBuilder.java +++ b/com.ibm.wala.cast.python/source/com/ibm/wala/cast/python/ipa/callgraph/PythonSSAPropagationCallGraphBuilder.java @@ -12,8 +12,8 @@ import com.ibm.wala.cast.ipa.callgraph.AstSSAPropagationCallGraphBuilder; import com.ibm.wala.cast.ipa.callgraph.GlobalObjectKey; -import com.ibm.wala.cast.ir.ssa.AstGlobalRead; import com.ibm.wala.cast.ir.ssa.AstPropertyRead; +import com.ibm.wala.cast.ir.ssa.EachElementGetInstruction; import com.ibm.wala.cast.python.ipa.summaries.BuiltinFunctions.BuiltinFunction; import com.ibm.wala.cast.python.ir.PythonLanguage; import com.ibm.wala.cast.python.ssa.PythonInstructionVisitor; @@ -187,34 +187,29 @@ public void visitPropertyRead(AstPropertyRead instruction) { PythonPropertyRead ppr = (PythonPropertyRead) instruction; SSAInstruction memberRefDef = du.getDef(ppr.getMemberRef()); - if (memberRefDef != null && memberRefDef instanceof AstGlobalRead) { - AstGlobalRead agr = (AstGlobalRead) memberRefDef; - - if (agr.isStatic()) { - // most likely a for each "property." - final PointerKey memberRefKey = this.getPointerKeyForLocal(ppr.getMemberRef()); - - // for each def of the property read. - for (int i = 0; i < ppr.getNumberOfDefs(); i++) { - PointerKey defKey = this.getPointerKeyForLocal(ppr.getDef(i)); - - // add an assignment constraint straight away as the traversal variable won't have a - // non-empty points-to set but still may be used for a dataflow analysis. - if (this.system.newConstraint(defKey, assignOperator, memberRefKey)) - logger.fine( - () -> - "Added new system constraint for global read from: " - + defKey - + " to: " - + memberRefKey - + " for instruction: " - + instruction - + "."); - else - logger.fine( - () -> - "No constraint added for global read in instruction: " + instruction + "."); - } + if (memberRefDef != null && memberRefDef instanceof EachElementGetInstruction) { + // most likely a for each "property." + final PointerKey memberRefKey = this.getPointerKeyForLocal(ppr.getMemberRef()); + + // for each def of the property read. + for (int i = 0; i < ppr.getNumberOfDefs(); i++) { + PointerKey defKey = this.getPointerKeyForLocal(ppr.getDef(i)); + + // add an assignment constraint straight away as the traversal variable won't have a + // non-empty points-to set but still may be used for a dataflow analysis. + if (this.system.newConstraint(defKey, assignOperator, memberRefKey)) + logger.fine( + () -> + "Added new system constraint for global read from: " + + defKey + + " to: " + + memberRefKey + + " for instruction: " + + instruction + + "."); + else + logger.fine( + () -> "No constraint added for global read in instruction: " + instruction + "."); } } }