All Downloads are FREE. Search and download functionalities are using the official Maven repository.
Please wait. This can take some minutes ...
Many resources are needed to download a project. Please understand that we have to compensate our server costs. Thank you in advance.
Project price only 1 $
You can buy this project and download/modify it how often you want.
org.refactoringminer.astDiff.matchers.LeafMatcher Maven / Gradle / Ivy
package org.refactoringminer.astDiff.matchers;
import com.github.gumtreediff.matchers.CompositeMatchers;
import com.github.gumtreediff.matchers.MappingStore;
import com.github.gumtreediff.matchers.optimizations.*;
import com.github.gumtreediff.tree.Tree;
import com.github.gumtreediff.utils.Pair;
import gr.uom.java.xmi.decomposition.AbstractCodeMapping;
import org.refactoringminer.astDiff.utils.TreeUtilFunctions;
import java.util.HashMap;
import java.util.Map;
/**
* @author Pourya Alikhani Fard [email protected]
*/
public class LeafMatcher extends BasicTreeMatcher implements TreeMatcher {
private boolean overwrite = false;
public LeafMatcher() {}
public LeafMatcher setOverwrite(boolean overwrite) {
this.overwrite = overwrite;
return this;
}
@Override
public void match(Tree src, Tree dst, ExtendedMultiMappingStore mappingStore) {
if (src == null || dst == null) return;
Map srcCopy = new HashMap<>();
Map dstCopy = new HashMap<>();
Pair prunedPair = pruneTrees(src, dst, srcCopy, dstCopy);
MappingStore match;
try {
if (prunedPair.first.isIsoStructuralTo(prunedPair.second))
{
if (!TreeUtilFunctions.isIsomorphicTo(prunedPair.first,prunedPair.second))
{
match = new MoveOptimizedIsomorphic().match(prunedPair.first, prunedPair.second);
}
else{
match = new MappingStore(src, dst);
match.addMappingRecursively(prunedPair.first, prunedPair.second);
}
}
else {
match = process(prunedPair.first, prunedPair.second);
}
if (!overwrite)
mappingStore.addWithMaps(match, srcCopy, dstCopy);
else
mappingStore.replaceWithMaps(match, srcCopy, dstCopy);
}
catch (Exception exception)
{
System.out.println(exception.getMessage());
}
}
public Pair pruneTrees(Tree src, Tree dst, Map srcCopy, Map dstCopy) {
Tree prunedSrc = TreeUtilFunctions.deepCopyWithMapPruning(src,srcCopy);
Tree prunedDst = TreeUtilFunctions.deepCopyWithMapPruning(dst,dstCopy);
return new Pair<>(prunedSrc,prunedDst);
}
private void specialCases(Tree src, Tree dst, AbstractCodeMapping abstractCodeMapping, ExtendedMultiMappingStore mappingStore) {
String EXP_STATEMENT = Constants.EXPRESSION_STATEMENT;
String VAR_DEC_STATEMENT = Constants.VARIABLE_DECLARATION_STATEMENT;
Tree expTree,varTree;
boolean expFirst;
Tree assignment_operator = null;
Tree assignment,varFrag;
assignment = varFrag = null;
if (src.getType().name.equals(EXP_STATEMENT) && dst.getType().name.equals(VAR_DEC_STATEMENT))
{
expTree = src;
varTree = dst;
expFirst = true;
if (varTree.getChildren().size() > 1)
{
varFrag = varTree.getChild(1);
}
if (expTree.getChildren().size() > 0)
{
if (expTree.getChild(0).getType().name.equals(Constants.ASSIGNMENT))
{
assignment = expTree.getChild(0);
for(Tree child : assignment.getChildren())
{
if (child.getType().name.equals(Constants.ASSIGNMENT_OPERATOR) && child.getLabel().equals(Constants.EQUAL_OPERATOR))
{
assignment_operator = child;
break;
}
}
}
}
}
else if (src.getType().name.equals(VAR_DEC_STATEMENT) && dst.getType().name.equals(EXP_STATEMENT))
{
expTree = dst;
varTree = src;
expFirst = false;
if (varTree.getChildren().size() > 1)
{
varFrag = varTree.getChild(1);
}
if (expTree.getChildren().size() > 0)
{
if (expTree.getChild(0).getType().name.equals(Constants.ASSIGNMENT))
{
assignment = expTree.getChild(0);
for(Tree child : assignment.getChildren())
{
if (child.getType().name.equals(Constants.ASSIGNMENT_OPERATOR) && child.getLabel().equals(Constants.EQUAL_OPERATOR))
{
assignment_operator = child;
break;
}
}
}
}
}
else
{
//TODO : nothing for now;
return;
}
if (expFirst)
{
mappingStore.addMapping(assignment,varFrag);
mappingStore.addMapping(expTree,varTree);
mappingStore.addMapping(assignment_operator, TreeUtilFunctions.getFakeTreeInstance());
}
else {
mappingStore.addMapping(varFrag,assignment);
mappingStore.addMapping(varTree,expTree);
mappingStore.addMapping(TreeUtilFunctions.getFakeTreeInstance(),assignment_operator);
}
}
static class MoveOptimizedIsomorphic extends CompositeMatchers.CompositeMatcher {
public MoveOptimizedIsomorphic() {
super(
(src, dst, mappings) -> {
if (TreeUtilFunctions.isIsomorphicTo(src,dst))
mappings.addMappingRecursively(src,dst);
return mappings;
}
, new LcsOptMatcherThetaB()
, new UnmappedLeavesMatcherThetaC()
, new InnerNodesMatcherThetaD()
, new LeafMoveMatcherThetaE()
, new CrossMoveMatcherThetaF()
);
}
}
}