com.github.gumtreediff.actions.OnlyRootsClassifier Maven / Gradle / Ivy
The newest version!
/*
* This file is part of GumTree.
*
* GumTree is free software: you can redistribute it and/or modify
* it under the terms of the GNU Lesser General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* GumTree is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public License
* along with GumTree. If not, see .
*
* Copyright 2011-2015 Jean-Rémy Falleri
* Copyright 2011-2015 Floréal Morandat
*/
package com.github.gumtreediff.actions;
import com.github.gumtreediff.actions.model.*;
import com.github.gumtreediff.actions.model.Delete;
import com.github.gumtreediff.tree.Tree;
import java.util.HashSet;
import java.util.Set;
/**
* Partition only root (of a complete subtree) moved, inserted, updated or deleted nodes.
*/
public class OnlyRootsClassifier extends AbstractITreeClassifier {
public OnlyRootsClassifier(Diff diff) {
super(diff);
}
@Override
public void classify() {
Set insertedDsts = new HashSet<>();
for (Action a: diff.editScript)
if (a instanceof Insert)
insertedDsts.add(a.getNode());
Set deletedSrcs = new HashSet<>();
for (Action a: diff.editScript)
if (a instanceof Delete)
deletedSrcs.add(a.getNode());
for (Action a: diff.editScript) {
if (a instanceof TreeDelete)
srcDelTrees.add(a.getNode());
else if (a instanceof Delete) {
if (!(deletedSrcs.containsAll(a.getNode().getDescendants())
&& deletedSrcs.contains(a.getNode().getParent())))
srcDelTrees.add(a.getNode());
}
else if (a instanceof Insert) {
if (!(insertedDsts.containsAll(a.getNode().getDescendants())
&& insertedDsts.contains(a.getNode().getParent())))
dstAddTrees.add(a.getNode());
}
else if (a instanceof TreeInsert )
dstAddTrees.add(a.getNode());
else if (a instanceof Update) {
srcUpdTrees.add(a.getNode());
dstUpdTrees.add(diff.mappings.getDstForSrc(a.getNode()));
}
else if (a instanceof Move) {
srcMvTrees.add(a.getNode());
dstMvTrees.add(diff.mappings.getDstForSrc(a.getNode()));
}
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy