/* * 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 <http://www.gnu.org/licenses/>. * * Copyright 2011-2015 Jean-Rémy Falleri <jr.falleri@gmail.com> * Copyright 2011-2015 Floréal Morandat <florealm@gmail.com> */ package com.github.gumtreediff.actions; import java.util.List; import java.util.Set; import com.github.gumtreediff.actions.model.Delete; import com.github.gumtreediff.actions.model.Update; import com.github.gumtreediff.actions.model.Action; import com.github.gumtreediff.actions.model.Delete; import com.github.gumtreediff.actions.model.Insert; import com.github.gumtreediff.actions.model.Move; import com.github.gumtreediff.actions.model.Update; import com.github.gumtreediff.matchers.Mapping; import com.github.gumtreediff.matchers.Matcher; import com.github.gumtreediff.tree.ITree; import com.github.gumtreediff.tree.TreeContext; public class LeavesClassifier extends TreeClassifier { public LeavesClassifier(TreeContext src, TreeContext dst, Set<Mapping> rawMappings, List<Action> actions) { super(src, dst, rawMappings, actions); } public LeavesClassifier(TreeContext src, TreeContext dst, Matcher m) { super(src, dst, m); } @Override public void classify() { for (Action a: actions) { if (a instanceof Delete && isLeafAction(a)) { srcDelTrees.add(a.getNode()); } else if (a instanceof Insert && isLeafAction(a)) { dstAddTrees.add(a.getNode()); } else if (a instanceof Update && isLeafAction(a)) { srcUpdTrees.add(a.getNode()); dstUpdTrees.add(mappings.getDst(a.getNode())); } else if (a instanceof Move && isLeafAction(a)) { srcMvTrees.add(a.getNode()); dstMvTrees.add(mappings.getDst(a.getNode())); } } } private boolean isLeafAction(Action a) { for (ITree d: a.getNode().getDescendants()) { for (Action c: actions) if (a != c && d == c.getNode()) return false; } return true; } }