From 14974440fa6a761b8a9605cf9433f13e8e135236 Mon Sep 17 00:00:00 2001 From: Pouryafard75 Date: Sat, 29 Apr 2023 14:41:04 -0400 Subject: [PATCH] Fix for https://github.com/pouryafard75/RM-ASTDiff/issues/75 Enable the matching of leaf subtrees with the different EXPRESSION_OPERATOR --- .../astDiff/matchers/CustomGTSimple.java | 29 +++++++++++++------ 1 file changed, 20 insertions(+), 9 deletions(-) diff --git a/src/org/refactoringminer/astDiff/matchers/CustomGTSimple.java b/src/org/refactoringminer/astDiff/matchers/CustomGTSimple.java index 48dd693a8b..a5184a8bf6 100644 --- a/src/org/refactoringminer/astDiff/matchers/CustomGTSimple.java +++ b/src/org/refactoringminer/astDiff/matchers/CustomGTSimple.java @@ -52,8 +52,7 @@ private static boolean isAcceptableMatch(Mapping mapping) { mapping.first.getParent().getType().name.equals(Constants.METHOD_INVOCATION)); } - private static boolean isOnlyOneMethodInvocation(Tree input1, Tree input2) - { + private static boolean isOnlyOneMethodInvocation(Tree input1, Tree input2) { if (input1 == null || input2 == null) return false; if (input1.getParent() == null || input2.getParent() == null) return false; if (input1.getParent().getType().name.equals(Constants.METHOD_INVOCATION) && !input2.getParent().getType().name.equals(Constants.METHOD_INVOCATION)) @@ -63,6 +62,7 @@ else if (!input1.getParent().getType().name.equals(Constants.METHOD_INVOCATION) return false; } + private static boolean isPartOfConditional(Tree input) { if (input.getType().name.equals(Constants.CONDITIONAL_EXPRESSION)) return true; @@ -73,8 +73,8 @@ private static boolean isPartOfConditional(Tree input) { return isPartOfConditional(parent); } } - private static boolean isSamePositionInConditional(Tree input1, Tree input2) - { + + private static boolean isSamePositionInConditional(Tree input1, Tree input2) { int input1Index = 0; int input2Index = 0; while (!input1.getParent().getType().name.equals(Constants.CONDITIONAL_EXPRESSION)) @@ -106,11 +106,23 @@ public MappingStore match(Tree src, Tree dst, MappingStore mappings) { for (var currentSrc : currentPrioritySrcTrees) for (var currentDst : currentPriorityDstTrees) - if (currentSrc.getMetrics().hash == currentDst.getMetrics().hash) + if (currentSrc.getMetrics().hash == currentDst.getMetrics().hash) { if (currentSrc.isIsomorphicTo(currentDst)) { - if (!isOnlyOneMethodInvocation(currentSrc,currentDst)) + if (!isOnlyOneMethodInvocation(currentSrc, currentDst)) + multiMappings.addMapping(currentSrc, currentDst); + } + } + else { + if (currentSrc.getLabel().equals(currentDst.getLabel())) + { + if (currentSrc.getType().name.contains("_EXPRESSION_OPERATOR") + && + currentDst.getType().name.contains("_EXPRESSION_OPERATOR")) multiMappings.addMapping(currentSrc, currentDst); } + } + + for (var t : currentPrioritySrcTrees) if (!multiMappings.hasSrc(t)) @@ -123,6 +135,7 @@ public MappingStore match(Tree src, Tree dst, MappingStore mappings) { filterMappings(multiMappings); return this.mappings; } + @Override public void filterMappings(MultiMappingStore multiMappings) { // Select unique mappings first and extract ambiguous mappings. @@ -152,7 +165,6 @@ public void filterMappings(MultiMappingStore multiMappings) { // Rank the mappings by score. Set srcIgnored = new HashSet<>(); Set dstIgnored = new HashSet<>(); - Collections.sort(ambiguousList, new MappingComparators.FullMappingComparator(mappings)); if (ambiguousList.size() > 1) ambiguousStringLiteralModification(ambiguousList,srcIgnored,dstIgnored); @@ -180,8 +192,7 @@ private void ambiguousStringLiteralModification(List ambiguousList, Set } } } - } - else { + } else { break; } }